:root{font-family:Space Grotesk,sans-serif;color:#0c0c0f;background:radial-gradient(circle at top,#f7f1ff,#f6f7fb 40%,#f2f4f8);--accent: #ff6b3d;--accent-2: #2274a5;--ink: #111217;--muted: #6b6f7a;--panel: #ffffff;--shadow: 0 20px 60px rgba(12, 12, 15, .12)}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at top left,rgba(255,217,184,.5),transparent 45%),radial-gradient(circle at top right,rgba(151,211,252,.5),transparent 40%),#f3f4f7}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit;border:none;cursor:pointer}input,select,textarea{font-family:inherit}.app{min-height:100vh}.topbar{display:flex;justify-content:space-between;align-items:center;padding:20px 40px}.brand{display:flex;gap:12px;align-items:center;font-weight:600;letter-spacing:.02em}.brand-mark{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:12px;background:var(--accent);color:#fff;font-weight:700}.top-actions button{padding:10px 16px;border-radius:999px}.primary{background:var(--accent);color:#fff;padding:12px 18px;border-radius:12px;font-weight:600}.ghost{background:#1112170d;color:var(--ink);padding:10px 14px;border-radius:12px}.auth-shell{display:grid;grid-template-columns:1.1fr .9fr;min-height:100vh}.auth-card{padding:80px 80px 40px}.auth-badge{font-size:12px;letter-spacing:.4em;text-transform:uppercase;font-weight:700;color:var(--accent-2)}.auth-header h1{font-family:"Instrument Serif",serif;font-size:48px;margin:12px 0 8px}.auth-header p{color:var(--muted);max-width:360px}.auth-form{display:grid;gap:16px;margin-top:32px;max-width:360px}.auth-form label{display:grid;gap:8px;color:var(--muted)}.auth-form input{padding:12px 14px;border-radius:12px;border:1px solid rgba(0,0,0,.1)}.auth-error{color:#c62828;font-size:14px}.auth-side{padding:80px 60px;display:flex;align-items:center;justify-content:center}.side-panel{background:var(--panel);padding:32px;border-radius:24px;box-shadow:var(--shadow);max-width:320px}.side-panel h2{margin-top:0}.side-panel ul{padding-left:18px;color:var(--muted)}.library{padding:0 40px 40px}.library header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.library header h1{font-size:32px;margin:0}.library .upload{background:var(--accent);color:#fff;padding:12px 18px;border-radius:12px;font-weight:600;cursor:pointer}.library .upload input{display:none}.error{color:#c62828;margin-bottom:12px}.book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px}.book-card{background:var(--panel);padding:20px;border-radius:16px;box-shadow:var(--shadow);text-align:left;transition:transform .2s ease;display:grid;gap:14px}.book-card:hover{transform:translateY(-4px)}.book-card-main{background:transparent;padding:0;text-align:left;display:grid;gap:6px}.book-card-actions{display:flex;gap:8px}.book-card-actions button{flex:1}.danger{background:#c6282814;color:#b71c1c;padding:10px 14px;border-radius:12px}.danger:disabled{opacity:.6;cursor:default}.book-title{display:block;font-weight:600;margin-bottom:6px}.book-meta{color:var(--muted);font-size:14px}.empty{color:var(--muted)}.reader{display:grid;grid-template-columns:320px 1fr;height:calc(100vh - 72px)}.reader-panel{padding:20px;background:#f7f7fa;border-right:1px solid rgba(0,0,0,.05);overflow-y:auto;transition:all .2s ease}.reader-panel h2{margin:12px 0 8px}.reader-panel .section{margin-top:24px;display:grid;gap:12px}.reader-panel label{display:grid;gap:6px;color:var(--muted)}.reader-panel select,.reader-panel input[type=range]{width:100%}.reader-panel .status{color:var(--accent-2);font-size:14px}.reader-main{display:flex;flex-direction:column;background:#fff;min-height:0;min-width:0;overflow:hidden}.reader.collapsed{grid-template-columns:0 1fr}.reader.collapsed .reader-panel{width:0;padding:0;border-right:none;overflow:hidden}.reader-toolbar{display:flex;gap:12px;padding:12px 20px;border-bottom:1px solid rgba(0,0,0,.05)}.reader-toolbar button{background:#11121714;padding:8px 12px;border-radius:10px}.viewer{flex:1;overflow:hidden;min-height:60vh;position:relative;height:100%;width:100%;min-width:0}.preview-app{height:100dvh;min-height:100dvh;display:flex;flex-direction:column;overflow:hidden}.preview-app .preview-reader{flex:1;min-height:0;height:auto;position:relative;overflow:hidden}.preview-reader .viewer{min-height:0}.viewer iframe{width:100%!important;height:100%!important;border:none;display:block}.toc{display:grid;gap:8px}.toc-item{background:#1112170d;padding:8px 10px;border-radius:10px;text-align:left}.preview-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;background:#2274a51f;color:var(--accent-2);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.preview-meta{color:var(--muted);margin-top:-4px;margin-bottom:4px}.preview-note{color:var(--muted);font-size:14px;line-height:1.4;margin-top:8px}.preview-primary{width:100%;margin-top:12px}.preview-status{padding:10px 16px;color:var(--accent-2);border-bottom:1px solid rgba(0,0,0,.05);background:#2274a50a}.preview-cta-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 18px;border-top:1px solid rgba(0,0,0,.06);background:linear-gradient(180deg,#fffffff0,#fff8f3fa)}.preview-cta-copy{display:grid;gap:2px}.preview-cta-copy strong{font-size:14px}.preview-cta-copy span{color:var(--muted);font-size:13px}.preview-panel-backdrop,.reader-panel-backdrop{display:none}.reader-menu-toggle{display:inline-flex;align-items:center;gap:8px}.reader-menu-toggle-icon{width:16px;text-align:center;font-size:16px;line-height:1}.preview-mobile-bottom-cta{display:none}@media (max-width: 960px){.auth-shell{grid-template-columns:1fr}.auth-card{padding:40px 24px}.auth-side{padding:24px}.reader{grid-template-columns:1fr;height:calc(100dvh - 72px);min-height:0;position:relative}.reader-panel{position:absolute;top:0;bottom:0;left:0;width:min(86vw,340px);max-width:calc(100vw - 32px);z-index:40;background:#f7f7fa;box-shadow:0 20px 48px #0003;border-right:1px solid rgba(0,0,0,.08);transform:translate(0);transition:transform .22s ease;padding-bottom:20px;order:0}.reader-main{min-height:0}.reader.collapsed{grid-template-columns:1fr}.reader.collapsed .reader-panel{width:min(86vw,340px);max-width:calc(100vw - 32px);padding:20px;border-right:1px solid rgba(0,0,0,.08);overflow-y:auto;transform:translate(-110%)}.preview-cta-bar{flex-direction:column;align-items:stretch}.preview-app .topbar{padding:12px 16px}.preview-app .brand{gap:10px;font-size:14px}.preview-app .brand-mark{width:30px;height:30px;border-radius:10px;font-size:12px}.preview-app .top-actions{display:none}.preview-app .preview-reader{grid-template-columns:1fr;min-height:0}.preview-app .preview-reader.collapsed{grid-template-columns:1fr}.preview-app .preview-reader .reader-panel{position:absolute;top:0;bottom:0;left:0;width:min(86vw,340px);max-width:calc(100vw - 32px);z-index:40;background:#f7f7fa;box-shadow:0 20px 48px #0003;border-right:1px solid rgba(0,0,0,.08);transform:translate(0);transition:transform .22s ease;padding-bottom:calc(96px + env(safe-area-inset-bottom));order:0}.preview-app .preview-reader.collapsed .reader-panel{width:min(86vw,340px);max-width:calc(100vw - 32px);padding:20px;padding-bottom:calc(96px + env(safe-area-inset-bottom));border-right:1px solid rgba(0,0,0,.08);overflow-y:auto;transform:translate(-110%)}.preview-app .preview-reader .reader-main{min-height:0;min-width:0;padding-bottom:calc(76px + env(safe-area-inset-bottom))}.preview-app .preview-reader .reader-toolbar{gap:8px;padding:10px 12px;overflow-x:auto}.preview-app .preview-reader .reader-toolbar button{white-space:nowrap}.preview-app .preview-reader .preview-primary{display:none}.preview-app .preview-reader .preview-note{line-height:1.35}.preview-app .preview-reader .viewer{min-height:0;width:100%}.preview-app .preview-reader .preview-cta-bar{display:none}.preview-panel-backdrop,.reader-panel-backdrop{display:block;position:absolute;top:0;right:0;bottom:0;left:0;z-index:30;background:#11121757;border:0;padding:0;margin:0;cursor:pointer}.preview-mobile-bottom-cta{position:fixed;left:0;right:0;bottom:0;z-index:60;display:flex;padding:10px 12px calc(10px + env(safe-area-inset-bottom));background:linear-gradient(180deg,#f3f4f7d9,#f3f4f7fa);border-top:1px solid rgba(0,0,0,.08);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.preview-mobile-bottom-cta .primary,.preview-mobile-bottom-cta .ghost{width:100%;text-align:center;justify-content:center;display:inline-flex;align-items:center;min-height:48px;border-radius:14px;font-weight:700}}
