*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#111010;--bg2:#171413;--surface:#1c1917;--surface2:#252220;--surface3:#302b28;
  --border:#3a3330;--border2:#4a4340;
  --text:#e8dfd4;--muted:#9c9085;--dim:#6b6158;
  --gold:#c8956c;--gold-l:#dbb08a;--gold-d:#8a6548;--gold-bg:rgba(200,149,108,.12);
  --green:#5dba7d;--yellow:#d4a855;--red:#c45c4a;--blue:#6bacd4;--teal:#3bb8a0;
  --parchment:#f0e6cc;--parchment2:#e8dcc0;--ink:#2c2418;
  --r:10px;--rs:6px;
}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text);height:100vh;overflow:hidden}
body.lib-mode{overflow:auto}
.hidden{display:none!important}

/* LIBRARY DASHBOARD */
.library-view{min-height:100vh;overflow-y:auto;background:var(--bg);background-image:linear-gradient(180deg,rgba(30,24,18,.6) 0%,transparent 40%),radial-gradient(ellipse at 50% 100%,rgba(30,24,18,.5),transparent 70%)}
.lib-nav{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:.6rem 2rem;background:rgba(10,7,5,.9);backdrop-filter:blur(12px);border-bottom:1px solid rgba(200,149,108,.1)}
.lib-nav-l{display:flex;align-items:center;gap:.5rem}
.lib-brand{color:var(--gold-l);font-size:1.1rem;font-family:'Lora',serif}
.lib-nav-r{display:flex;align-items:center;gap:1rem}
.lib-search-wrap{position:relative}
.lib-search-icon{position:absolute;left:.6rem;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--dim)}
.lib-search{padding:.4rem .6rem .4rem 1.8rem;background:var(--surface2);border:1px solid var(--border);border-radius:20px;color:var(--text);font-size:.78rem;font-family:inherit;width:200px;transition:width .3s}
.lib-search:focus{outline:none;border-color:var(--gold-d);width:260px}
.lib-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-d));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.8rem;text-decoration:none;flex-shrink:0}
.lib-nav-link{color:var(--muted);font-size:.82rem;text-decoration:none;font-family:Inter,sans-serif}
.lib-nav-link:hover{color:var(--gold-l)}
.lib-content{max-width:1200px;margin:0 auto;padding:2.5rem 2rem 4rem}
.lib-header{margin-bottom:2.5rem}
.lib-title{font-family:'Lora',serif;font-size:2rem;color:var(--text);font-weight:700}
.lib-subtitle{color:var(--muted);font-size:.9rem;margin-top:.3rem}
.lib-section{margin-bottom:2.5rem}
.lib-section-head{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}
.lib-section-head h2{font-family:'Lora',serif;font-size:1.15rem;color:var(--text);font-weight:600;position:relative;padding-right:1rem}
.lib-section-head h2::after{content:'';position:absolute;top:50%;right:0;width:0;height:1px;background:var(--border)}
.lib-section-head::after{content:'';flex:1;height:1px;background:var(--border)}

/* Continue Writing row */
.lib-cards-row{display:flex;gap:1rem;overflow-x:auto;padding-bottom:.5rem;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.lib-cards-row::-webkit-scrollbar{height:4px}
.lib-cards-row::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}

/* All Manuscripts grid */
.lib-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}

/* Manuscript card */
.lib-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.2rem;position:relative;transition:border-color .2s,box-shadow .2s;cursor:default}
.lib-card:hover{border-color:rgba(200,149,108,.3);box-shadow:0 4px 20px rgba(0,0,0,.3)}
.lib-card-recent{min-width:260px;flex-shrink:0}
.lib-card-title{font-family:'Lora',serif;font-size:1.05rem;color:var(--text);font-weight:600;margin-bottom:.3rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:50px}
.lib-card-meta{font-size:.72rem;color:var(--muted);margin-bottom:.5rem;line-height:1.5;padding-right:50px}
.lib-card-score{position:absolute;top:1rem;right:1rem;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;border:2px solid}
.lib-card-badge{display:inline-flex;align-items:center;gap:.25rem;font-size:.65rem;padding:.15rem .5rem;border-radius:10px;margin-bottom:.6rem;font-weight:600}
.lib-badge-progress{background:rgba(93,186,125,.12);color:var(--green)}
.lib-badge-needs{background:rgba(196,92,74,.12);color:var(--red)}
.lib-badge-draft{background:rgba(107,97,88,.15);color:var(--muted)}
.lib-badge-analyzed{background:rgba(93,186,125,.12);color:var(--green)}
.lib-card-actions{display:flex;gap:.4rem;margin-top:.6rem}
.lib-card-actions button{padding:.3rem .7rem;font-size:.72rem;font-weight:600;border-radius:var(--rs);cursor:pointer;font-family:inherit;transition:.2s}
.lib-btn-open{background:var(--surface2);border:1px solid var(--border);color:var(--text)}
.lib-btn-open:hover{border-color:var(--gold-d);color:var(--gold-l)}
.lib-btn-analyze{background:linear-gradient(135deg,var(--gold),var(--gold-d));border:none;color:#fff}
.lib-btn-analyze:hover{opacity:.9}
.lib-btn-more{background:none;border:1px solid var(--border);color:var(--dim);padding:.3rem .5rem}
.lib-btn-more:hover{border-color:var(--gold-d);color:var(--gold-l)}

/* Add Manuscript card */
.lib-card-add{border:2px dashed rgba(200,149,108,.25);background:transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;cursor:pointer;padding:2rem 1.2rem;transition:border-color .2s,background .2s;min-height:180px}
.lib-card-add:hover{border-color:var(--gold);background:rgba(200,149,108,.06)}
.lib-add-icon{width:32px;height:32px;color:var(--gold);margin-bottom:.6rem}
.lib-add-title{font-family:'Lora',serif;font-size:1rem;color:var(--gold-l);font-weight:600;margin-bottom:.3rem}
.lib-add-sub{font-size:.72rem;color:var(--dim);line-height:1.5}

/* Loading */
.lib-loading{text-align:center;padding:3rem 0}
.lib-back-editor{padding:.45rem 1rem;background:linear-gradient(135deg,var(--gold),var(--gold-d));color:#fff;border:none;border-radius:8px;font-size:.82rem;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;flex-shrink:0}
.lib-back-editor:hover{opacity:.9}

/* Context menu for ... button */
.lib-ctx-menu{position:absolute;z-index:200;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 30px rgba(0,0,0,.5);padding:.3rem 0;min-width:140px}
.lib-ctx-item{display:block;width:100%;padding:.45rem .8rem;font-size:.78rem;color:var(--text);background:none;border:none;text-align:left;cursor:pointer;font-family:inherit}
.lib-ctx-item:hover{background:var(--surface2);color:var(--gold-l)}
.lib-ctx-item.danger{color:var(--red)}
.lib-ctx-item.danger:hover{background:rgba(196,92,74,.1)}

/* UPLOAD (inside modal now) */
.upload-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:2.5rem;max-width:480px;width:100%;box-shadow:0 12px 48px rgba(0,0,0,.5)}
.upload-logo{text-align:center;margin-bottom:1.5rem}
.leaf{font-size:1.8rem}.upload-logo h1{font-size:1.7rem;color:var(--gold-l);font-family:'Lora',serif;font-weight:700}
.tagline{color:var(--muted);font-size:.82rem;font-style:italic;margin-top:.2rem}
.drop-zone{border:2px dashed var(--border);border-radius:var(--r);padding:2rem;text-align:center;cursor:pointer;transition:.2s}
.drop-zone:hover,.drop-zone.drag-over{border-color:var(--gold);background:var(--gold-bg)}
.upload-icon{width:36px;height:36px;color:var(--gold);margin-bottom:.6rem}
.drop-text{font-size:1rem;font-weight:600}.drop-sub{color:var(--muted);font-size:.78rem;margin-top:.2rem}
.file-info{display:flex;align-items:center;gap:.5rem;background:var(--surface2);border:1px solid var(--border);border-radius:var(--rs);padding:.5rem .75rem;margin-top:.6rem;font-size:.82rem}
.x-btn{background:none;border:none;color:var(--muted);font-size:1.1rem;cursor:pointer;margin-left:auto}
.btn-gold{display:block;width:100%;margin-top:.6rem;padding:.65rem;background:linear-gradient(135deg,var(--gold),var(--gold-d));color:#fff;border:none;border-radius:var(--rs);font-size:.9rem;font-weight:600;cursor:pointer;font-family:inherit}
.btn-gold:hover{opacity:.9}
.btn-dark{padding:.5rem 1rem;background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:var(--rs);font-size:.8rem;cursor:pointer;font-family:inherit}
.loading{text-align:center;padding:1.5rem}
.spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--gold);border-radius:50%;margin:0 auto .6rem;animation:sp .7s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}

/* TOPBAR */
.topbar{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border-bottom:1px solid var(--border);padding:0 1rem;height:42px;font-size:.82rem}
.topbar-l{display:flex;align-items:center;gap:.6rem}
.leaf-sm{font-size:1rem}.brand{color:var(--gold-l);font-size:.95rem;font-family:'Lora',serif}
.status-pill{font-size:.68rem;color:var(--muted);background:var(--surface2);padding:.12rem .5rem;border-radius:10px}
.topbar-c{color:var(--muted);display:flex;align-items:center;gap:.5rem}.topbar-r{display:flex;align-items:center;gap:.6rem}
.genre-override{background:var(--surface2);border:1px solid var(--border);color:var(--muted);font-size:.65rem;padding:.15rem .3rem;border-radius:4px;font-family:Inter,sans-serif;cursor:pointer;max-width:100px}
.genre-override:focus{outline:none;border-color:var(--gold-d)}
.wc{color:var(--muted);font-size:.78rem}
.tb-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:.2rem .6rem;border-radius:var(--rs);font-size:.72rem;cursor:pointer;font-family:inherit}

/* 3 PANELS */
.editor-view{display:flex;flex-direction:column;height:100vh}
.panels{display:flex;flex:1;overflow:hidden}

/* LEFT */
.left-panel{width:270px;background:var(--bg2);border-right:1px solid var(--border);overflow-y:auto;flex-shrink:0;transition:width .25s}
.left-panel.panel-collapsed{width:40px;min-width:40px;overflow:hidden}
.left-panel.panel-collapsed .lp-title,.left-panel.panel-collapsed .gauge-wrap,.left-panel.panel-collapsed .gauge-cats,.left-panel.panel-collapsed #lp-cards,.left-panel.panel-collapsed .scene-intel{display:none}
.lp-head{display:flex;justify-content:space-between;align-items:center;padding:.65rem .9rem;font-size:.8rem;font-weight:600;border-bottom:1px solid var(--border)}
.lp-collapse,.rp-collapse{background:none;border:none;color:var(--dim);font-size:.55rem;cursor:pointer;padding:.15rem .3rem;border-radius:3px;transition:.2s}
.lp-collapse:hover,.rp-collapse:hover{color:var(--gold-l);background:var(--surface2)}
.lp-dots{color:var(--muted);letter-spacing:2px}

/* GAUGE (semi-circle) */
.gauge-wrap{position:relative;text-align:center;padding:1rem 0 .2rem}
.gauge-wrap canvas{display:block;margin:0 auto}
.gauge-value{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);text-align:center}
.gauge-value span:first-child{font-size:2.8rem;font-weight:800;display:block;line-height:1;color:var(--text)}
.gauge-lbl{font-size:.7rem;color:var(--muted)}
.gauge-cats{text-align:center;font-size:.68rem;color:var(--dim);padding:.2rem 0 .6rem;border-bottom:1px solid var(--border)}

/* LEFT CARDS */
.lp-cards{padding:.4rem .6rem}
.lp-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:.65rem .8rem;margin-bottom:.45rem}
.lp-card-head{display:flex;align-items:center;gap:.6rem;margin-bottom:.15rem}
.lpc-ring{width:40px;height:40px;position:relative;flex-shrink:0}
.lpc-ring canvas{width:40px;height:40px}
.lpc-ring .lpc-num{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.72rem;font-weight:700}
.lpc-info{flex:1}
.lpc-name{font-size:.82rem;font-weight:600}.lpc-sub{font-size:.65rem;color:var(--muted)}
.lpc-score{font-size:.9rem;font-weight:700}
.lpc-bar{height:4px;background:var(--surface3);border-radius:2px;margin-top:.3rem;overflow:hidden}
.lpc-bar-fill{height:100%;border-radius:2px;transition:width .8s}
.lpc-action{display:block;margin-top:.4rem;font-size:.68rem;color:var(--gold);background:var(--surface2);border:1px solid var(--gold-d);border-radius:var(--rs);padding:.22rem 0;text-align:center;cursor:pointer;width:100%}
.lpc-action:hover{background:var(--gold-d);color:#fff}

/* CENTER */
.center-panel{flex:1;display:flex;flex-direction:column;background:var(--bg);overflow:hidden}
.center-toolbar{display:flex;justify-content:space-between;align-items:center;padding:.3rem .6rem;border-bottom:1px solid var(--border);background:var(--surface);font-size:.82rem;color:var(--muted);gap:.3rem;flex-wrap:wrap}
.fmt-group{display:inline-flex;gap:.1rem;align-items:center}
.fmt-sep{width:1px;height:16px;background:var(--border);margin:0 .3rem;flex-shrink:0}
.fmt-select{padding:.15rem .3rem;background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:4px;font-size:.68rem;font-family:inherit;cursor:pointer}
.fmt-select:focus{outline:none;border-color:var(--gold-d)}

/* Chapter navigation sidebar */
.ms-workspace{display:flex;flex:1;overflow:hidden}
.ms-workspace .chapter-nav+.ms-ruler+.manuscript-scroll,.ms-workspace .chapter-nav~.manuscript-scroll{flex:1}
.ms-scroll-col{display:flex;flex-direction:column;flex:1;overflow:hidden}
.chapter-nav{width:160px;background:var(--bg2);border-right:1px solid var(--border);overflow-y:auto;flex-shrink:0;display:flex;flex-direction:column}
.chn-head{padding:.5rem .7rem;font-size:.7rem;font-weight:700;color:var(--muted);letter-spacing:.5px;text-transform:uppercase;border-bottom:1px solid var(--border)}
.chn-list{flex:1;overflow-y:auto;padding:.3rem 0}
.chn-item{display:block;padding:.35rem .7rem;font-size:.75rem;color:var(--muted);cursor:pointer;border-left:2px solid transparent;transition:.15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chn-item:hover{color:var(--text);background:var(--surface2)}
.chn-item.active{color:var(--gold-l);border-left-color:var(--gold);background:rgba(200,149,108,.06);font-weight:600}
.chn-item.chn-h2{padding-left:1.2rem;font-size:.7rem}
.fmt-icons,.fmt-right{display:flex;gap:.3rem}
.fmt-btn{background:none;border:1px solid transparent;color:var(--muted);cursor:pointer;padding:.2rem .45rem;border-radius:4px;font-size:.82rem;font-family:inherit;line-height:1}
.fmt-btn:hover{background:var(--surface2);color:var(--text);border-color:var(--border)}
.fmt-btn:active{background:var(--surface3)}
.manuscript-scroll{flex:1;overflow-y:auto;padding:2rem 0;background:#1a1714}
.ms-page{display:none;max-width:720px;width:100%;margin:0 auto}
.ms-page.active{display:block}
.ms-page.parchment{background:#faf6ee;color:#000;padding:3rem 4rem;font-family:'Lora',serif;font-size:1.05rem;line-height:1.8;word-wrap:break-word;box-shadow:0 2px 24px rgba(0,0,0,.35),0 0 0 1px rgba(0,0,0,.08);border-radius:2px;margin-bottom:2rem;min-height:900px;text-indent:0;text-align:justify;position:relative;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
.ms-page.parchment,.ms-page.parchment p,.ms-page.parchment span,.ms-page.parchment div:not(.scene-break):not(.ms-page-footer){color:#000}
.ms-page.parchment::before{content:'';position:absolute;inset:0;pointer-events:none;z-index:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100' height='100' filter='url(%23n)' opacity='.03'/%3E%3C/svg%3E")}
.ms-page.parchment>*{position:relative;z-index:1}
.ms-page.parchment h1{font-family:'Lora',serif;font-size:1.6rem;font-weight:700;text-align:center;text-indent:0;margin:2rem 0 1.2rem;color:#000;letter-spacing:.5px;page-break-before:always}
.ms-page.parchment h2{font-family:'Lora',serif;font-size:1.2rem;font-weight:600;text-indent:0;margin:1.5rem 0 .8rem;color:#111}
.ms-page.parchment p{text-indent:1.5em;margin:0;padding:0;orphans:2;widows:2}
.ms-page.parchment p:first-child,.ms-page.parchment h1+p,.ms-page.parchment h2+p{text-indent:0}
.ms-page.parchment .scene-break{text-align:center;margin:1.5rem 0;color:#8a7a66;font-size:1.2rem;letter-spacing:.5em;text-indent:0}
.ms-page.dark-page{padding:1.5rem;overflow-y:auto;margin-bottom:2rem}

/* Writing ruler */
.ms-ruler{width:100%;max-width:720px;height:20px;background:#2a2520;border-bottom:1px solid var(--border);display:flex;align-items:flex-end;padding:0 4rem;position:relative;flex-shrink:0;margin:0 auto}
.ms-ruler-ticks{display:flex;width:100%;height:100%;align-items:flex-end;justify-content:space-between}
.ms-ruler-tick{width:1px;background:var(--dim);flex-shrink:0}
.ms-ruler-tick.major{height:10px}
.ms-ruler-tick.minor{height:5px;opacity:.4}
.ms-ruler-num{position:absolute;top:1px;font-size:.5rem;color:var(--dim);transform:translateX(-50%)}
/* Page footer with page number */
.ms-page-footer{text-align:center;font-size:.7rem;color:#8a7a66;padding-top:1.5rem;margin-top:auto;font-family:'Inter',sans-serif;letter-spacing:.5px;text-indent:0}

.center-bottom{display:flex;justify-content:space-between;align-items:center;padding:.7rem 1.25rem;border-top:1px solid var(--border);background:var(--surface);min-height:52px}
.bottom-tabs{display:flex;gap:.3rem}
.btab{background:none;border:none;color:var(--muted);font-size:.9rem;padding:.5rem .9rem;cursor:pointer;font-family:inherit;transition:.15s}
.btab:hover{color:var(--text)}.btab.active{color:var(--gold-l);font-weight:600}
.bottom-icons{display:flex;gap:.3rem;color:var(--muted);font-size:1rem}
.bi-btn{background:none;border:1px solid transparent;color:var(--muted);font-size:.75rem;cursor:pointer;padding:.25rem .45rem;border-radius:4px;font-family:inherit;line-height:1;transition:.15s}
.bi-btn:hover{background:var(--surface2);border-color:var(--border);color:var(--text)}

/* HIGHLIGHTS */
.hl{padding:1px 2px;border-radius:2px;cursor:pointer;transition:.15s}
.hl:hover{opacity:.8}
.hl[data-t="passive"]{background:rgba(196,92,74,.18);border-bottom:2px solid var(--red)}
.hl[data-t="adverb"]{background:rgba(212,168,85,.15);border-bottom:2px solid var(--yellow)}
.hl[data-t="cliche"]{background:rgba(196,92,74,.18);border-bottom:2px solid var(--red)}
.hl[data-t="weak-verb"]{background:rgba(200,149,108,.15);border-bottom:2px solid var(--gold)}
.hl[data-t="show-tell"]{background:rgba(196,92,74,.12);border-bottom:2px solid var(--red)}
.hl[data-t="repetition"]{background:rgba(107,172,212,.15);border-bottom:2px solid var(--blue)}
.hl[data-t="wordy"]{background:rgba(93,186,125,.15);border-bottom:2px solid var(--green)}
.hl[data-t="sentence-length"]{background:rgba(212,168,85,.12);border-bottom:2px solid var(--yellow)}
.hl.off{background:none!important;border-bottom:none!important}
.fix-applied{transition:outline .3s}

/* TOOLTIP */
.tip{display:none;position:fixed;background:var(--surface);border:1px solid var(--border2);border-radius:var(--r);padding:.8rem 1rem;max-width:340px;z-index:1000;box-shadow:0 10px 30px rgba(0,0,0,.5)}
.tip.on{display:block}
.tip-cat{font-weight:700;font-size:.85rem;margin-bottom:.3rem}
.tip-sug{color:var(--muted);font-size:.82rem;margin-bottom:.1rem}
.tip-quote{font-style:italic;color:var(--gold-l);font-size:.88rem;margin:.3rem 0 .6rem}
.tip-btns{display:flex;gap:.4rem}
.tip-fix{padding:.35rem .8rem;background:var(--gold);color:#fff;border:none;border-radius:var(--rs);font-size:.78rem;cursor:pointer;font-weight:600;font-family:inherit}
.tip-ign{padding:.35rem .8rem;background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:var(--rs);font-size:.78rem;cursor:pointer;font-family:inherit}

/* RIGHT */
.right-panel{width:310px;background:var(--bg2);border-left:1px solid var(--border);overflow-y:auto;flex-shrink:0;transition:width .25s}
.right-panel.panel-collapsed{width:40px;min-width:40px;overflow:hidden}
.right-panel.panel-collapsed .rp-title,.right-panel.panel-collapsed .rp-tabs,.right-panel.panel-collapsed #rp-scores,.right-panel.panel-collapsed #rp-detail{display:none}
.rp-head{display:flex;justify-content:space-between;align-items:center;padding:.6rem .9rem;border-bottom:1px solid var(--border)}
.rp-title{font-size:.85rem;font-weight:600}
.rp-select{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:.18rem .4rem;border-radius:var(--rs);font-size:.7rem}
.rp-tabs{display:flex;gap:.1rem;padding:.35rem .6rem;border-bottom:1px solid var(--border)}
.rtab{background:none;border:none;color:var(--muted);font-size:.72rem;padding:.25rem .5rem;cursor:pointer;font-family:inherit;border-bottom:2px solid transparent;transition:.15s}
.rtab:hover{color:var(--text)}.rtab.active{color:var(--gold-l);border-bottom-color:var(--gold)}

/* RIGHT SCORE CARDS */
.rp-scores{padding:.4rem .6rem}
.rsc{display:flex;align-items:center;gap:.55rem;padding:.5rem .65rem;border-radius:var(--rs);margin-bottom:.3rem;cursor:pointer;border:1px solid transparent;transition:.15s}
.rsc:hover{background:var(--surface);border-color:var(--border)}
.rsc.active{background:var(--surface);border-color:var(--gold-d)}
.rsc-ring{width:34px;height:34px;position:relative;flex-shrink:0}
.rsc-ring canvas{width:34px;height:34px}
.rsc-ring .rsc-n{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.62rem;font-weight:700}
.rsc-info{flex:1;min-width:0}.rsc-name{font-size:.8rem;font-weight:600}.rsc-sub{font-size:.62rem;color:var(--muted)}
.rsc-val{font-size:.78rem;font-weight:700;background:var(--surface2);padding:.15rem .5rem;border-radius:var(--rs);flex-shrink:0}
.rsc-badge{font-size:.68rem;font-weight:600;padding:.18rem .5rem;border-radius:var(--rs);flex-shrink:0}

/* RIGHT DETAIL */
.rp-detail{padding:.6rem .9rem;border-top:1px solid var(--border)}
.rpd-title{font-size:1.1rem;font-weight:700;color:var(--gold-l);margin-bottom:.6rem;display:flex;align-items:center;justify-content:space-between}
.rpd-title span{font-size:.7rem;cursor:pointer;color:var(--muted)}
.rpd-issue{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:.7rem .85rem;margin-bottom:.5rem}
.rpd-issue-head{display:flex;align-items:center;gap:.4rem;font-size:.82rem;font-weight:600;margin-bottom:.3rem}
.rpd-issue-head::before{content:"";display:inline-block;width:6px;height:14px;background:var(--red);border-radius:2px}
.rpd-desc{font-size:.78rem;color:var(--muted);margin-bottom:.4rem;line-height:1.5}
.rpd-quote{background:var(--surface2);padding:.35rem .6rem;border-radius:var(--rs);font-size:.82rem;font-style:italic;color:var(--gold-l);margin-bottom:.5rem}
.rpd-btns{display:flex;gap:.35rem}

/* ANALYSIS SECTIONS */
.a-sec{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:.9rem 1rem;margin-bottom:.6rem}
.a-sec h3{font-size:.85rem;margin-bottom:.5rem;color:var(--gold-l);display:flex;justify-content:space-between}
.a-sec h3 span{font-weight:700}
.a-sec p{font-size:.8rem;color:var(--muted);line-height:1.5}
.sr{display:flex;justify-content:space-between;gap:.8rem;padding:.28rem 0;border-bottom:1px solid var(--border);font-size:.78rem}.sr:last-child{border:none}
.sr-l{color:var(--muted);flex-shrink:0;min-width:65px}.sr-v{font-weight:600;text-align:right;word-break:break-word}

/* READER */
.rdr-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-bottom:.8rem}
.rdr-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:.8rem}
.rdr-card h4{font-size:.8rem;color:var(--gold-l);margin-bottom:.3rem}
.rdr-big{font-size:2rem;font-weight:800}
.rdr-bar{height:5px;background:var(--surface3);border-radius:3px;overflow:hidden;margin:.3rem 0}
.rdr-fill{height:100%;border-radius:3px}
.rdr-lbl{font-size:.68rem;color:var(--muted)}
.emo-row{display:flex;align-items:center;gap:.4rem;margin-bottom:.25rem;font-size:.72rem}
.emo-name{width:60px;text-align:right;color:var(--muted)}.emo-track{flex:1;height:4px;background:var(--surface3);border-radius:2px}
.emo-fill{height:100%;border-radius:2px}

/* HEATMAP, CHARS */
.hm-wrap{display:flex;flex-wrap:wrap;gap:2px;margin:.4rem 0}
.hm-blk{width:22px;height:22px;border-radius:3px;cursor:pointer}.hm-blk:hover{transform:scale(1.3)}
.hm-leg{display:flex;gap:.6rem;font-size:.65rem;color:var(--muted);margin-top:.3rem}.hm-leg span{display:flex;align-items:center;gap:.2rem}
.hm-dot{width:7px;height:7px;border-radius:2px;display:inline-block}
.ch-grid{display:grid;grid-template-columns:1fr 1fr;gap:.4rem}
.ch-card{background:var(--surface2);border-radius:var(--rs);padding:.5rem .65rem}
.ch-name{font-weight:700;font-size:.82rem}.ch-cnt{font-size:.68rem;color:var(--muted)}
.ch-bar{height:3px;background:var(--surface3);border-radius:2px;margin-top:.3rem}.ch-fill{height:100%;background:var(--gold);border-radius:2px}

/* AI */
.ai-intro{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:1rem}
.ai-intro ul{list-style:none;padding:0}.ai-intro li{padding:.2rem 0;font-size:.8rem;color:var(--muted)}.ai-intro li::before{content:"\2713";color:var(--gold);margin-right:.4rem}
.ai-list{list-style:none;padding:0}.ai-list li{padding:.25rem 0;font-size:.78rem;color:var(--muted);border-bottom:1px solid var(--border)}.ai-list li::before{content:">";color:var(--gold);font-weight:700;margin-right:.35rem}
.comp-grid{display:grid;grid-template-columns:1fr 1fr;gap:.4rem;margin:.4rem 0}
.comp-card{background:var(--surface2);border-radius:var(--rs);padding:.5rem}.comp-title{font-weight:700;font-size:.8rem}.comp-author{font-size:.7rem;color:var(--muted)}.comp-reason{font-size:.68rem;color:var(--muted);font-style:italic;margin-top:.15rem}
.ql-text{background:var(--surface2);border-radius:var(--rs);padding:.65rem;font-size:.82rem;line-height:1.6;white-space:pre-wrap}
.beta-grid{display:grid;grid-template-columns:1fr 1fr;gap:.4rem;margin:.4rem 0}
.beta-card{background:var(--surface2);border-radius:var(--rs);padding:.6rem}
.beta-hdr{display:flex;justify-content:space-between;margin-bottom:.2rem}.beta-nm{font-weight:700;font-size:.8rem}.beta-rt{color:var(--yellow);font-size:.8rem}
.beta-pro{font-size:.68rem;color:var(--muted);margin-bottom:.3rem}.beta-rx{font-size:.78rem;font-style:italic}
.ch-grid2{display:flex;flex-direction:column;gap:.35rem;margin:.4rem 0}.ch-card2{background:var(--surface2);border-radius:var(--rs);padding:.5rem .65rem;display:flex;gap:.6rem}
.ch-num{font-weight:800;font-size:.78rem;color:var(--gold);min-width:30px}.ch-ttl{font-weight:600;font-size:.8rem}.ch-sum{font-size:.75rem;color:var(--muted);margin-top:.1rem}
.ch-bdg{padding:.08rem .35rem;border-radius:5px;font-size:.62rem;background:var(--surface3)}

/* VERSION */
.v-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem}.v-head h3{font-size:.9rem}
.v-tl{position:relative;padding-left:1.2rem}.v-tl::before{content:'';position:absolute;left:4px;top:0;bottom:0;width:2px;background:var(--border)}
.v-item{position:relative;margin-bottom:.6rem}.v-dot{position:absolute;left:-1.2rem;top:3px;width:10px;height:10px;border-radius:50%;border:2px solid var(--bg)}
.v-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--rs);padding:.5rem .65rem}
.v-top{display:flex;justify-content:space-between}.v-grade{font-weight:700;font-size:.85rem}.v-date{font-size:.65rem;color:var(--muted)}
.v-name{font-size:.78rem;margin-top:.1rem}.v-stats{font-size:.68rem;color:var(--muted);margin-top:.05rem}
.v-sum{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:.6rem;margin-top:.6rem}
.v-sum h4{font-size:.82rem;margin-bottom:.3rem;color:var(--gold-l)}

/* MODAL */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:2000}
.modal-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:1.5rem;max-width:400px;width:90%}
.modal-box h3{color:var(--gold-l);margin-bottom:.6rem}.modal-box p{font-size:.82rem;color:var(--muted);margin-bottom:.8rem;line-height:1.4}
.modal-input{width:100%;padding:.5rem .65rem;background:var(--surface2);border:1px solid var(--border);border-radius:var(--rs);color:var(--text);font-size:.82rem;font-family:monospace}
.modal-btns{display:flex;gap:.4rem;margin-top:.8rem;justify-content:flex-end}

/* BLURBS */
.blurb-card{border-left:3px solid var(--gold-d)}
.blurb-text{background:var(--surface2);border-radius:var(--rs);padding:.75rem 1rem;font-size:.88rem;line-height:1.7;font-family:'Lora',serif;color:var(--text);white-space:pre-wrap;min-height:60px}
.blurb-text[contenteditable="true"]{background:var(--surface3)}

/* GENRE SELECT */
.genre-select-wrap{margin-top:.5rem}
.genre-dropdown{width:100%;padding:.45rem .6rem;background:var(--surface2);border:1px solid var(--border);border-radius:var(--rs);color:var(--text);font-size:.8rem;font-family:inherit;margin-top:.25rem}
.genre-dropdown optgroup{color:var(--gold-l);font-weight:600}

/* BOOK PREVIEW */
/* Panel resize handles */
.panel-resize{position:absolute;top:0;width:5px;height:100%;cursor:col-resize;z-index:50;background:transparent;transition:background .2s}
.panel-resize:hover,.panel-resize.dragging{background:var(--gold-d)}
.panel-resize.resize-left{left:0}
.panel-resize.resize-right{right:0}
.pv-head{display:flex;justify-content:space-between;align-items:center;padding:.5rem .7rem;border-bottom:1px solid var(--border);font-size:.8rem;font-weight:600}
.pv-toggle{background:none;border:none;color:var(--muted);font-size:1rem;cursor:pointer}
.pv-content{padding:.5rem}
.pv-emotions{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:.6rem}
.pv-emo-tag{display:flex;align-items:center;gap:.2rem;padding:.2rem .45rem;border-radius:12px;font-size:.65rem;font-weight:600;cursor:pointer;border:1px solid var(--border)}
.pv-emo-tag:hover{opacity:.8}
/* Device buttons */
.pv-devices{display:flex;gap:.3rem}
.pv-dev{background:var(--surface2);border:1px solid var(--border);color:var(--muted);font-size:.65rem;cursor:pointer;padding:.2rem .45rem;border-radius:4px;transition:.15s;font-family:'Inter',sans-serif}
.pv-dev:hover{color:var(--text);border-color:var(--gold-d)}.pv-dev.active{color:var(--gold-l);border-color:var(--gold);background:var(--gold-bg)}
/* Emotions subtle */
.pv-emotions{display:flex;flex-wrap:wrap;gap:.2rem;padding:.25rem .5rem;border-bottom:1px solid var(--border)}
.pv-emo-tag{padding:.1rem .3rem;border-radius:8px;font-size:.55rem;font-weight:500;opacity:.6}
.pv-emo-tag:hover{opacity:1}
/* Device frame */
.pv-device-frame{display:flex;justify-content:center;flex:1;overflow:hidden;padding:.4rem;position:relative}

/* Shared screen */
.pv-screen{width:100%;display:flex;flex-direction:column;overflow:hidden}

/* Kindle */
.pv-device-frame.kindle .pv-screen{max-width:600px;height:calc(100vh - 180px);background:#f5f0e6;color:#1a1a1a;border:8px solid #444;border-radius:4px;box-shadow:inset 0 0 12px rgba(0,0,0,.04),0 4px 20px rgba(0,0,0,.3);font-family:'Lora','Georgia',serif;font-size:16px;line-height:1.55;text-align:justify}
.pv-device-frame.kindle::after{content:'kindle';position:absolute;bottom:6px;left:50%;transform:translateX(-50%);font-size:.5rem;color:#555;letter-spacing:3px;text-transform:uppercase;font-family:'Inter',sans-serif}
.pv-device-frame.kindle .pv-navbar{background:#f5f0e6;border-top:1px solid #d8d0c0}
.pv-device-frame.kindle .pv-nbtn{color:#666}
.pv-device-frame.kindle .pv-nbtn:hover{color:#333}
.pv-device-frame.kindle .pv-nav-prev,.pv-device-frame.kindle .pv-nav-next{color:#666;border-color:#d0c8b8}
.pv-device-frame.kindle .pv-page-info{color:#888}
.pv-device-frame.kindle .pv-display-panel{background:#e8dcc4;border-color:#d0c8b8;color:#333}

/* iPad */
.pv-device-frame.ipad .pv-screen{max-width:680px;height:calc(100vh - 180px);background:#fff;color:#222;border:2px solid #c0c0c0;border-radius:20px;box-shadow:0 8px 30px rgba(0,0,0,.2);font-family:-apple-system,'Helvetica Neue',sans-serif;font-size:16px;line-height:1.5}
.pv-device-frame.ipad .pv-navbar{background:#fff;border-top:1px solid #e0e0e0}
.pv-device-frame.ipad .pv-nbtn{color:#007AFF}
.pv-device-frame.ipad .pv-nbtn:hover{opacity:.7}
.pv-device-frame.ipad .pv-nav-prev,.pv-device-frame.ipad .pv-nav-next{color:#007AFF;border-color:#e0e0e0}
.pv-device-frame.ipad .pv-page-info{color:#666}
.pv-device-frame.ipad .pv-display-panel{background:#f5f5f5;border-color:#e0e0e0;color:#333}

/* Paperback 6x9 — realistic book */
.pv-device-frame.paperback{position:relative;perspective:1200px}
.pv-device-frame.paperback .pv-screen{max-width:540px;height:calc(100vh - 180px);background:#faf6ee;color:#1a1a1a;font-family:'Lora','Georgia',serif;font-size:12pt;line-height:1.5;text-align:justify;border:none;border-radius:0 3px 3px 0;box-shadow:6px 6px 20px rgba(0,0,0,.35),1px 0 3px rgba(0,0,0,.12),inset -2px 0 4px rgba(0,0,0,.04);position:relative}
/* Spine edge */
.pv-device-frame.paperback .pv-screen::before{content:'';position:absolute;left:0;top:0;bottom:0;width:14px;background:linear-gradient(90deg,#c8b898 0%,#d8ccb0 30%,#e8dcc4 60%,#f0e6d0 100%);border-right:1px solid #c0b498;border-radius:2px 0 0 2px;box-shadow:inset -2px 0 4px rgba(0,0,0,.08)}
/* Page edges (right side) */
.pv-device-frame.paperback .pv-screen::after{content:'';position:absolute;right:-4px;top:3px;bottom:3px;width:4px;background:repeating-linear-gradient(180deg,#e8dcc0 0px,#f0e6cc 1px,#d8ccb0 2px);border-radius:0 1px 1px 0;box-shadow:1px 0 2px rgba(0,0,0,.1)}
.pv-device-frame.paperback .pv-page{padding:2rem 2rem 2rem 2.5rem}
.pv-device-frame.paperback .pv-navbar{background:#f5efe0;border-top:1px solid #d8d0c0}
.pv-device-frame.paperback .pv-nbtn{color:#8a7a66}
.pv-device-frame.paperback .pv-nav-prev,.pv-device-frame.paperback .pv-nav-next{color:#8a7a66;border-color:#d0c8b8}
.pv-device-frame.paperback .pv-page-info{color:#8a7a66;font-family:'Lora',serif;font-style:italic;font-size:.6rem}
.pv-device-frame.paperback .pv-display-panel{background:#f0e8d8;border-color:#d0c8b8;color:#333}

/* Dark theme overrides */
.pv-screen.dark-theme{background:#1a1a1a!important;color:#ccc!important}
.pv-screen.dark-theme .pv-navbar{background:#1a1a1a!important;border-color:#333!important}
.pv-screen.dark-theme .pv-nbtn{color:#888!important}
.pv-screen.dark-theme .pv-nav-prev,.pv-screen.dark-theme .pv-nav-next{color:#888!important;border-color:#333!important}
.pv-screen.dark-theme .pv-page-info{color:#666!important}
.pv-screen.dark-theme .pv-display-panel{background:#222!important;border-color:#444!important;color:#ccc!important}

/* Page content area */
.pv-page{flex:1;overflow:hidden;padding:2rem 1.8rem;position:relative}
.pv-para{text-indent:1.5em;margin:0;padding:0}
.pv-para:first-child{text-indent:0}
.pv-para.chapter-heading{text-indent:0;text-align:center;font-weight:700;font-size:1.15em;margin:1.2em 0 .6em;page-break-before:always}

/* Search panel */
.pv-search-panel{padding:.4rem .6rem;border-bottom:1px solid rgba(128,128,128,.2);background:inherit}
.pv-search-row{display:flex;align-items:center;gap:.3rem}
.pv-search-input{flex:1;padding:.3rem .5rem;border:1px solid rgba(128,128,128,.3);border-radius:4px;font-size:.75rem;font-family:inherit;background:rgba(255,255,255,.1);color:inherit}
.pv-search-count{font-size:.6rem;color:inherit;opacity:.6;white-space:nowrap}
.pv-search-nav{background:none;border:1px solid rgba(128,128,128,.3);color:inherit;border-radius:3px;padding:.15rem .35rem;font-size:.65rem;cursor:pointer}
.pv-search-nav:hover{background:rgba(128,128,128,.1)}
.pv-search-close{background:none;border:none;color:inherit;font-size:1rem;cursor:pointer;opacity:.6;padding:0 .2rem}
.pv-search-close:hover{opacity:1}
mark.pv-highlight{background:#ffd700;color:#000;padding:0 1px;border-radius:2px}
mark.pv-highlight.active{background:#ff6b35;color:#fff}

/* Focus & Recovery */
.focus-banner{position:fixed;top:0;left:50%;transform:translateX(-50%);z-index:500;min-width:320px;max-width:520px;animation:focusSlideDown .4s ease}
@keyframes focusSlideDown{from{transform:translateX(-50%) translateY(-100%)}to{transform:translateX(-50%) translateY(0)}}
.focus-inner{background:linear-gradient(135deg,#1e2a1e,#1a2018);border:1px solid rgba(93,186,125,.3);border-top:none;border-radius:0 0 12px 12px;padding:.7rem 1rem;display:flex;align-items:center;gap:.6rem;box-shadow:0 4px 20px rgba(0,0,0,.4)}
.focus-icon{font-size:1.3rem;flex-shrink:0}
.focus-msg{font-size:.78rem;color:#c5e8d0;flex:1;line-height:1.4;font-family:'Inter',sans-serif}
.focus-actions{display:flex;gap:.3rem;flex-shrink:0}
.focus-btn{background:rgba(93,186,125,.15);border:1px solid rgba(93,186,125,.3);color:#5dba7d;padding:.25rem .65rem;border-radius:5px;font-size:.68rem;cursor:pointer;font-family:inherit;transition:.2s}
.focus-btn:hover{background:rgba(93,186,125,.25)}
.focus-snooze{background:rgba(212,168,85,.1);border-color:rgba(212,168,85,.3);color:#d4a855}
.focus-timer{height:2px;background:rgba(93,186,125,.2);border-radius:0 0 12px 12px;overflow:hidden}
.focus-timer::after{content:'';display:block;height:100%;background:#5dba7d;animation:focusCountdown 20s linear forwards}
@keyframes focusCountdown{from{width:100%}to{width:0%}}
.pv-emo-inline{font-size:.55rem;opacity:.35;margin-right:.1rem}

/* Bottom navbar */
.pv-navbar{flex-shrink:0;padding:.3rem .5rem .2rem;font-family:'Inter',sans-serif}
.pv-nav-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.25rem}
.pv-nav-prev,.pv-nav-next{background:none;border:1px solid;border-radius:4px;padding:.15rem .5rem;font-size:.75rem;cursor:pointer;font-family:inherit;transition:.15s}
.pv-nav-prev:hover,.pv-nav-next:hover{opacity:.7}
.pv-nav-prev:disabled,.pv-nav-next:disabled{opacity:.3;cursor:default}
.pv-page-info{font-size:.65rem;font-weight:500}
.pv-nav-btns{display:flex;justify-content:center;gap:.3rem;padding-top:.2rem;border-top:1px solid rgba(128,128,128,.15)}
.pv-nbtn{background:none;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.1rem;padding:.2rem .45rem;font-size:.55rem;font-family:'Inter',sans-serif;transition:.15s;border-radius:4px}
.pv-nbtn:hover{background:rgba(128,128,128,.08)}
.pv-ni{font-size:.9rem;line-height:1}
.pv-display-panel{padding:.4rem .6rem;border-top:1px solid;margin-top:.2rem;display:flex;align-items:center;gap:.5rem;font-size:.7rem}
.pv-display-panel label{flex-shrink:0}
.pv-display-panel input[type=range]{flex:1;height:3px;accent-color:#c8956c}
/* Preview panel */
.preview-panel{width:22%;min-width:210px;background:var(--bg2);border-left:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;transition:width .3s}
.preview-panel.collapsed{width:40px;min-width:40px}
.preview-panel.collapsed .pv-content,.preview-panel.collapsed .pv-title,.preview-panel.collapsed .pv-devices{display:none}
.pv-content{flex:1;display:flex;flex-direction:column;overflow:hidden}

/* LIVE SCORE */
.live-score{font-size:.82rem;color:var(--muted);margin-right:.5rem}
.live-score b{color:var(--gold-l);font-size:1rem}
.delta{font-size:.75rem;font-weight:700;margin-left:.2rem}
.delta.up{color:var(--green)}.delta.down{color:var(--red)}.delta.same{color:var(--muted)}

/* GOAL BAR */
.goal-bar{display:flex;gap:.4rem;padding:.4rem 1rem;background:var(--surface);border-bottom:1px solid var(--border);overflow-x:auto}
.goal-pill{display:flex;align-items:center;gap:.35rem;padding:.35rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--surface2);color:var(--text);transition:.2s;white-space:nowrap;font-family:inherit}
.goal-pill:hover{border-color:var(--gold-d);background:var(--gold-bg)}
.goal-pill.active{border-color:var(--gold);background:var(--gold-bg);color:var(--gold-l)}
.goal-pill .gp-icon{font-size:.85rem}

/* SCENE INTELLIGENCE */
.scene-intel{padding:.5rem .6rem;border-top:1px solid var(--border)}
.si-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--rs);padding:.5rem .65rem;margin-bottom:.4rem}
.si-section h4{font-size:.78rem;font-weight:600;margin-bottom:.35rem;color:var(--gold-l)}
.si-row{display:flex;justify-content:space-between;font-size:.72rem;padding:.15rem 0}
.si-row .si-label{color:var(--muted)}.si-row .si-val{font-weight:600}
.si-check{display:flex;align-items:center;gap:.35rem;font-size:.72rem;padding:.12rem 0;color:var(--text)}
.si-check.done{color:var(--green)}.si-check.todo{color:var(--muted)}
.si-check::before{content:"\2610";font-size:.85rem;color:var(--muted)}
.si-check.done::before{content:"\2611";color:var(--green)}
.focus-toggle{display:flex;align-items:center;justify-content:space-between;padding:.4rem .5rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--rs);font-size:.75rem;cursor:pointer;margin-bottom:.3rem}
.focus-badge{background:var(--green);color:#fff;padding:.1rem .4rem;border-radius:8px;font-size:.6rem;font-weight:700}
.focus-badge.off{background:var(--surface3);color:var(--muted)}
.sim-btn{display:flex;align-items:center;gap:.3rem;padding:.35rem .6rem;background:var(--surface2);border:1px solid var(--border);border-radius:var(--rs);font-size:.72rem;color:var(--muted);cursor:pointer;width:100%;font-family:inherit}
.sim-btn:hover{border-color:var(--gold-d);color:var(--text)}

/* AUTOSAVE INDICATOR */
.autosave{font-size:.6rem;color:var(--dim);padding:.1rem .4rem}
.autosave.saving{color:var(--gold)}

/* COOKIE BANNER */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:300;background:var(--surface);border-top:1px solid var(--border);padding:.75rem 1.5rem;box-shadow:0 -4px 20px rgba(0,0,0,.3)}
.cookie-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;max-width:900px;margin:0 auto}
.cookie-inner p{font-size:.75rem;color:var(--muted);flex:1;line-height:1.4}

/* SMARTALYSIS ENGINE */
.smartalysis-intro{padding:2rem!important;background:linear-gradient(145deg,#1e1812,#2a2018);border:1px solid rgba(200,149,108,.2);border-radius:14px;margin:1.5rem;position:relative;overflow:hidden}
.smartalysis-intro::after{content:'';position:absolute;top:0;right:0;width:40%;height:100%;background:radial-gradient(ellipse at 80% 50%,rgba(200,149,108,.08),transparent 70%);pointer-events:none}
.smt-header{display:flex;align-items:center;gap:.8rem;margin-bottom:.5rem}
.smt-badge{font-size:.55rem;font-weight:700;letter-spacing:1.5px;color:var(--gold);border:1px solid var(--gold-d);padding:.15rem .5rem;border-radius:4px}
.smt-title{font-family:'Lora',serif;font-size:1.5rem;color:var(--gold-l);font-weight:700;margin:0}
.smt-tagline{color:var(--muted);font-size:.9rem;margin-bottom:1.5rem;font-style:italic}
.smt-features{display:flex;flex-direction:column;gap:.1rem;margin-bottom:1.5rem;position:relative;z-index:1}
.smt-feature{display:flex;align-items:flex-start;gap:.7rem;padding:.65rem .5rem;border-bottom:1px solid rgba(200,149,108,.08)}
.smt-feature:last-child{border-bottom:none}
.smt-icon{font-size:1.1rem;flex-shrink:0;width:24px;text-align:center;margin-top:.1rem}
.smt-feature strong{display:block;font-size:.88rem;color:var(--gold-l);margin-bottom:.15rem;font-family:'Lora',serif}
.smt-feature span{font-size:.78rem;color:var(--muted);line-height:1.4}
.smt-run-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 2rem;background:linear-gradient(135deg,#c8956c,#8a6548);color:#fff;border:none;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;font-family:inherit;position:relative;z-index:1;box-shadow:0 4px 16px rgba(200,149,108,.3)}
.smt-run-btn:hover{box-shadow:0 6px 24px rgba(200,149,108,.5);transform:translateY(-1px)}

/* WRITING & BLOCK TAB */
.wb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}
.wb-tool{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.2rem}
.wb-tool-icon{font-size:1.5rem;margin-bottom:.5rem}
.wb-tool h4{font-family:'Lora',serif;color:var(--gold-l);font-size:.9rem;margin-bottom:.3rem}
.wb-tool p{font-size:.78rem;color:var(--muted);line-height:1.5}
.wb-result{margin-top:.6rem;padding:.7rem;background:var(--surface2);border:1px solid var(--border);border-radius:var(--rs);font-size:.8rem;color:var(--text);line-height:1.6;white-space:pre-wrap}

@media(max-width:900px){.left-panel{width:220px}.right-panel{width:250px}.preview-panel{width:18%;min-width:180px}.lib-cards-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}}
@media(max-width:700px){.panels{flex-direction:column}.left-panel,.right-panel,.preview-panel{width:100%!important;max-height:200px;border:none;border-bottom:1px solid var(--border);min-width:0!important}.chapter-nav{display:none}.ms-ruler{display:none}.lib-nav{padding:.5rem 1rem}.lib-content{padding:1.5rem 1rem}.lib-search{width:140px}.lib-cards-grid{grid-template-columns:1fr 1fr}.center-toolbar{flex-wrap:wrap}.bottom-tabs{flex-wrap:wrap;gap:.15rem}.btab{font-size:.75rem;padding:.35rem .5rem}.fmt-right{display:none}}
@media(max-width:480px){.lib-cards-grid{grid-template-columns:1fr}.topbar{flex-wrap:wrap;height:auto;padding:.4rem .6rem}.topbar-c{display:none}.topbar-r{flex-wrap:wrap;gap:.3rem}.lib-title{font-size:1.4rem}.lib-nav-r{gap:.5rem}.bottom-tabs{overflow-x:auto;flex-wrap:nowrap}.btab{white-space:nowrap;flex-shrink:0}}
