:root{--bg:#ffffff;--bg1:#fafafa;--bg2:#f1f1f3;--bg3:#e7e7eb;--border:#dcdce2;--text:#1c1c24;--dim:#5a5a70;--faint:#9a9aae;--gold:#8a6d20;--gold-dim:#b89a4a;--p-color:#6b3fa0;--g-color:#a05a1c;--c-color:#1c5a9e;--s-color:#2d7a2d;--p-bg:#f1eaf8;--g-bg:#f8efe6;--c-bg:#e8f0fa;--s-bg:#eaf5ea;--pass:#1a8a6f;--warn:#a87a14;--fail:#c4332a;--up:#8a6d20;--heat-0:#f5f7fa;--heat-1:#d6f0df;--heat-2:#7fcf9f;--heat-3:#3aa860;--heat-4:#1c7a3a;}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'Menlo','Consolas','Courier New',monospace;background:var(--bg);color:var(--text);font-size:12px;}
.vg{font-family:'VE',serif;}
#app{display:grid;grid-template-columns:220px 1fr;grid-template-rows:48px 1fr;height:100vh;}
@media(max-width:768px){#app{grid-template-columns:1fr;grid-template-rows:auto auto 1fr;}#sidebar{max-height:40vh;}#topbar{padding:8px 12px;gap:8px 12px;min-height:48px;height:auto;white-space:normal;overflow:visible;align-items:flex-start;}#topbar h1{font-size:13px;}.topbar-transcriber{width:100%;min-width:0;}.topbar-transcriber label{min-width:88px;}.topbar-stats{width:100%;gap:6px 12px;}#tcrSel{width:100%;min-width:0;}}
#topbar{grid-column:1/-1;background:var(--bg1);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:16px;overflow-x:auto;white-space:nowrap;}
#topbar h1{font-family:Georgia,serif;font-size:15px;color:var(--gold);font-weight:normal;letter-spacing:2px;}
#topbar .stat{color:var(--dim);font-size:11px;} #topbar .stat b{color:var(--text);}
.topbar-transcriber{display:flex;align-items:center;gap:8px;flex:0 0 auto;min-width:260px;}
.topbar-transcriber label{color:var(--dim);font-size:10px;text-transform:uppercase;letter-spacing:1px;white-space:nowrap;}
.topbar-stats{display:flex;align-items:center;gap:16px;flex:1 1 auto;flex-wrap:wrap;min-width:0;}
#tcrSel{width:220px;min-width:220px;max-width:100%;flex:0 0 auto;}
#sidebar{background:var(--bg1);border-right:1px solid var(--border);overflow-y:auto;padding:12px 0;}
#main{overflow-y:auto;padding:0;}
.nav-section{padding:8px 16px;color:var(--gold-dim);font-size:10px;text-transform:uppercase;letter-spacing:1.5px;margin-top:14px;cursor:pointer;user-select:none;display:flex;align-items:center;gap:4px;transition:color .15s;border-bottom:1px solid var(--border);margin-bottom:2px;font-weight:bold;}
.nav-section:hover{color:var(--text);}
.nav-toggle{font-size:8px;transition:transform .2s;display:inline-block;width:10px;}
.nav-section.collapsed .nav-toggle{transform:rotate(-90deg);}
.nav-group{overflow:hidden;max-height:500px;transition:max-height .25s ease;}
.nav-group.collapsed{max-height:0;}
.nav-item{padding:7px 16px;cursor:pointer;color:var(--dim);transition:all .15s;font-size:11px;display:flex;align-items:center;gap:8px;}
.nav-item:hover{background:var(--bg2);color:var(--text);}
.nav-item.active{color:var(--gold);background:rgba(201,168,76,.06);border-right:2px solid var(--gold);}
.nav-item .badge{margin-left:auto;background:var(--bg3);padding:1px 6px;border-radius:8px;font-size:9px;color:var(--faint);}
.lock-icon{margin-left:auto;font-size:9px;opacity:.5;}
.panel{display:none;padding:24px 28px;} .panel.active{display:block;}
h2{font-family:Georgia,serif;font-size:16px;color:var(--gold);font-weight:normal;letter-spacing:1px;margin-bottom:12px;}
h3{color:var(--dim);font-size:12px;font-weight:normal;margin:16px 0 8px;text-transform:uppercase;letter-spacing:1px;}
.desc{color:var(--dim);font-size:11px;margin-bottom:16px;max-width:700px;line-height:1.5;}
.controls{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:16px;}
select,input[type=text],input[type=number],button{background:var(--bg2);border:1px solid var(--border);color:var(--text);padding:6px 12px;border-radius:4px;font-size:11px;font-family:inherit;}
select:focus,input:focus{border-color:var(--gold-dim);outline:none;}
button{cursor:pointer;} button:hover{border-color:var(--gold);color:var(--gold);}
input[type=text]{width:200px;} input[type=number]{width:60px;}
label{color:var(--dim);font-size:10px;text-transform:uppercase;letter-spacing:1px;}
.tgrid{display:flex;flex-wrap:wrap;gap:8px;}
.tcard{background:var(--bg1);border:1px solid var(--border);border-radius:5px;padding:10px 14px;min-width:110px;text-align:center;transition:border-color .15s;}
.tcard:hover{border-color:var(--gold-dim);} .tcard .gl{font-size:28px;padding:4px 0;} .tcard .ev{color:var(--dim);font-size:10px;} .tcard .ct{color:var(--faint);font-size:9px;}
.fline{margin:6px 0;padding:10px 14px;background:var(--bg1);border-left:2px solid var(--border);border-radius:0 4px 4px 0;}
.fline:hover{border-left-color:var(--gold-dim);} .fline .ln{color:var(--faint);font-size:9px;margin-bottom:4px;} .fline .toks{display:flex;flex-wrap:wrap;gap:10px;}
.fline .tok{text-align:center;} .fline .tok .g{font-size:24px;} .fline .tok .e{font-size:9px;color:var(--faint);}
.ag-line{margin:6px 0;padding:10px 14px;background:var(--bg1);border-left:2px solid var(--border);border-radius:0 4px 4px 0;}
.ag-line .ln{color:var(--faint);font-size:9px;margin-bottom:4px;}
.ag-tok{display:inline-block;margin:2px 4px;padding:2px 5px;border-radius:3px;font-size:11px;}
.ag-match{background:rgba(68,170,153,.12);color:var(--pass);}
.ag-partial{background:rgba(221,170,68,.12);color:var(--warn);}
.ag-diff{background:rgba(221,85,85,.12);color:var(--fail);}
.ag-missing{background:rgba(102,102,116,.12);color:var(--faint);font-style:italic;}
.xc-cell{text-align:right;padding:4px 8px;font-size:11px;font-family:inherit;}
.xc-hdr{font-size:10px;color:var(--dim);text-transform:uppercase;letter-spacing:.5px;}
.srow{display:flex;align-items:center;gap:4px;padding:6px 10px;margin:3px 0;background:var(--bg1);border-radius:3px;flex-wrap:wrap;}
.srow .full{font-size:22px;min-width:100px;} .srow .arrow{color:var(--faint);margin:0 6px;}
.slot{padding:3px 7px;border-radius:3px;font-size:11px;display:inline-flex;align-items:center;gap:5px;}
.slot .lb{font-size:8px;color:var(--dim);text-transform:uppercase;} .slot .gi{font-family:'VE',serif;font-size:18px;}
.sl-p{background:var(--p-bg);color:var(--p-color);} .sl-g{background:var(--g-bg);color:var(--g-color);}
.sl-c{background:var(--c-bg);color:var(--c-color);} .sl-s{background:var(--s-bg);color:var(--s-color);} .sl-e{background:var(--bg2);color:var(--faint);}
.sfam{color:var(--faint);font-size:9px;margin-left:8px;}
.grammar-wrap{max-height:calc(100vh - 220px);overflow-y:auto;border:1px solid var(--border);border-radius:4px;}
.grammar-tbl{width:100%;border-collapse:collapse;}
.grammar-tbl thead{position:sticky;top:0;z-index:10;}
.grammar-tbl thead th{background:var(--bg2);padding:8px 12px;font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--dim);font-weight:bold;text-align:center;border-bottom:1px solid var(--border);}
.grammar-tbl .gt-tok{text-align:center;min-width:110px;padding:6px 10px;}
.grammar-tbl .gt-slot{text-align:center;padding:6px 8px;}
.grammar-tbl .gt-fam{color:var(--faint);font-size:9px;text-align:center;padding:6px 8px;}
.gt-row td{border-bottom:1px solid rgba(0,0,0,.06);}
.gt-row:hover td{background:rgba(201,168,76,.03);}
.gt-line-hdr td{padding:12px 10px 6px;color:var(--dim);font-size:12px;text-transform:uppercase;letter-spacing:1px;}
.sr{padding:8px 12px;margin:3px 0;background:var(--bg1);border-radius:3px;display:flex;align-items:center;gap:12px;font-size:11px;}
.sr .gl{font-size:24px;min-width:90px;} .sr .loc{color:var(--dim);min-width:80px;} .sr .meta{color:var(--faint);}
.bar-row{display:flex;align-items:center;gap:8px;margin:3px 0;}
.bar-row.no-glyph .bar-label{min-width:80px;}
.bar-label{min-width:60px;text-align:right;color:var(--dim);font-size:11px;flex-shrink:0;}
.bar-track{flex:1;height:18px;background:var(--bg2);border-radius:2px;overflow:hidden;max-width:400px;position:relative;}
.bar-fill{height:100%;border-radius:2px;transition:width .3s;} .bar-val{font-size:10px;color:var(--faint);flex-shrink:0;}
.bar-gl{font-family:'VE',serif;font-size:14px;min-width:60px;flex-shrink:0;}
.agrid{display:grid;grid-template-columns:repeat(auto-fill,90px);gap:6px;}
.acell{background:var(--bg1);border:1px solid var(--border);border-radius:4px;padding:10px;text-align:center;}
.acell .ag{font-size:40px;} .acell .ae{color:var(--dim);font-size:11px;} .acell .au{color:var(--faint);font-size:8px;}
table.dt{width:100%;border-collapse:collapse;}
table.dt th{text-align:left;padding:6px 10px;color:var(--dim);font-size:10px;text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid var(--border);font-weight:normal;}
table.dt td{padding:6px 10px;border-bottom:1px solid rgba(0,0,0,.06);font-size:11px;}
table.dt tr:hover td{background:rgba(201,168,76,.03);}
.pagination{display:flex;gap:6px;align-items:center;margin:12px 0;} .page-info{color:var(--dim);font-size:10px;}
.stat-card{background:var(--bg1);border:1px solid var(--border);border-radius:6px;padding:16px;margin:8px 0;}
.stat-card h4{color:var(--gold);font-size:12px;font-weight:normal;margin-bottom:8px;text-transform:uppercase;letter-spacing:1px;}
.stat-row{display:flex;align-items:center;gap:12px;padding:4px 0;border-bottom:1px solid rgba(0,0,0,.04);font-size:11px;}
.stat-row .name{min-width:200px;color:var(--dim);} .stat-row .val{min-width:90px;text-align:right;color:var(--text);}
.dropzone{border:2px dashed var(--border);border-radius:8px;padding:40px 20px;text-align:center;color:var(--dim);cursor:pointer;transition:all .2s;margin-bottom:16px;}
.dropzone:hover,.dropzone.dragover{border-color:var(--gold);background:rgba(201,168,76,.04);color:var(--text);}
.dropzone.loaded{border-color:var(--pass);border-style:solid;background:rgba(68,170,153,.04);}
.dropzone .icon{font-size:32px;margin-bottom:8px;} .dropzone .hint{font-size:10px;color:var(--faint);margin-top:6px;}
.tok-opts{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;margin:16px 0;padding:16px;background:var(--bg1);border-radius:6px;border:1px solid var(--border);}
.tok-opts label{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:11px;color:var(--text);text-transform:none;letter-spacing:0;}
.tok-opts input[type=checkbox]{accent-color:var(--gold);}
.preview-box{background:var(--bg1);border:1px solid var(--border);border-radius:6px;padding:12px 16px;margin:12px 0;max-height:200px;overflow-y:auto;font-size:11px;line-height:1.8;word-wrap:break-word;}
.preview-box .tok{display:inline-block;padding:1px 5px;margin:2px;background:var(--bg2);border-radius:3px;}
.upload-info{color:var(--dim);font-size:11px;padding:4px 0;}

.rtl{direction:rtl;text-align:right;font-family:'Amiri','Noto Sans Arabic','Noto Sans Hebrew','serif',monospace;}
.preview-box.rtl .tok{direction:rtl;unicode-bidi:embed;}
.rtl-hint{display:inline-block;padding:2px 8px;border-radius:10px;font-size:9px;background:var(--bg3);color:var(--dim);margin-left:8px;}
::-webkit-scrollbar{width:6px;} ::-webkit-scrollbar-track{background:var(--bg);} ::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px;}
.csv-btn{background:var(--bg2);border:1px solid var(--border);color:var(--dim);padding:4px 10px;border-radius:4px;font-size:10px;font-family:inherit;cursor:pointer;transition:all .15s;margin-left:auto;}
.csv-btn:hover{border-color:var(--gold);color:var(--gold);background:rgba(201,168,76,.06);}
.panel-header{display:flex;align-items:center;gap:12px;margin-bottom:12px;}
.panel-header h2{margin-bottom:0;}

/* KWIC */
.kwic-results{font-size:11px;max-height:60vh;overflow-y:auto;}
.kwic-row{display:flex;align-items:baseline;gap:0;padding:4px 0;border-bottom:1px solid rgba(0,0,0,.06);font-family:inherit;}
.kwic-loc{min-width:80px;color:var(--faint);font-size:10px;flex-shrink:0;}
.kwic-left{min-width:200px;text-align:right;color:var(--dim);padding-right:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.kwic-key{color:var(--gold);font-weight:bold;padding:1px 4px;background:rgba(201,168,76,.1);border-radius:3px;font-size:16px;}
.kwic-right{padding-left:6px;color:var(--dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}

/* Co-occurrence matrix */
.cooc-wrap{overflow:auto;max-width:100%;}
.cooc-tbl{border-collapse:collapse;font-size:9px;}
.cooc-tbl th,.cooc-tbl td{padding:3px 5px;text-align:center;border:1px solid var(--border);min-width:28px;}
.cooc-tbl th{background:var(--bg2);color:var(--dim);font-size:14px;}
.cooc-tbl td{font-size:9px;cursor:default;transition:opacity .15s;}
.cooc-tbl td:hover{opacity:.7;}

/* N-gram heatmap */
.ngh-tbl{border-collapse:collapse;font-size:9px;}
.ngh-tbl th,.ngh-tbl td{padding:2px 3px;text-align:center;border:1px solid var(--border);}
.ngh-label{background:var(--bg2);color:var(--dim);font-size:11px;text-align:left!important;padding:3px 8px!important;white-space:nowrap;position:sticky;left:0;z-index:1;}
.ngh-fhdr{background:var(--bg2);color:var(--faint);font-size:8px;writing-mode:vertical-rl;text-orientation:mixed;padding:4px 1px!important;min-width:16px;max-width:20px;}
.ngh-cell{min-width:16px;max-width:20px;font-size:8px;cursor:default;transition:opacity .15s;}
.ngh-cell:hover{opacity:.7;}

/* Accretion Models */
.acc-tabs{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--border);padding-bottom:8px;}
.acc-tab{background:var(--bg2);border:1px solid var(--border);color:var(--dim);padding:6px 14px;border-radius:4px 4px 0 0;font-size:11px;font-family:inherit;cursor:pointer;transition:all .15s;}
.acc-tab:hover{color:var(--text);border-color:var(--gold-dim);}
.acc-tab.active{color:var(--gold);border-color:var(--gold);background:rgba(201,168,76,.08);}
.acc-stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;margin:12px 0;}
.acc-info-box{margin:16px 0;padding:12px 16px;border:1px solid var(--border);border-left:3px solid var(--gold-dim);border-radius:4px;background:var(--bg1);color:var(--dim);font-size:11px;line-height:1.6;}
.acc-heatmap-tbl td{transition:opacity .15s;}.acc-heatmap-tbl td:hover{opacity:.8;}

/* Scribal Production Model */
.scribal-workshop{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
@media(max-width:900px){.scribal-workshop{grid-template-columns:1fr;}}
.scribal-crib{background:#18150e;border:1px solid #3a3020;border-radius:6px;padding:20px;background-image:repeating-linear-gradient(0deg,transparent,transparent 28px,#2a2518 28px,#2a2518 29px);}
.scribal-crib-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:8px;}
.scribal-crib-list{max-height:500px;overflow-y:auto;}
.crib-entry{display:flex;align-items:center;padding:5px 8px;border-radius:3px;margin-bottom:2px;border-left:3px solid transparent;transition:background .3s,border-left-color .3s;}
.crib-entry.flash{background:rgba(201,168,76,.2);border-left-color:var(--gold);}
.crib-word-glyph{font-size:22px;min-width:40px;flex-shrink:0;}
.crib-word{font-size:11px;font-weight:600;min-width:70px;flex-shrink:0;color:var(--faint);}
.scribal-token{display:inline-flex;flex-direction:column;align-items:center;cursor:help;}
.scribal-token-eva{font-size:9px;opacity:.6;}
.slot-badge{display:inline-block;padding:2px 7px;border-radius:3px;font-size:11px;font-weight:600;margin-right:3px;border:1px solid;}
.slot-badge-empty{background:var(--bg2);color:var(--faint);border-color:var(--border);}
.slot-badge-p{background:var(--p-bg);color:var(--p-color);border-color:rgba(176,136,204,.4);}
.slot-badge-g{background:rgba(255,107,107,.08);color:#ff6b6b;border-color:rgba(255,107,107,.3);}
.slot-badge-c{background:var(--c-bg);color:var(--c-color);border-color:rgba(91,155,213,.3);}
.slot-badge-s{background:var(--s-bg);color:var(--s-color);border-color:rgba(77,182,172,.3);}
.slot-badge-label{font-size:9px;color:var(--faint);margin-right:3px;}
.freq-dots{display:inline-flex;gap:2px;margin-left:8px;}
.freq-dot{width:5px;height:5px;border-radius:50%;}
.dot-high{background:#e6a817;}.dot-med{background:#8a7040;}.dot-low{background:#4a4030;}
.scribal-dot-legend{margin-top:12px;font-size:11px;color:var(--dim);display:flex;gap:12px;flex-wrap:wrap;}
.scribal-controls{background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:16px 20px;margin-bottom:16px;}
.scribal-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px;}
.scribal-stat{background:var(--bg2);border:1px solid var(--border);border-radius:4px;padding:8px 12px;text-align:center;}
.scribal-stat-val{font-size:20px;color:var(--text);}.scribal-stat-lbl{font-size:10px;color:var(--faint);}
.manuscript-output{background:#18150e;border:1px solid #3a3020;border-radius:6px;padding:20px;min-height:280px;background-image:repeating-linear-gradient(0deg,transparent,transparent 23px,#2a2518 23px,#2a2518 24px);}
.scribal-output-wrap{display:flex;flex-wrap:wrap;gap:4px 10px;line-height:1.8;}
.scribal-token{font-size:14px;cursor:help;}
.scribal-legend{margin-top:8px;display:flex;gap:16px;font-size:11px;}
.grammar-card{background:#18150e;border:2px solid #3a3020;border-radius:8px;padding:24px 28px;max-width:700px;box-shadow:0 4px 20px rgba(0,0,0,.4);}
.grammar-slot-hdr{font-size:13px;font-weight:600;margin-bottom:8px;border-bottom:1px solid var(--border);padding-bottom:4px;}
.mutation-card{background:var(--bg1);border:1px solid var(--border);border-radius:6px;padding:16px 20px;border-left:3px solid var(--warn);}
.mutation-prob{font-size:10px;padding:2px 8px;background:rgba(255,152,0,.13);color:var(--warn);border-radius:3px;}

/* Manuscript View */
.ms-view-toggle{display:flex;gap:2px;margin-left:auto;background:var(--bg2);border:1px solid var(--border);border-radius:4px;padding:2px;}
.ms-view-btn{background:transparent;border:none;color:var(--dim);padding:5px 12px;border-radius:3px;font-size:10px;font-family:inherit;cursor:pointer;transition:all .15s;}
.ms-view-btn:hover{color:var(--text);}
.ms-view-btn.active{background:rgba(201,168,76,.15);color:var(--gold);}
.ms-display-toggle{display:flex;gap:2px;background:var(--bg2);border:1px solid var(--border);border-radius:4px;padding:2px;}
.ms-disp-btn{background:transparent;border:none;color:var(--dim);padding:4px 10px;border-radius:3px;font-size:10px;font-family:inherit;cursor:pointer;transition:all .15s;}
.ms-disp-btn:hover{color:var(--text);}
.ms-disp-btn.active{background:rgba(201,168,76,.15);color:var(--gold);}
.ms-split{display:flex;gap:0;height:calc(100vh - 180px);border:1px solid var(--border);border-radius:6px;overflow:hidden;}
.ms-image-panel{flex:1;overflow:auto;background:var(--bg1);display:flex;flex-direction:column;align-items:center;justify-content:flex-start;position:relative;border-right:1px solid var(--border);}
.ms-zoom-wrapper{width:100%;height:100%;overflow:hidden;position:relative;cursor:grab;}
.ms-zoom-wrapper:active{cursor:grabbing;}
.ms-zoom-wrapper img{display:block;transform-origin:0 0;user-select:none;-webkit-user-drag:none;}
.ms-zoom-controls{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:4px;background:rgba(8,8,12,.85);border:1px solid var(--border);border-radius:6px;padding:4px 6px;backdrop-filter:blur(8px);z-index:5;}
.ms-zoom-btn{background:transparent;border:1px solid transparent;color:var(--dim);width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:4px;font-size:16px;font-family:inherit;cursor:pointer;transition:all .15s;}
.ms-zoom-btn:hover{color:var(--gold);border-color:var(--border);background:var(--bg2);}
.ms-zoom-level{color:var(--dim);font-size:10px;min-width:36px;text-align:center;user-select:none;}
.ms-trans-panel{flex:1;overflow-y:auto;padding:16px;background:var(--bg);}
.ms-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;width:100%;}
.ms-spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:ms-spin .8s linear infinite;}
@keyframes ms-spin{to{transform:rotate(360deg);}}
.ms-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--dim);text-align:center;padding:20px;}
@media(max-width:768px){.ms-split{flex-direction:column;height:auto;}.ms-image-panel{max-height:50vh;border-right:none;border-bottom:1px solid var(--border);}}

/* Word Trace strip */
.wd-strip-wrap{margin:16px 0;overflow-x:auto;}
.wd-strip{display:flex;align-items:flex-end;height:60px;gap:1px;min-width:max-content;}
.wd-bar{width:8px;min-width:4px;height:100%;display:flex;align-items:flex-end;justify-content:center;cursor:pointer;transition:background .15s;position:relative;border-radius:2px 2px 0 0;}
.wd-bar:hover{outline:1px solid var(--gold);z-index:1;}
.wd-bar-count{font-size:7px;color:var(--text);writing-mode:vertical-rl;text-orientation:mixed;line-height:8px;}
.wd-labels{display:flex;gap:1px;min-width:max-content;}
.wd-label{width:8px;min-width:4px;font-size:7px;color:var(--faint);text-align:center;transform:rotate(-45deg);transform-origin:top left;height:40px;overflow:visible;white-space:nowrap;margin-top:4px;}
.wd-sections{margin:20px 0;}
.wd-sections h3{font-size:11px;color:var(--dim);margin-bottom:8px;font-weight:normal;text-transform:uppercase;letter-spacing:1px;}
.wd-detail{margin:20px 0;}
.wd-detail h3{font-size:11px;color:var(--dim);margin-bottom:8px;font-weight:normal;text-transform:uppercase;letter-spacing:1px;}

/* ── Stroke-Level AI Analysis ── */
.ag-stroke-tbl { width:100%; border-collapse:collapse; font-size:12px; margin-top:6px; }
.ag-stroke-tbl th, .ag-stroke-tbl td { padding:6px 8px; border-bottom:1px solid var(--border); text-align:left; vertical-align:top; }
.ag-stroke-tbl th { background:var(--bg2); font-weight:600; font-size:11px; }
.ag-stroke-tbl tr:hover { background:rgba(0,0,0,.02); }
.ag-stroke-reading { display:inline-block; margin-right:10px; padding:2px 4px; border:1px solid var(--border); border-radius:3px; background:var(--bg2); }
.ag-stroke-detail td { background:rgba(0,0,0,.02); padding:0; }
.ag-glyph-detail { display:flex; gap:16px; padding:14px; align-items:flex-start; }
.ag-glyph-img-wrap { flex:0 0 320px; }
.ag-glyph-img { width:100%; max-width:320px; border:1px solid var(--border); background:#f8f8f4; border-radius:3px; }
.ag-glyph-result { flex:1; min-width:0; font-size:13px; line-height:1.5; }
.ag-gemini-md h2, .ag-gemini-md h3, .ag-gemini-md h4 { margin:10px 0 4px 0; font-size:13px; color:var(--text); }
.ag-gemini-md p { margin:6px 0; }
.ag-gemini-md ul { margin:4px 0 6px 18px; }
.ag-gemini-md code { background:var(--bg2); padding:1px 4px; border-radius:2px; font-size:12px; }

.gem-folio-wrap{margin-top:12px;}
.gem-folio-controls{display:flex;align-items:center;flex-wrap:wrap;gap:8px;padding:10px 12px;background:var(--bg1);border:1px solid var(--border);border-radius:4px;margin-bottom:12px;}
.gem-folio-split{display:grid;grid-template-columns:minmax(280px,1fr) 2fr;gap:16px;}
@media(max-width:900px){.gem-folio-split{grid-template-columns:1fr;}}
.gem-folio-img{background:var(--bg1);border:1px solid var(--border);border-radius:4px;padding:8px;min-height:300px;display:flex;align-items:center;justify-content:center;}
.gem-folio-out{background:var(--bg1);border:1px solid var(--border);border-radius:4px;padding:16px;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;font-size:13px;line-height:1.55;color:var(--text);min-height:300px;overflow-y:auto;max-height:80vh;}
.gem-folio-out h1,.gem-folio-out h2,.gem-folio-out h3{font-family:Georgia,serif;color:var(--gold);margin:14px 0 6px;}
.gem-folio-out h3{font-size:13px;text-transform:none;letter-spacing:0;}
.gem-folio-out p{margin:6px 0;}
.gem-folio-out ul,.gem-folio-out ol{margin:6px 0 6px 20px;}
.gem-folio-out code{background:var(--bg2);padding:1px 4px;border-radius:3px;font-size:12px;}

/* Gemini reference comparison */
.gem-cmp-wrap{margin-top:18px;padding-top:14px;border-top:1px solid var(--border);}
.gem-cmp-head{font-family:Georgia,serif;color:var(--gold);font-size:14px;margin-bottom:8px;}
.gem-cmp-sub{color:var(--dim);font-size:11px;font-family:inherit;font-weight:normal;margin-left:8px;}
.gem-cmp-legend{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:10px;font-size:11px;color:var(--dim);}
.gem-cmp-stat{margin-left:auto;color:var(--fg);}
.gem-cmp-line{display:flex;flex-wrap:wrap;align-items:center;gap:4px;padding:4px 0;border-bottom:1px dashed var(--border);}
.gem-cmp-line.gem-cmp-label{color:var(--dim);font-style:italic;font-size:11px;}
.gem-cmp-ln{color:var(--dim);font-size:10px;min-width:32px;font-family:monospace;}
.gem-tok{display:inline-block;padding:2px 6px;border-radius:3px;font-family:monospace;font-size:12px;border:1px solid transparent;position:relative;cursor:default;}
.gem-tok-ok{background:rgba(46,160,67,0.18);border-color:rgba(46,160,67,0.45);color:var(--fg);}
.gem-tok-warn{background:rgba(210,153,34,0.22);border-color:rgba(210,153,34,0.55);color:var(--fg);}
.gem-tok-bad{background:rgba(218,54,51,0.22);border-color:rgba(218,54,51,0.6);color:var(--fg);}
.gem-tok-na{background:var(--bg2);color:var(--dim);border-color:var(--border);}
.gem-tok[data-tip]:hover::after{
  content:attr(data-tip);position:absolute;bottom:calc(100% + 4px);left:0;
  background:var(--bg2);color:var(--fg);border:1px solid var(--border);
  padding:6px 8px;border-radius:4px;font-size:11px;white-space:nowrap;z-index:50;
  box-shadow:0 4px 12px rgba(0,0,0,0.4);
}
