@font-face{font-family:Archivo Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/archivo-vietnamese-wght-normal-XAtsl5Q_.woff2) format("woff2-variations");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Archivo Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/archivo-latin-ext-wght-normal-C4zznr8T.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Archivo Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/archivo-latin-wght-normal-E0tuGl4L.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--bg: #fafaf8;--paper: #ffffff;--ink: #111111;--muted: #6e6e6e;--hair: #dad8d2;--plate: #ece9e3;--accent: #9a4a3a;--font: "Archivo Variable", Archivo, system-ui, -apple-system, sans-serif;color-scheme:light}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--font);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}#root{min-height:100vh}button{font:inherit;color:inherit;background:none;border:none;padding:0;cursor:pointer}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app{max-width:1440px;min-height:100vh;margin:0 auto;padding:40px clamp(20px,5vw,80px) 32px;display:flex;flex-direction:column}.frame-header{display:flex;align-items:center;justify-content:space-between;gap:24px;padding-bottom:18px;flex-wrap:wrap}.wordmark{display:flex;align-items:center;gap:11px}.wordmark-mark{width:12px;height:12px;background:var(--accent);display:block}.wordmark-name{font-size:18px;font-weight:800;letter-spacing:-.2px;color:var(--ink)}.frame-meta{display:flex;align-items:center;gap:clamp(16px,3vw,36px);flex-wrap:wrap}.frame-meta span{font-size:12px;font-weight:600;letter-spacing:1.5px;color:var(--muted)}.top-rule{height:2px;background:var(--ink);width:100%}.stage{flex:1;display:flex;flex-direction:column}.stage-upload{padding-top:48px;justify-content:space-between;gap:56px}.stage-result{padding-top:36px;gap:32px}.hero{display:flex;gap:clamp(32px,5vw,64px);align-items:flex-start}.hero-headline-col{flex:1;display:flex;flex-direction:column;gap:30px;min-width:0}.eyebrow{margin:0;font-size:13px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted)}.hero-headline{margin:0;font-size:clamp(44px,8vw,94px);font-weight:800;letter-spacing:-.035em;line-height:.92;color:var(--ink);white-space:pre-line}.index-col{width:380px;flex-shrink:0;display:flex;flex-direction:column}.index-head{display:flex;align-items:center;justify-content:space-between;padding-bottom:12px}.index-head-label{font-size:12px;font-weight:700;letter-spacing:2px;color:var(--ink)}.index-head-count{font-size:12px;font-weight:600;color:var(--muted)}.index-rule{height:1px;background:var(--ink)}.index-divider{height:1px;background:var(--hair)}.index-row{display:flex;align-items:center;gap:18px;padding:16px 0}.index-num{font-size:22px;font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums}.index-text{display:flex;flex-direction:column;gap:3px}.index-name{font-size:16px;font-weight:700;color:var(--ink)}.index-prev{font-size:12px;font-weight:500;color:var(--muted)}.dropzone{display:flex;align-items:center;justify-content:space-between;gap:24px;background:var(--paper);border:1px solid var(--ink);padding:36px clamp(20px,3vw,44px);cursor:pointer;transition:border-color .12s,background .12s}.dropzone:hover{border-color:var(--accent)}.dropzone:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.dropzone[data-dragging=true]{border-color:var(--accent);background:#faf3f0}.dropzone-left{display:flex;align-items:center;gap:28px;min-width:0}.dz-icon{width:40px;height:40px;color:var(--ink);flex-shrink:0}.dropzone-text{display:flex;flex-direction:column;gap:7px;min-width:0}.dropzone-title{font-size:clamp(22px,3vw,32px);font-weight:700;letter-spacing:-.5px;color:var(--ink)}.dropzone-sub{font-size:14px;font-weight:500;color:var(--muted)}.dropzone-btn{flex-shrink:0;background:var(--ink);color:var(--bg);padding:15px 30px;font-size:13px;font-weight:700;letter-spacing:1.5px}.dropzone:hover .dropzone-btn{background:var(--accent)}.title-row{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap}.result-title{margin:0;font-size:clamp(34px,5vw,60px);font-weight:800;letter-spacing:-2px;line-height:.94;color:var(--ink);white-space:pre-line}.title-right{display:flex;flex-direction:column;gap:14px;align-items:flex-end}.result-filename{font-size:13px;font-weight:600;letter-spacing:1px;color:var(--muted);text-transform:uppercase;text-align:right}.title-actions{display:flex;align-items:stretch;gap:10px}.ghost-btn{display:inline-flex;align-items:center;border:1px solid var(--ink);color:var(--ink);padding:13px 20px;font-size:13px;font-weight:700;letter-spacing:1.5px;cursor:pointer;transition:background .12s,color .12s}.ghost-btn:hover{background:var(--ink);color:var(--bg)}.export-btn{display:inline-flex;align-items:center;gap:9px;background:var(--ink);color:var(--bg);padding:13px 24px;font-size:13px;font-weight:700;letter-spacing:1.5px;transition:background .12s}.export-btn:hover:not(:disabled){background:var(--accent)}.export-btn:disabled{opacity:.55;cursor:default}.export-icon{width:15px;height:15px}.poster{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}.poster-col{display:flex;flex-direction:column;gap:12px;min-width:0}.poster-rule{height:1px;background:var(--ink)}.poster-rule[data-original]{height:3px;background:var(--accent)}.poster-head{display:flex;flex-direction:column;gap:5px}.poster-numrow{display:flex;align-items:center;justify-content:space-between}.poster-num{font-size:24px;font-weight:800;color:var(--ink);font-variant-numeric:tabular-nums}.poster-tag{font-size:9.5px;font-weight:700;letter-spacing:1.2px;color:var(--muted)}.poster-tag[data-original]{color:var(--accent)}.poster-name{font-size:17px;font-weight:700;letter-spacing:-.2px;color:var(--ink)}.poster-plate{position:relative;width:100%;aspect-ratio:4 / 5;background:var(--plate);overflow:hidden;display:block;cursor:pointer;padding:0}.poster-plate:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.poster-expand{position:absolute;right:8px;bottom:8px;background:var(--ink);color:var(--bg);font-size:10px;font-weight:700;letter-spacing:1px;padding:5px 8px;opacity:0;transition:opacity .12s;pointer-events:none}.poster-plate:hover .poster-expand,.poster-plate:focus-visible .poster-expand{opacity:1}.poster-canvas{width:100%;height:100%;object-fit:cover;display:block}.poster-caption{font-size:12px;font-weight:500;color:var(--muted)}.analysis{margin-top:24px;display:flex;flex-direction:column}.analysis-toprule{height:2px;background:var(--ink);width:100%}.ledger-header{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;flex-wrap:wrap;padding:26px 0}.ledger-score-block{display:flex;flex-direction:column;gap:8px}.ledger-eyebrow{font-size:11px;font-weight:600;letter-spacing:1.8px;color:var(--muted)}.ledger-score{display:flex;align-items:flex-end;gap:12px}.ledger-score-number{font-size:clamp(54px,9vw,78px);font-weight:800;letter-spacing:-1px;line-height:.85;color:var(--ink);font-variant-numeric:tabular-nums}.ledger-score-denominator{font-size:18px;font-weight:600;color:var(--muted)}.ledger-rating{align-self:center;background:var(--accent);color:#fff;padding:5px 9px;font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase}.ledger-score-sub{font-size:13px;font-weight:500;color:var(--muted)}.ledger-palette{display:flex;flex-direction:column;gap:8px;align-items:flex-end}.ledger-palette-label{font-size:11px;font-weight:600;letter-spacing:1.8px;color:var(--muted)}.ledger-palette-swatches{display:flex}.ledger-swatch{width:42px;height:42px;border:1px solid var(--hair)}.ledger-swatch+.ledger-swatch{border-left:none}.ledger-palette-src{font-size:10px;font-weight:600;letter-spacing:1.2px;color:var(--muted)}.ledger-summary{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-bottom:18px}.ledger-summary-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.ledger-pill{padding:5px 9px;font-size:11px;font-weight:600;letter-spacing:1.5px}.ledger-pill--critical{background:var(--accent);color:#fff}.ledger-pill--warning{background:var(--plate);color:var(--ink)}.ledger-summary-note,.ledger-summary-right{font-size:11px;font-weight:600;letter-spacing:1.5px;color:var(--muted)}.ledger-rule2{height:2px;background:var(--ink)}.ledger-table{width:100%}.ledger-head,.ledger-row{display:grid;grid-template-columns:minmax(140px,1.6fr) minmax(150px,1.6fr) minmax(70px,.9fr) minmax(90px,1fr) minmax(110px,1.1fr) minmax(96px,1fr);gap:16px;align-items:center}.ledger-head{padding:12px 0;border-bottom:1px solid var(--hair)}.ledger-head .lc{font-size:10px;font-weight:600;letter-spacing:1.4px;color:var(--muted)}.ledger-row{padding:15px 0;border-bottom:1px solid var(--hair)}.ledger-row:last-child{border-bottom:none}.lc-result{justify-self:end}.lc-type{font-size:15px;font-weight:700;color:var(--ink)}.lc-common{font-size:12px;font-weight:500;color:var(--muted)}.lc-colours{display:flex;gap:5px}.swatch-sm{width:22px;height:22px;border:1px solid var(--hair)}.lc-dash{color:var(--muted);font-size:13px}.lc-before{font-size:13px;font-weight:500;color:#2a2a2a}.after-wrap{display:flex;flex-direction:column;gap:2px}.lc-after .av{font-size:13px;font-weight:600;color:#2a2a2a}.lc-after[data-warn] .av{color:var(--accent)}.lc-after .ad{font-size:11px;font-weight:500;color:var(--muted)}.ledger-tag{padding:5px 10px;font-size:11px;font-weight:600;letter-spacing:1.5px}.ledger-tag--ok{background:var(--plate);color:var(--ink)}.ledger-tag--check{background:var(--accent);color:#fff}.ledger-actions{display:flex;flex-direction:column;gap:11px;padding-top:26px}.ledger-actions-label{font-size:11px;font-weight:600;letter-spacing:1.8px;color:var(--ink)}.ledger-action{display:flex;gap:12px}.ledger-action-dash{font-size:14px;font-weight:700;color:var(--accent);flex-shrink:0}.ledger-action-text{font-size:13px;font-weight:500;line-height:1.4;color:#2a2a2a}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#111111d1;display:flex;align-items:center;justify-content:center;padding:clamp(16px,4vw,48px)}.lightbox-panel{background:var(--bg);width:100%;max-width:1100px;max-height:92vh;display:flex;flex-direction:column;border:1px solid var(--ink)}.lightbox-head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 22px;border-bottom:2px solid var(--ink);flex-wrap:wrap}.lightbox-titles{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}.lightbox-num{font-size:20px;font-weight:800}.lightbox-name{font-size:18px;font-weight:700;letter-spacing:-.2px}.lightbox-tag{font-size:10px;font-weight:700;letter-spacing:1.2px;color:var(--muted)}.lightbox-tag[data-original]{color:var(--accent)}.lightbox-caption{font-size:12px;font-weight:500;color:var(--muted)}.lightbox-close{background:var(--ink);color:var(--bg);font-size:11px;font-weight:700;letter-spacing:1.2px;padding:9px 14px;flex-shrink:0;transition:background .12s}.lightbox-close:hover{background:var(--accent)}.lightbox-stage{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--plate)}.lightbox-canvas{max-width:100%;max-height:78vh;object-fit:contain;display:block}@media(max-width:720px){.ledger-head{display:none}.ledger-row{display:block;padding:18px 0}.lc-common{margin-bottom:12px}.lc-colours,.lc-before,.lc-after,.lc-result{display:flex;justify-content:space-between;align-items:center;padding:5px 0}.lc-colours:before,.lc-before:before,.lc-after:before,.lc-result:before{content:attr(data-label);font-size:10px;font-weight:600;letter-spacing:1.4px;color:var(--muted);text-transform:uppercase}.lc-after .after-wrap{align-items:flex-end}.lc-result{justify-self:auto}}.frame-footer{margin-top:28px;display:flex;flex-direction:column;gap:14px}.frame-footer-rule{height:1px;background:var(--hair)}.frame-footer-row{display:flex;align-items:center;justify-content:space-between}.frame-footer-row span{font-size:12px;font-weight:600;letter-spacing:1px;color:var(--muted)}@media(max-width:1040px){.poster{grid-template-columns:repeat(3,1fr)}}@media(max-width:900px){.hero{flex-direction:column}.index-col{width:100%}}@media(max-width:620px){.poster{grid-template-columns:repeat(2,1fr)}.dropzone{flex-direction:column;align-items:flex-start;gap:20px}.dropzone-btn{align-self:stretch;text-align:center}.title-row{flex-direction:column;align-items:flex-start}.title-right{align-items:flex-start}.result-filename{text-align:left}}@media(max-width:420px){.poster{grid-template-columns:1fr}}
