:root{--paper:#f8f7f2;--ink:#181816;--muted:#65625a;--line:#1f1e1a;--soft:#eeece4;--shade:#ded9ca;--good:#edf7ee;--warn:#fff4d8;--bad:#ffe8e2}*{box-sizing:border-box}html,body{min-height:100%}body{background:var(--paper);color:var(--ink);margin:0;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,select,textarea{color:inherit;font:inherit}button,a{-webkit-tap-highlight-color:transparent}.app-shell{width:min(1180px,100%);margin:0 auto;padding:24px}.hero{border-bottom:2px solid var(--line);grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:20px;padding:34px 0 22px;display:grid}.brand-title{max-width:720px;margin:0 0 8px;font-size:clamp(2.1rem,5.6vw,4.4rem);font-weight:900;line-height:.95}h1,h2,p{overflow-wrap:anywhere}h1{max-width:720px;margin:0;font-family:Georgia,Times New Roman,serif;font-size:clamp(2rem,5vw,4rem);font-weight:500;line-height:1}.hero-copy{max-width:680px;color:var(--muted);margin:16px 0 0;font-size:1.05rem;line-height:1.6}.hero-actions,.button-row,.footer-action,.player-bar{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.steps{grid-template-columns:repeat(6,1fr);gap:8px;margin:20px 0;display:grid}.step,.icon-button,.primary,.secondary,.danger,.file-button,.icon-only{border:2px solid var(--line);min-height:42px;box-shadow:3px 3px 0 var(--line);cursor:pointer;background:#fffdf6;border-radius:7px;justify-content:center;align-items:center;gap:8px;font-weight:800;text-decoration:none;transition:transform .12s,box-shadow .12s,opacity .12s;display:inline-flex}.step{box-shadow:2px 2px 0 var(--line);padding:10px 8px;font-size:.9rem}.step.active,.primary{background:var(--ink);color:var(--paper)}.secondary{background:var(--soft)}.danger{background:var(--bad)}.wide,.primary,.secondary,.danger,.file-button{padding:10px 14px}button:disabled{cursor:not-allowed;opacity:.42}button:not(:disabled):active,a:active,.file-button:active{box-shadow:1px 1px 0 var(--line);transform:translate(2px,2px)}.workspace{min-height:620px}.panel{border:2px solid var(--line);box-shadow:6px 6px 0 var(--line);background-color:#fffdf6;background-image:linear-gradient(#0000 31px,#1818160f 32px),none;background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:100% 32px;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;border-radius:8px;padding:22px}.panel-header{align-items:center;gap:10px;margin-bottom:18px;display:flex}.panel-header span{border:2px solid var(--line);background:var(--paper);border-radius:999px;place-items:center;width:38px;height:38px;display:grid}.panel-header h2,.notebook-card h2,.reader-page h2{margin:0;font-family:Georgia,Times New Roman,serif;font-size:1.65rem;font-weight:500}.upload-zone{border:2px dashed var(--line);text-align:center;background:#f8f7f2b8;border-radius:8px;place-items:center;gap:12px;min-height:230px;padding:28px;display:grid}.upload-zone label{align-items:center;gap:8px;font-size:1.3rem;font-weight:900;display:inline-flex}.upload-zone input,.file-button input{max-width:240px}.file-button{position:relative;overflow:hidden}.file-button input{opacity:0;cursor:pointer;position:absolute;inset:0}.tooltip{display:inline-flex;position:relative}.tooltip span{z-index:5;border:2px solid var(--line);width:min(290px,80vw);box-shadow:3px 3px 0 var(--line);color:var(--ink);opacity:0;pointer-events:none;background:#fffdf6;border-radius:7px;padding:12px;font-size:.86rem;font-weight:600;line-height:1.35;position:absolute;bottom:130%;left:50%;transform:translate(-50%)translateY(4px)}.tooltip:hover span,.tooltip:focus span{opacity:1}.metadata-grid,.settings-grid,.field-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin:18px 0;display:grid}.metric,.notebook-card,.preview-card,.section-card,.reader-page{border:2px solid var(--line);background:#fffdf6eb;border-radius:8px;padding:16px}.metric span,label,.muted{color:var(--muted)}.metric strong{color:var(--ink);margin-top:6px;font-size:1.05rem;display:block}.check-row{color:var(--ink);align-items:flex-start;gap:10px;margin:14px 0;font-weight:700;line-height:1.35;display:flex}.check-row input{width:18px;height:18px;accent-color:var(--ink);flex:none;margin-top:2px}.notice{border:2px solid var(--line);border-radius:8px;align-items:flex-start;gap:10px;margin:16px 0;padding:12px;display:flex}.notice p{margin:0;line-height:1.45}.notice.plain{background:var(--soft)}.notice.good{background:var(--good)}.notice.warn{background:var(--warn)}.notice.bad{background:var(--bad)}.footer-action{justify-content:flex-end;margin-top:20px}.section-list{gap:12px;display:grid}.section-list.compact{gap:8px}.section-card>div{justify-content:space-between;align-items:center;gap:12px;display:flex}.section-card input,label input,textarea,select{border:2px solid var(--line);background:#fffdf6;border-radius:7px;width:100%;padding:10px}textarea{resize:vertical;min-height:92px}.section-index{color:var(--muted);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-weight:900}.section-card p,.notebook-card p,.reader-page p{color:var(--muted);line-height:1.65}.section-card .error-text{color:#8b1f12;margin:8px 46px 0 0;font-size:.9rem;line-height:1.4}.two-column,.reader-layout{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.notebook-card{gap:12px;display:grid}.preview-card{gap:12px;margin-top:16px;display:grid}.preview-card h3{margin:0 0 4px;font-size:1.1rem}.preview-card p{color:var(--muted);margin:0;line-height:1.5}.preview-card audio,.notebook-card audio,.player-bar audio{width:100%}.field-grid{grid-template-columns:repeat(2,minmax(0,1fr));margin:0}label{gap:6px;font-weight:800;display:grid}.settings-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.wide-field{grid-column:1/-1}.progress-wrap{border:2px solid var(--line);background:var(--soft);border-radius:999px;height:18px;overflow:hidden}.progress-wrap div{background:repeating-linear-gradient(45deg, var(--ink), var(--ink) 8px, #444 8px, #444 16px);height:100%;transition:width .24s}.status-card{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px 12px;display:grid}.status-card>div,.status-card .estimate-line,.status-card .error-text{grid-column:1}.status-card .section-action{grid-area:1/2/span 3;align-self:center;min-width:126px}.estimate-line{color:var(--muted);margin:0;font-size:.92rem;line-height:1.45}.pill{border:2px solid var(--line);border-radius:999px;justify-content:center;min-width:92px;padding:5px 8px;font-size:.78rem;font-weight:900;display:inline-flex}.pill.ready{background:var(--good)}.pill.generating{background:var(--warn)}.pill.failed{background:var(--bad)}.icon-only{width:38px;min-height:38px;padding:0}.reader-layout{grid-template-columns:280px minmax(0,1fr)}.chapter-rail{align-content:start;gap:8px;display:grid}.chapter{border:2px solid var(--line);text-align:left;cursor:pointer;background:#fffdf6;border-radius:7px;gap:4px;width:100%;padding:10px;display:grid}.chapter.active{background:var(--ink);color:var(--paper)}.chapter small{color:inherit;opacity:.72}.reader-page{min-height:480px}.reader-page h2{margin-top:20px}.reader-page p{color:var(--ink);font-family:Georgia,Times New Roman,serif;font-size:1.12rem}.player-bar{border-bottom:2px solid var(--line);justify-content:space-between;padding-bottom:14px}@media (max-width:820px){.app-shell{padding:14px}.hero,.two-column,.reader-layout{grid-template-columns:1fr}.steps{grid-template-columns:repeat(3,1fr)}.metadata-grid,.settings-grid,.field-grid{grid-template-columns:1fr}.panel{box-shadow:4px 4px 0 var(--line);padding:16px}.hero-actions,.footer-action,.player-bar{flex-direction:column;align-items:stretch}.hero-actions>*,.footer-action>*,.player-bar>*{width:100%}}@media (max-width:480px){.steps{grid-template-columns:repeat(2,1fr)}.brand-title{font-size:2.9rem}h1{font-size:2.15rem}}
