:root{
  --bg:#0A0A0A;
  --panel:#101010;
  --panel-2:#141414;
  --line:#1F1F1F;
  --line-2:#2A2A2A;
  --text:#F2F0EB;
  --muted:#8A8A88;
  --muted-2:#5A5A58;
  --accent:#FF2D1E;
  --accent-ink:#FFFFFF;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:'Helvetica Neue','Helvetica','Arial',sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
body{min-height:100vh}
button{font-family:inherit;color:inherit;cursor:pointer;border:none;background:none}
input,textarea{font-family:inherit;color:inherit}
a{color:inherit;text-decoration:none}
.mono{font-family:'JetBrains Mono','IBM Plex Mono',ui-monospace,Menlo,monospace}
.display{font-family:'Helvetica Neue','Arial Black',sans-serif;font-weight:900;font-stretch:condensed;letter-spacing:-0.02em;line-height:0.88}

/* utility */
.u-up{text-transform:uppercase}
.u-tracked{letter-spacing:0.14em}
.u-tight{letter-spacing:-0.01em}
.u-dot::after{content:"";display:inline-block;width:0.22em;height:0.22em;border-radius:50%;background:var(--accent);margin-left:0.08em;vertical-align:baseline;transform:translateY(-0.02em)}

/* chip/pill */
.chip{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid var(--line-2);border-radius:999px;font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);background:rgba(0,0,0,0.35);backdrop-filter:blur(6px)}
.chip .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px rgba(255,45,30,0.18)}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 22px;border-radius:999px;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;font-family:'JetBrains Mono',monospace;transition:transform .12s ease, background .18s ease, color .18s ease}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{filter:brightness(1.08)}
.btn-ghost{border:1px solid var(--line-2);color:var(--text);background:transparent}
.btn-ghost:hover{border-color:#4a4a48}

/* grain — inline base64 PNG (bundler-safe, no url(#id) fragments) */
.grain{position:absolute;inset:0;pointer-events:none;opacity:.07;mix-blend-mode:overlay;background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAGQAAABkCAIAAAD/gAIDAAAACXBIWXMAAA7EAAAOxAGVKw4bAAADUElEQVR4nO2aS27bMBCGf6ZIAzdoi6CLbnqBHqBX6BV6hR6hF+gVeoBeoDfoBbpp0UWBIl3UgFvbshLZkuWHJEvikGJmNCMSlOTE/5dv8pLDkTijwWAwGAwGw8sDIcRRNPa2ABBCBJ/qPfEaUVVVURSzLNMiEBG0jCAEh0XFyjGIvSwvLzJBhCBbZZlumgAQ4gqE1OtvbPhgqgBCCLgwBFACISAECAGxVRJaVjwmBJRAKEkxAQhKTgohrlYoCU8QwhqCEJCkuw6CABBpy7KMZb1DCHAEIYQQBABCiAxBCAhCcFA0BCHmG8y+8KHGBCFuI4S4CSFEUCwIkSGEGBDCmiiKotQ6x7HoPaOMWZYZhlFVlZYFIyxIUiQxsnB42WkOrRELJFEUJUmCY2i5DGOs67rf73e73R+/vvBb68e0bxU9Sv4eZVP9zSZvc+eXerPTf/TZx3/7dRwP84/jeq4+LxuTff7zuS3mf+xj7Yo/+xTPbuy1A6Y93LKsPM8FQRDd94oEMRYRBBFCLBKLOOf/OgdOWFfaf9hSAAoR2E5Yu5PnzBwE5QeSdeS0oGgOJ7gQMEOJAT2IEQ2AcbGSIG45qN0OZwKj9pPBaEEJwJGKzCIJsIpBgQO0UYUfIiAaDX9GgLZNMCKCGMGACnZtgZLk8HGFEDGWsFBIFGABJAUEDEGQJtEQE8xAqICGAAEhCEIGhNAC0V0SggzZYmCwjwcPHjz4V/v5Gtzc8Pzc5v/H8S/zv16+XNN3ci8OHDxy/Ok8aL3Xrj1YPHjz413IPHjz48l+7j69+Lj7u6pT5LQI4EAbUtKJrOzjSrPZMAkYs8EYbYDMhm+tFIfCOTNx01ubeA+djAeB+XpfWK39K6sVjzvBwjDmZwCZ4YJfTjFIAaIBgBwghsSgyABF6CMkEMH3dJq6Y4gRwfWiRY3qg4ryOE4xgBHQsTIM+EgRwqIDAgxwmFtgAhlGPFRxsTyMIIAAKqX6QmEZYl/AexFhYlDiwr4RXoFy3GKHRAMLAGsfEWIVhMy9wmJYgz0p1gU4yhYQAE4Zy6bSCpkyHJC6ahmVlSNsYSF3dZFkWGoZT1/5xhsJLKCaJzADS6wDLMsyiLz7flo24mA0OjAYDAbDf8q+nM8d6MB3AAAAAElFTkSuQmCC")}

/* scrollbar (dark) */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:#202020;border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:#2a2a2a}

/* keyframes */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
@keyframes slow-pan{0%{transform:scale(1.05) translate3d(0,0,0)}50%{transform:scale(1.1) translate3d(-1.5%,-1%,0)}100%{transform:scale(1.05) translate3d(0,0,0)}}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes flicker{0%,19%,21%,23%,25%,54%,56%,100%{opacity:1}20%,24%,55%{opacity:.55}}
@keyframes ringspin{to{transform:rotate(360deg)}}
@keyframes scan{0%{transform:translateY(-10%)}100%{transform:translateY(110%)}}

/* progress bar */
.bar{height:2px;background:var(--line);position:relative;overflow:hidden;border-radius:2px}
.bar > span{display:block;height:100%;background:var(--accent);transition:width .2s linear}

/* dashed box */
.dashed{border:1px dashed var(--line-2);border-radius:14px}

/* global layout frame */
.enh-root{position:relative;min-height:100vh;overflow:hidden}

/* top nav */
.nav{position:relative;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:20px 28px;border-bottom:1px solid var(--line)}
.nav .brand{display:flex;align-items:center;gap:18px}
.nav .brand .logo{width:22px;height:22px;border:1.5px solid var(--text);display:grid;place-items:center;font-size:10px;font-family:'JetBrains Mono',monospace;font-weight:700}
.nav .brand .name{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:0.22em;font-weight:700}
.nav .brand .sep{width:1px;height:14px;background:var(--line-2)}
.nav .brand .sub{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.22em;color:var(--muted)}
.nav .right{display:flex;gap:10px;align-items:center}
.nav .right .pill{border:1px solid var(--line-2);border-radius:999px;padding:8px 12px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.2em;color:var(--muted)}
.nav .right .pill.red{border-color:rgba(255,45,30,0.4);color:var(--accent)}

/* footer */
.footer{position:relative;z-index:20;display:flex;justify-content:space-between;align-items:center;padding:20px 28px;border-top:1px solid var(--line);font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.22em;color:var(--muted-2)}

/* variant switcher (only visible in tweaks mode) */
.tweaks{position:fixed;bottom:20px;right:20px;z-index:200;width:280px;background:#0B0B0B;border:1px solid var(--line-2);border-radius:14px;padding:16px;box-shadow:0 20px 60px rgba(0,0,0,0.6);font-family:'JetBrains Mono',monospace;font-size:11px;display:none}
.tweaks.on{display:block}
.tweaks h4{margin:0 0 10px;font-size:10px;letter-spacing:0.22em;color:var(--muted);text-transform:uppercase}
.tweaks .row{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.tweaks .variants{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.tweaks .variants button{border:1px solid var(--line-2);border-radius:6px;padding:10px 4px;font-size:9px;letter-spacing:0.16em;color:var(--muted);text-transform:uppercase}
.tweaks .variants button.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.tweaks .colors{display:flex;gap:8px;flex-wrap:wrap}
.tweaks .colors button{width:26px;height:26px;border-radius:50%;border:2px solid transparent}
.tweaks .colors button.active{border-color:#fff}
.tweaks .close{position:absolute;top:10px;right:10px;font-size:10px;color:var(--muted);cursor:pointer}

/* ========================= VARIANT: STUDIO ========================= */
.v-studio .stage{position:relative;min-height:calc(100vh - 122px);display:grid;place-items:center;padding:40px 28px 60px;overflow:hidden}
.v-studio .hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;animation:slow-pan 22s ease-in-out infinite;filter:saturate(1.1) contrast(1.05)}
.v-studio .hero-bg::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center, rgba(10,10,10,0) 0%, rgba(10,10,10,0.55) 40%, rgba(10,10,10,0.95) 85%)}
.v-studio .ticker{position:absolute;top:18px;left:0;right:0;display:flex;gap:60px;white-space:nowrap;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.24em;color:var(--muted-2);overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.v-studio .ticker .track{display:flex;gap:60px;animation:marquee 40s linear infinite}
.v-studio .ticker span{display:inline-flex;align-items:center;gap:10px}
.v-studio .ticker .sq{width:6px;height:6px;background:var(--accent);display:inline-block}

.v-studio .card{position:relative;z-index:5;width:min(720px,92vw);background:rgba(12,12,12,0.72);backdrop-filter:blur(14px);border:1px solid var(--line-2);border-radius:18px;padding:32px 34px 28px;box-shadow:0 40px 100px rgba(0,0,0,0.6)}
.v-studio .card .wm{font-size:clamp(56px,11vw,132px)}
.v-studio .card .sub{margin-top:8px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.24em;color:var(--muted);text-transform:uppercase}
.v-studio .card .drop{margin-top:22px;position:relative;border:1px dashed #3a3a38;border-radius:12px;padding:34px 20px;text-align:center;background:repeating-linear-gradient(45deg,rgba(255,255,255,0.008) 0 6px,transparent 6px 12px);transition:border-color .18s, background .18s}
.v-studio .card .drop.over{border-color:var(--accent);background:rgba(255,45,30,0.05)}
.v-studio .card .drop .icon{width:34px;height:34px;margin:0 auto 14px}
.v-studio .card .drop .label{font-family:'JetBrains Mono',monospace;font-size:13px;letter-spacing:0.22em;text-transform:uppercase}
.v-studio .card .drop .hint{margin-top:6px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.22em;color:var(--muted);text-transform:uppercase}
.v-studio .card .drop .fmt{margin-top:14px;display:inline-block;padding:5px 10px;border:1px solid var(--line-2);border-radius:999px;font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:0.2em;color:var(--muted);text-transform:uppercase}

.v-studio .meta{display:flex;justify-content:space-between;align-items:center;margin-top:18px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.22em;color:var(--muted-2);text-transform:uppercase}
.v-studio .meta .lora{display:flex;align-items:center;gap:10px}
.v-studio .meta .lora .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 1.6s ease-in-out infinite}

/* lora feature strip */
.v-studio .feature{position:relative;z-index:5;margin:-30px auto 0;width:min(1200px,92vw);padding:40px 0 0;display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:end}
.v-studio .feature h2{font-size:clamp(36px,6vw,64px);margin:0}
.v-studio .feature .copy{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.04em;line-height:1.7;color:var(--muted);text-transform:uppercase}
.v-studio .feature .copy b{color:var(--text);font-weight:500}

.v-studio .examples{margin:50px auto 0;width:min(1200px,92vw);position:relative;z-index:5}
.v-studio .examples .head{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);padding-top:14px;margin-bottom:14px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.22em;color:var(--muted);text-transform:uppercase}
.v-studio .examples .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.v-studio .examples .card-ex{position:relative;aspect-ratio:3/4;background:#0d0d0d;border-radius:8px;overflow:hidden;border:1px solid var(--line)}
.v-studio .examples .card-ex img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}
.v-studio .examples .card-ex:hover img{transform:scale(1.04)}
.v-studio .examples .tag{position:absolute;top:8px;left:8px;font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:0.2em;text-transform:uppercase;padding:4px 6px;background:rgba(0,0,0,0.6);border-radius:4px;color:#fff}

/* ========================= VARIANT: GRID ========================= */
.v-grid .stage{position:relative;min-height:calc(100vh - 122px);padding:0}
.v-grid .backdrop{position:absolute;inset:0;display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:1fr;gap:2px;padding:2px;filter:saturate(0.92)}
.v-grid .backdrop .tile{position:relative;overflow:hidden;background:#0d0d0d}
.v-grid .backdrop .tile img{width:100%;height:100%;object-fit:cover;display:block;opacity:0.85}
.v-grid .backdrop::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center, rgba(10,10,10,0.55) 0%, rgba(10,10,10,0.92) 58%, rgba(10,10,10,1) 100%)}

.v-grid .center{position:relative;z-index:5;display:grid;place-items:center;min-height:calc(100vh - 122px);padding:48px 28px}
.v-grid .wm-wrap{text-align:center;margin-bottom:22px}
.v-grid .wm-wrap h1{font-size:clamp(90px,16vw,220px);margin:0;mix-blend-mode:screen}
.v-grid .wm-wrap .sub{margin-top:-6px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.3em;color:var(--muted);text-transform:uppercase}
.v-grid .dropbox{width:min(620px,92vw);background:rgba(10,10,10,0.78);backdrop-filter:blur(10px);border:1px dashed #3a3a38;border-radius:14px;padding:36px 24px;text-align:center;transition:border-color .18s, background .18s}
.v-grid .dropbox.over{border-color:var(--accent);background:rgba(255,45,30,0.06)}
.v-grid .dropbox .icon{width:32px;height:32px;margin:0 auto 12px}
.v-grid .dropbox .big{font-family:'JetBrains Mono',monospace;font-size:14px;letter-spacing:0.22em;text-transform:uppercase}
.v-grid .dropbox .sm{margin-top:6px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.24em;color:var(--muted);text-transform:uppercase}
.v-grid .dropbox .select{margin-top:20px;width:100%;padding:16px;background:var(--accent);color:#fff;border-radius:999px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.24em;text-transform:uppercase}
.v-grid .dropbox .select:hover{filter:brightness(1.08)}

.v-grid .rail{position:absolute;bottom:0;left:0;right:0;z-index:6;display:flex;justify-content:space-between;align-items:center;padding:14px 28px;border-top:1px solid var(--line);background:rgba(10,10,10,0.7);backdrop-filter:blur(8px);font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.22em;color:var(--muted);text-transform:uppercase}

/* ========================= VARIANT: TERMINAL ========================= */
.v-term{font-family:'JetBrains Mono','IBM Plex Mono',monospace}
.v-term .stage{min-height:calc(100vh - 122px);padding:40px 28px;display:grid;grid-template-columns:1.1fr 0.9fr;gap:28px;position:relative}
.v-term .grid-lines{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:80px 80px;opacity:0.25;pointer-events:none;mask-image:radial-gradient(ellipse at center, rgba(0,0,0,1) 0%, rgba(0,0,0,0) 80%);-webkit-mask-image:radial-gradient(ellipse at center, rgba(0,0,0,1) 0%, rgba(0,0,0,0) 80%)}
.v-term .left{position:relative;display:flex;flex-direction:column;justify-content:space-between}
.v-term .block{border:1px solid var(--line);padding:20px;background:#0b0b0b}
.v-term .block .lbl{font-size:10px;letter-spacing:0.22em;color:var(--muted-2);text-transform:uppercase;margin-bottom:10px}
.v-term .head{font-size:clamp(48px,9vw,120px);line-height:0.88;letter-spacing:-0.03em;font-family:'Helvetica Neue','Arial Black',sans-serif;font-weight:900}
.v-term .kv{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;padding:12px 0;border-bottom:1px solid var(--line);font-size:11px;letter-spacing:0.14em;text-transform:uppercase}
.v-term .kv:last-child{border-bottom:none}
.v-term .kv .k{color:var(--muted-2)}
.v-term .kv .v{color:var(--text)}
.v-term .kv .v .red{color:var(--accent)}

.v-term .right{position:relative;display:flex;flex-direction:column;gap:20px}
.v-term .terminal{background:#0b0b0b;border:1px solid var(--line);padding:0;overflow:hidden}
.v-term .terminal .tbar{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--line);font-size:10px;letter-spacing:0.2em;color:var(--muted);text-transform:uppercase}
.v-term .terminal .tbar .led{width:8px;height:8px;border-radius:50%;background:var(--accent)}
.v-term .terminal .tbody{padding:16px;font-size:12px;line-height:1.7;color:var(--text)}
.v-term .terminal .tbody .p{color:var(--accent)}
.v-term .terminal .tbody .m{color:var(--muted)}
.v-term .terminal .tbody .c{color:#6a6a68}

.v-term .drop-t{border:1px dashed #3a3a38;padding:30px 20px;text-align:center;cursor:pointer;transition:border-color .18s, background .18s;background:#0a0a0a}
.v-term .drop-t.over{border-color:var(--accent);background:rgba(255,45,30,0.05)}
.v-term .drop-t .ln{font-size:12px;letter-spacing:0.22em;text-transform:uppercase;color:var(--text)}
.v-term .drop-t .ln b{color:var(--accent);font-weight:700}
.v-term .drop-t .ln-sm{margin-top:8px;font-size:10px;color:var(--muted);letter-spacing:0.22em;text-transform:uppercase}
.v-term .caret::after{content:"_";color:var(--accent);animation:pulse 1s ease-in-out infinite;margin-left:4px}

/* ========================= VARIANT: HERO ========================= */
.v-hero .stage{position:relative;min-height:calc(100vh - 122px);overflow:hidden}
.v-hero .bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:saturate(1.05)}
.v-hero .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(10,10,10,0.2) 0%, rgba(10,10,10,0.35) 35%, rgba(10,10,10,0.82) 85%, rgba(10,10,10,1) 100%)}
.v-hero .bg::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg, rgba(10,10,10,0.8) 0%, rgba(10,10,10,0.2) 45%, rgba(10,10,10,0.25) 100%)}
.v-hero .left{position:absolute;top:0;left:0;bottom:0;width:56%;z-index:5;padding:60px 56px;display:flex;flex-direction:column;justify-content:space-between}
.v-hero .eyebrow{display:flex;gap:14px;align-items:center;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.24em;color:var(--muted);text-transform:uppercase}
.v-hero .eyebrow .line{width:60px;height:1px;background:var(--accent)}
.v-hero h1{font-size:clamp(96px,14vw,200px);margin:18px 0 0;font-family:'Helvetica Neue','Arial Black',sans-serif;font-weight:900;line-height:0.84;letter-spacing:-0.035em}
.v-hero .lead{margin-top:22px;max-width:520px;font-family:'JetBrains Mono',monospace;font-size:13px;line-height:1.7;color:#cdcdcb;text-transform:uppercase;letter-spacing:0.04em}
.v-hero .ctas{display:flex;gap:10px;margin-top:28px;flex-wrap:wrap}
.v-hero .stats{display:flex;gap:32px;margin-top:26px;font-family:'JetBrains Mono',monospace}
.v-hero .stats .stat .n{font-size:28px;letter-spacing:-0.01em}
.v-hero .stats .stat .l{font-size:10px;letter-spacing:0.22em;color:var(--muted);text-transform:uppercase}
.v-hero .side{position:absolute;right:40px;top:0;bottom:0;width:36%;z-index:5;padding:60px 0;display:flex;flex-direction:column;justify-content:center;gap:14px}
.v-hero .side .up{background:rgba(10,10,10,0.72);backdrop-filter:blur(10px);border:1px solid var(--line-2);border-radius:14px;padding:18px}
.v-hero .side .up .top{display:flex;justify-content:space-between;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.22em;color:var(--muted);text-transform:uppercase;margin-bottom:10px}
.v-hero .side .up .drop-h{border:1px dashed #3a3a38;border-radius:10px;padding:24px 16px;text-align:center;transition:border-color .18s, background .18s}
.v-hero .side .up .drop-h.over{border-color:var(--accent);background:rgba(255,45,30,0.06)}
.v-hero .side .up .drop-h .t{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:0.22em;text-transform:uppercase}
.v-hero .side .up .drop-h .s{margin-top:4px;font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:0.22em;text-transform:uppercase}
.v-hero .side .up .select-h{margin-top:14px;width:100%;padding:14px;background:var(--accent);color:#fff;border-radius:999px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.22em;text-transform:uppercase}

/* ========================= UPLOAD PROGRESS + RESULT (shared) ========================= */
.modal{position:fixed;inset:0;z-index:100;background:rgba(5,5,5,0.88);backdrop-filter:blur(10px);display:grid;place-items:center;padding:28px;opacity:0;pointer-events:none;transition:opacity .25s}
.modal.on{opacity:1;pointer-events:auto}
.modal .panel{width:min(1200px,96vw);max-height:92vh;background:#0b0b0b;border:1px solid var(--line-2);border-radius:18px;overflow:hidden;display:flex;flex-direction:column}
.modal .phead{display:flex;justify-content:space-between;align-items:center;padding:16px 22px;border-bottom:1px solid var(--line);font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.22em;color:var(--muted);text-transform:uppercase}
.modal .phead .close{cursor:pointer;color:var(--muted)}
.modal .phead .close:hover{color:var(--text)}

/* processing */
.proc{padding:48px 36px;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.proc .preview{position:relative;aspect-ratio:4/3;background:#0a0a0a;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.proc .preview img{width:100%;height:100%;object-fit:cover;filter:brightness(0.7)}
.proc .preview .scan{position:absolute;left:0;right:0;height:80px;background:linear-gradient(180deg,rgba(255,45,30,0) 0%,rgba(255,45,30,0.25) 50%,rgba(255,45,30,0) 100%);animation:scan 2.2s linear infinite}
.proc .preview .corner{position:absolute;width:22px;height:22px;border:2px solid var(--accent)}
.proc .preview .corner.tl{top:10px;left:10px;border-right:0;border-bottom:0}
.proc .preview .corner.tr{top:10px;right:10px;border-left:0;border-bottom:0}
.proc .preview .corner.bl{bottom:10px;left:10px;border-right:0;border-top:0}
.proc .preview .corner.br{bottom:10px;right:10px;border-left:0;border-top:0}
.proc .right{font-family:'JetBrains Mono',monospace}
.proc .right .label{font-size:10px;letter-spacing:0.24em;color:var(--muted);text-transform:uppercase}
.proc .right h2{font-family:'Helvetica Neue','Arial Black',sans-serif;font-weight:900;font-size:clamp(42px,6vw,74px);margin:8px 0 20px;letter-spacing:-0.02em;line-height:0.92}
.proc .right .bar{margin:18px 0 8px}
.proc .right .pmeta{display:flex;justify-content:space-between;font-size:10px;letter-spacing:0.22em;color:var(--muted);text-transform:uppercase}
.proc .steps{margin-top:28px;border-top:1px solid var(--line);padding-top:18px;display:flex;flex-direction:column;gap:10px}
.proc .step{display:grid;grid-template-columns:22px 1fr auto;gap:12px;align-items:center;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted)}
.proc .step.done{color:var(--text)}
.proc .step.active{color:var(--text)}
.proc .step .ic{width:14px;height:14px;border:1.5px solid var(--muted-2);border-radius:50%}
.proc .step.done .ic{background:var(--accent);border-color:var(--accent)}
.proc .step.active .ic{border-color:var(--accent);position:relative}
.proc .step.active .ic::after{content:"";position:absolute;inset:-4px;border:1.5px solid var(--accent);border-right-color:transparent;border-radius:50%;animation:ringspin 0.9s linear infinite}
.proc .step .t{font-family:'JetBrains Mono',monospace}
.proc .step .s{font-family:'JetBrains Mono',monospace;font-size:10px}

/* result */
.res{display:flex;flex-direction:column}
.res .compare{position:relative;background:#080808;aspect-ratio:16/9;width:100%;max-height:calc(92vh - 130px);overflow:hidden;user-select:none}
.res .compare .layer{position:absolute;inset:0}
.res .compare .layer img{width:100%;height:100%;object-fit:contain;display:block}
.res .compare .after{clip-path:inset(0 0 0 var(--split,50%))}
.res .compare .handle{position:absolute;top:0;bottom:0;left:var(--split,50%);width:2px;background:var(--accent);cursor:ew-resize;z-index:5}
.res .compare .handle::before{content:"";position:absolute;inset:0 -20px;cursor:ew-resize}
.res .compare .knob{position:absolute;top:50%;left:var(--split,50%);transform:translate(-50%,-50%);width:44px;height:44px;border-radius:50%;background:var(--accent);display:grid;place-items:center;cursor:ew-resize;z-index:6;box-shadow:0 0 0 6px rgba(255,45,30,0.18)}
.res .compare .tag{position:absolute;top:14px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.22em;text-transform:uppercase;padding:6px 10px;background:rgba(0,0,0,0.7);border:1px solid var(--line-2);border-radius:4px;color:#fff;z-index:4}
.res .compare .tag.l{left:14px}
.res .compare .tag.r{right:14px;background:var(--accent);border-color:var(--accent)}
.res .rbar{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-top:1px solid var(--line);font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.22em;color:var(--muted);text-transform:uppercase}
.res .rbar .stats{display:flex;gap:26px}
.res .rbar .stats .s .n{color:var(--text)}
.res .rbar .actions{display:flex;gap:10px}

/* ========================= TWEAKS ========================= */
body.tweaks-on .tweaks{display:block}
