
:root{
  --bg:#101216;--panel:#181b21;--panel-2:#1f232b;--panel-3:#262b34;
  --line:#2a2f39;--line-2:#363c47;--text:#e7e9ee;--muted:#8b919e;--faint:#5a606c;
  --accent:#e7a83c;--accent-dim:#3a2f17;--keep:#46b07a;--keep-dim:#16301f;
  --delete:#e0566f;--delete-dim:#321a20;--sel:#4ea0e0;--sel-dim:#14283a;
  --radius:10px;--radius-sm:6px;--ui:'Archivo',system-ui,sans-serif;--mono:'JetBrains Mono',ui-monospace,Menlo,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{background:var(--bg);color:var(--text);font-family:var(--ui);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased;overflow:hidden}
button,input,select{font-family:inherit;color:inherit}
button{cursor:pointer;border:none;background:none}
.mono{font-family:var(--mono);font-feature-settings:"tnum"}
.app{display:flex;flex-direction:column;height:100vh}
.frost{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:linear-gradient(to top,rgba(8,9,11,.82),rgba(8,9,11,.5))}

.topbar{display:flex;align-items:center;gap:18px;height:56px;flex:0 0 56px;padding:0 18px;background:var(--panel);border-bottom:1px solid var(--line);z-index:20}
.brand{display:flex;align-items:center;gap:10px;cursor:pointer}
.brand .glyph{width:23px;height:23px;border:2px solid var(--accent);border-radius:5px;position:relative;flex:0 0 auto}
.brand .glyph::after{content:"";position:absolute;inset:4px;border:1.5px solid var(--accent);border-radius:2px;opacity:.6}
.brand .wm{font-weight:800;font-size:16px}.brand .wm .dot{color:var(--accent)}
.modes{display:flex;gap:2px;margin-left:8px;background:var(--bg);padding:3px;border-radius:8px;border:1px solid var(--line)}
.modes button{padding:6px 14px;border-radius:6px;color:var(--muted);font-weight:600;font-size:12.5px;transition:.15s;display:flex;align-items:center;gap:7px}
.modes button .count{font-family:var(--mono);font-size:10.5px;background:var(--panel-3);color:var(--muted);padding:1px 6px;border-radius:20px;line-height:1.6}
.modes button.active{background:var(--panel-3);color:var(--text)}
.modes button.active .count{background:var(--accent);color:#1a1206}
.modes button:hover:not(.active){color:var(--text)}
.spacer{flex:1}
.viewas{display:flex;align-items:center;gap:9px;font-size:12px;color:var(--muted)}
.viewas select{background:var(--bg);border:1px solid var(--line);color:var(--text);padding:7px 10px;border-radius:8px;font-weight:600;font-size:12.5px;max-width:230px}
.role-pill{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;padding:3px 9px;border-radius:5px;background:var(--accent-dim);color:var(--accent);white-space:nowrap}
.role-pill.client{background:var(--sel-dim);color:var(--sel)}

.main{flex:1;overflow:auto;position:relative}
.wrap{max-width:1180px;margin:0 auto;padding:28px 24px 70px}
.crumbs{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);margin-bottom:22px;flex-wrap:wrap}
.crumbs button{color:var(--muted);font-weight:600}.crumbs button:hover{color:var(--accent)}
.crumbs .sep{color:var(--faint)}.crumbs .here{color:var(--text);font-weight:700}
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);margin-bottom:6px}
.h1{font-size:26px;font-weight:800;letter-spacing:-.01em;margin-bottom:2px}
.sub{color:var(--muted);font-size:13.5px;margin-bottom:26px;max-width:64ch}

.grid{display:grid;gap:14px}
.grid.years{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
.grid.mfrs{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
.grid.shoots{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.grid.photos{grid-template-columns:repeat(auto-fill,minmax(190px,1fr))}

.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;text-align:left;transition:.16s;position:relative;overflow:hidden}
.card:hover{border-color:var(--line-2);transform:translateY(-2px);background:var(--panel-2)}
.card .kbig{font-family:var(--mono);font-size:30px;font-weight:700}.card .kbig.accent{color:var(--accent)}
.card .klabel{color:var(--muted);font-size:12.5px;margin-top:8px;display:flex;justify-content:space-between;align-items:center}
.card .pill{font-family:var(--mono);font-size:10.5px;color:var(--muted);border:1px solid var(--line);padding:2px 8px;border-radius:20px}
.mfr-card{display:flex;flex-direction:column;gap:14px;min-height:120px}
.mfr-card .mname{font-size:18px;font-weight:700}
.mfr-card .mmeta{margin-top:auto;display:flex;justify-content:space-between;color:var(--muted);font-size:12px}

.shoot-card{padding:0;aspect-ratio:4/3;position:relative;background:#000}
.shoot-card svg{position:absolute;inset:0;width:100%;height:100%;display:block}
.shoot-card .tag{position:absolute;top:10px;left:10px;z-index:2}
.shoot-meta{position:absolute;left:0;right:0;bottom:0;padding:12px 14px 13px;z-index:2}
.shoot-meta .model{font-size:15.5px;font-weight:700;display:flex;align-items:center;gap:8px;color:#fff}
.swatch{width:12px;height:12px;border-radius:3px;flex:0 0 auto;border:1px solid rgba(255,255,255,.35);box-shadow:0 0 0 1px rgba(0,0,0,.3)}
.shoot-meta .row{display:flex;justify-content:space-between;margin-top:7px;font-size:12px;color:#c7ccd4}
.shoot-meta .vin{font-family:var(--mono)}.shoot-meta .vin .pre{color:#8b919e}
.tag{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;padding:3px 8px;border-radius:5px}
.tag.final{background:rgba(70,176,122,.9);color:#06160e}
.tag.selecting{background:rgba(231,168,60,.9);color:#1a1206}
.tag.finalising{background:rgba(78,160,224,.9);color:#04121f}
.tag.muted{background:rgba(38,43,52,.85);color:#c7ccd4}

.pcell{border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--line);position:relative;aspect-ratio:3/2;background:#0a0b0e}
.pcell svg{display:block;width:100%;height:100%}
.pcell:hover{border-color:var(--line-2)}
.pcell .fnum{position:absolute;bottom:6px;right:7px;font-family:var(--mono);font-size:10px;padding:2px 7px;border-radius:4px;color:#fff}
.pcell .setchip{position:absolute;top:6px;left:7px;font-family:var(--mono);font-size:9px;letter-spacing:.04em;text-transform:uppercase;padding:2px 6px;border-radius:4px;background:rgba(8,9,11,.7);color:#c7ccd4}

.settabs{display:flex;gap:6px;margin-bottom:18px;flex-wrap:wrap}
.settabs button{padding:7px 14px;border-radius:8px;font-weight:600;font-size:12.5px;color:var(--muted);background:var(--panel);border:1px solid var(--line);transition:.15s;display:flex;align-items:center;gap:8px}
.settabs button .n{font-family:var(--mono);font-size:10.5px;color:var(--faint)}
.settabs button.on{background:var(--panel-3);color:var(--text);border-color:var(--line-2)}
.settabs button.on .n{color:var(--accent)}
.settabs button:hover:not(.on){color:var(--text)}

.queue{display:flex;flex-direction:column;gap:12px}
.qrow{display:flex;align-items:center;gap:18px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px 14px 14px;transition:.15s}
.qrow:hover{border-color:var(--line-2);background:var(--panel-2)}
.qthumb{width:104px;height:70px;border-radius:var(--radius-sm);overflow:hidden;flex:0 0 auto;border:1px solid var(--line);background:#0a0b0e}
.qthumb svg{width:100%;height:100%;display:block}
.qinfo{flex:1;min-width:0}
.qinfo .model{font-size:15.5px;font-weight:700;display:flex;align-items:center;gap:8px}
.qinfo .swatch{border-color:rgba(255,255,255,.18)}
.qinfo .meta{color:var(--muted);font-size:12.5px;margin-top:4px}.qinfo .meta .vin{font-family:var(--mono)}
.qprog{width:210px;flex:0 0 auto}
.qprog .bar{height:6px;border-radius:6px;background:var(--panel-3);overflow:hidden;display:flex}
.qprog .bar i{display:block;height:100%}.qprog .bar .ik{background:var(--keep)}.qprog .bar .id{background:var(--delete)}
.qprog .nums{display:flex;justify-content:space-between;margin-top:6px;font-family:var(--mono);font-size:11px;color:var(--muted)}
.btn{padding:9px 16px;border-radius:8px;font-weight:700;font-size:13px;background:var(--panel-3);color:var(--text);border:1px solid var(--line-2);transition:.15s;white-space:nowrap}
.btn:hover{border-color:var(--muted)}
.btn.primary{background:var(--accent);color:#1a1206;border-color:var(--accent)}.btn.primary:hover{filter:brightness(1.08)}
.btn.ghost{background:transparent}
.btn.danger{color:var(--delete);border-color:var(--delete-dim)}.btn.danger:hover{background:var(--delete-dim);border-color:var(--delete)}
.btn.sm{padding:6px 12px;font-size:12px}
.btn:disabled{opacity:.4;cursor:not-allowed}.btn:disabled:hover{filter:none;border-color:var(--line-2)}
.empty{text-align:center;padding:70px 20px;color:var(--muted)}.empty .big{font-size:17px;color:var(--text);font-weight:700;margin-bottom:6px}

.deck{position:fixed;inset:0;background:#0a0b0e;z-index:50;display:flex;flex-direction:column}
.deck-head{display:flex;align-items:center;gap:16px;padding:12px 18px;height:56px;flex:0 0 56px;border-bottom:1px solid var(--line)}
.deck-head .x{font-size:20px;color:var(--muted);width:30px;height:30px;border-radius:6px;display:grid;place-items:center}
.deck-head .x:hover{background:var(--panel-2);color:var(--text)}
.deck-meta{display:flex;align-items:center;gap:12px;font-size:13px;flex-wrap:wrap}
.deck-meta .model{font-weight:700;font-size:15px;display:flex;align-items:center;gap:8px}
.deck-meta .chip{font-family:var(--mono);font-size:11.5px;color:var(--muted);border:1px solid var(--line);padding:3px 9px;border-radius:6px}
.deck-meta .chip .pre{color:var(--faint)}
.deck-tally{display:flex;gap:8px}
.tally{font-family:var(--mono);font-size:12px;padding:5px 11px;border-radius:7px;display:flex;gap:7px;align-items:center}
.tally.k{background:var(--keep-dim);color:var(--keep)}.tally.d{background:var(--delete-dim);color:var(--delete)}.tally.p{background:var(--panel-2);color:var(--muted)}
.deck-sub{display:flex;align-items:center;gap:12px;padding:9px 18px;border-bottom:1px solid var(--line);background:rgba(16,18,22,.5)}
.deck-sub .settabs{margin:0}
.modeswitch{margin-left:auto;display:flex;background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:3px;gap:2px}
.modeswitch button{padding:6px 14px;border-radius:6px;color:var(--muted);font-weight:600;font-size:12px}
.modeswitch button.on{background:var(--panel-3);color:var(--text)}
.stage{flex:1;position:relative;display:grid;place-items:center;padding:22px;overflow:hidden}
.frame{position:relative;max-width:100%;max-height:100%;border-radius:10px;overflow:hidden;box-shadow:0 24px 70px rgba(0,0,0,.6);outline:3px solid transparent;outline-offset:3px}
.frame svg{display:block;width:auto;max-width:min(1100px,86vw);max-height:calc(100vh - 290px)}
.frame.is-keep{outline-color:var(--keep)}.frame.is-delete{outline-color:var(--delete)}
.frame.is-delete svg{filter:grayscale(1) brightness(.5)}
.frame .decided{position:absolute;top:14px;left:14px;font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:5px 12px;border-radius:7px;z-index:2}
.frame.is-keep .decided{background:var(--keep);color:#06160e}.frame.is-delete .decided{background:var(--delete);color:#1c0508}
.frame .fbar{position:absolute;left:0;right:0;bottom:0;padding:18px 16px 12px;display:flex;justify-content:flex-end;align-items:flex-end}
.frame .fbar .fcount{font-family:var(--mono);font-size:13px;color:#fff;font-weight:700}
.frame .fbar .setname{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#c7ccd4;margin-right:auto}
.nav-arrow{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:64px;border-radius:10px;background:rgba(24,27,33,.6);border:1px solid var(--line);color:var(--muted);font-size:22px;display:grid;place-items:center;transition:.15s;z-index:3}
.nav-arrow:hover{color:var(--text);border-color:var(--line-2);background:var(--panel-2)}
.nav-arrow.left{left:18px}.nav-arrow.right{right:18px}.nav-arrow:disabled{opacity:.25;cursor:default}
.controls{display:flex;align-items:center;justify-content:center;gap:14px;padding:14px 18px 6px}
.dbtn{display:flex;align-items:center;gap:11px;padding:12px 26px;border-radius:11px;font-weight:700;font-size:15px;border:1.5px solid var(--line-2);background:var(--panel-2);transition:.13s}
.dbtn .key{font-family:var(--mono);font-size:11px;border:1px solid currentColor;border-radius:5px;padding:2px 8px;opacity:.85}
.dbtn.keep{color:var(--keep)}.dbtn.keep:hover{background:var(--keep);color:#06160e;border-color:var(--keep)}
.dbtn.del{color:var(--delete)}.dbtn.del:hover{background:var(--delete);color:#1c0508;border-color:var(--delete)}
.dbtn.undo{color:var(--muted);font-size:13px;padding:12px 18px}.dbtn.undo:hover{color:var(--text);border-color:var(--muted)}
.sheet{position:absolute;inset:0;overflow:auto;padding:18px 22px 26px}
.sheet-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(168px,1fr))}
.scell{position:relative;border-radius:8px;overflow:hidden;border:2px solid transparent;aspect-ratio:3/2;background:#0a0b0e;transition:.12s}
.scell svg{width:100%;height:100%;display:block}
.scell.delete svg{filter:grayscale(1) brightness(.42)}
.scell.keep::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 3px var(--keep)}
.scell.delete::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 3px var(--delete)}
.scell.selected{border-color:var(--sel);box-shadow:0 0 0 2px var(--sel)}
.scell .mark{position:absolute;top:6px;right:7px;font-family:var(--mono);font-size:11px;font-weight:700;padding:2px 6px;border-radius:4px}
.scell.keep .mark{background:var(--keep);color:#06160e}.scell.delete .mark{background:var(--delete);color:#1c0508}
.scell .check{position:absolute;top:6px;left:7px;width:20px;height:20px;border-radius:5px;border:2px solid rgba(255,255,255,.55);background:rgba(8,9,11,.4);display:grid;place-items:center;font-size:12px;color:#fff}
.scell.selected .check{background:var(--sel);border-color:var(--sel)}
.scell .sf{position:absolute;bottom:5px;right:7px;font-family:var(--mono);font-size:10px;color:#fff;text-shadow:0 1px 3px #000}
.strip-wrap{flex:0 0 auto;border-top:1px solid var(--line);background:rgba(16,18,22,.6)}
.strip-bar{display:flex;align-items:center;gap:14px;padding:10px 18px}
.strip-hint{font-family:var(--mono);font-size:11px;color:var(--faint);white-space:nowrap}.strip-hint b{color:var(--muted)}
.finish-wrap{margin-left:auto;display:flex;align-items:center;gap:12px}.finish-note{font-size:12px;color:var(--muted)}
.strip{display:flex;gap:6px;overflow-x:auto;padding:0 18px 14px;scrollbar-width:thin;position:relative}
.strip::-webkit-scrollbar{height:7px}.strip::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:4px}
.sframe{flex:0 0 auto;width:78px;height:52px;border-radius:6px;overflow:hidden;position:relative;border:2px solid transparent;opacity:.5;transition:opacity .12s,border-color .12s;background:#0a0b0e}
.sframe svg{width:100%;height:100%;display:block}.sframe:hover{opacity:.85}
.sframe.active{border-color:var(--accent);opacity:1}
.sframe.keep{opacity:1}.sframe.keep::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 2px var(--keep)}
.sframe.delete{opacity:1}.sframe.delete svg{filter:grayscale(1) brightness(.4)}.sframe.delete::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 2px var(--delete)}
.sframe .badge{position:absolute;top:3px;right:4px;font-family:var(--mono);font-size:9px;font-weight:700}
.sframe.keep .badge{color:var(--keep)}.sframe.delete .badge{color:var(--delete)}
.bulkbar{display:flex;align-items:center;gap:12px;padding:12px 18px;border-top:1px solid var(--line);background:rgba(16,18,22,.7)}
.bulkbar .info{font-family:var(--mono);font-size:12.5px;color:var(--sel)}.bulkbar .hint{font-family:var(--mono);font-size:11px;color:var(--faint)}

.admin-tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.admin-tabs button{padding:11px 16px;color:var(--muted);font-weight:700;font-size:13.5px;border-bottom:2px solid transparent;margin-bottom:-1px}
.admin-tabs button.on{color:var(--text);border-color:var(--accent)}.admin-tabs button:hover:not(.on){color:var(--text)}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px;margin-bottom:18px}
.panel h3{font-size:15px;font-weight:800;margin-bottom:4px}.panel .pdesc{color:var(--muted);font-size:12.5px;margin-bottom:18px}
.formgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 16px}
.field label{display:block;font-size:12px;color:var(--muted);margin-bottom:6px;font-weight:600}
.field input,.field select{width:100%;padding:10px 12px;border-radius:8px;background:var(--bg);border:1px solid var(--line);color:var(--text);font-size:13px}
.field input:focus,.field select:focus{outline:none;border-color:var(--accent)}
.field input.mono{font-family:var(--mono)}.field.full{grid-column:1/-1}
.colour-select{display:flex;align-items:center;gap:10px}.colour-select select{flex:1}
.swatch-lg{width:36px;height:36px;border-radius:8px;border:1px solid var(--line-2);flex:0 0 auto}
.toggle{display:inline-flex;background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:3px}
.toggle button{padding:8px 14px;border-radius:6px;color:var(--muted);font-weight:600;font-size:12.5px}.toggle button.on{background:var(--panel-3);color:var(--text)}
.uploadzone{border:1.5px dashed var(--line-2);border-radius:10px;padding:26px;text-align:center;color:var(--muted)}.uploadzone .big{color:var(--text);font-weight:700;margin-bottom:4px}
.pathline{font-family:var(--mono);font-size:12px;color:var(--muted);background:var(--bg);border:1px solid var(--line);padding:10px 12px;border-radius:8px;word-break:break-all}
.pathline b{color:var(--keep)}
.dtable{width:100%;border-collapse:collapse;font-size:13px}
.dtable th{text-align:left;color:var(--faint);font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;padding:8px 10px;border-bottom:1px solid var(--line);font-weight:600}
.dtable td{padding:11px 10px;border-bottom:1px solid var(--line);vertical-align:middle}
.dtable tr:last-child td{border-bottom:none}
.dtable .tmini{width:54px;height:36px;border-radius:5px;overflow:hidden;border:1px solid var(--line);background:#0a0b0e}.dtable .tmini svg{width:100%;height:100%;display:block}
.dtable .act{display:flex;gap:8px;justify-content:flex-end}
.filterbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.filterbar input,.filterbar select{padding:9px 11px;border-radius:8px;background:var(--bg);border:1px solid var(--line);color:var(--text);font-size:13px}
.filterbar input{flex:1;min-width:200px}
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip-x{display:inline-flex;align-items:center;gap:7px;background:var(--panel-3);border:1px solid var(--line);padding:5px 8px 5px 11px;border-radius:7px;font-size:12.5px}
.chip-x button{color:var(--faint);font-size:13px;line-height:1}.chip-x button:hover{color:var(--delete)}
.brandrow{padding:14px 0;border-bottom:1px solid var(--line)}.brandrow:last-child{border-bottom:none}
.brandrow .bh{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.brandrow .bh b{font-size:15px}
.inline-add{display:flex;gap:8px;margin-top:10px}
.inline-add input,.inline-add select{padding:8px 11px;border-radius:7px;background:var(--bg);border:1px solid var(--line);color:var(--text);font-size:13px}
.inline-add input{flex:1}
.perm-toggles{display:flex;gap:16px;flex-wrap:wrap}
.perm{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--muted)}.perm input{width:16px;height:16px;accent-color:var(--accent)}
.banner{padding:11px 14px;border-radius:8px;background:var(--keep-dim);color:var(--keep);font-size:13px;font-weight:600;margin-bottom:16px;display:flex;align-items:center;gap:9px}

.overlay{position:fixed;inset:0;background:rgba(6,7,9,.72);z-index:60;display:grid;place-items:center;padding:20px}
.modal{background:var(--panel);border:1px solid var(--line-2);border-radius:14px;max-width:560px;width:100%;padding:26px;max-height:88vh;overflow:auto}
.modal h2{font-size:19px;font-weight:800;margin-bottom:5px}.modal p.lead{color:var(--muted);font-size:13px;margin-bottom:20px}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:22px}
.lightbox{position:fixed;inset:0;background:rgba(6,7,9,.93);z-index:55;display:grid;place-items:center;padding:40px}
.lightbox svg{max-width:90vw;max-height:82vh;border-radius:10px;box-shadow:0 20px 60px rgba(0,0,0,.6)}
.lightbox .lx{position:absolute;top:22px;right:24px;font-size:26px;color:var(--muted)}.lightbox .lx:hover{color:#fff}
.lightbox .larrow{position:absolute;top:50%;transform:translateY(-50%);font-size:30px;color:var(--muted);padding:20px}.lightbox .larrow:hover{color:#fff}
.lightbox .larrow.l{left:10px}.lightbox .larrow.r{right:10px}
.lightbox .lcap{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:12px;color:var(--muted)}
.review-block{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin-bottom:18px}
.review-block .rtitle{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px;flex-wrap:wrap}
.review-block .rtitle .model{font-size:16px;font-weight:700;display:flex;align-items:center;gap:8px}
.review-paths{display:flex;flex-direction:column;gap:6px;margin:10px 0 14px}

@media (max-width:760px){.modes button .count{display:none}.qprog{display:none}.deck-meta .chip{display:none}.strip-hint{display:none}.formgrid{grid-template-columns:1fr}.viewas span.lbl{display:none}}
@media (prefers-reduced-motion:reduce){*{transition:none!important}}

/* ===== real-image overrides (replacing prototype SVG) ===== */
.pcell img,.qthumb img,.sframe img,.scell img,.tmini img{width:100%;height:100%;object-fit:cover;display:block}
.shoot-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.frame img{display:block;width:auto;max-width:min(1100px,86vw);max-height:calc(100vh - 290px)}
.lightbox img{max-width:90vw;max-height:82vh;border-radius:10px;box-shadow:0 20px 60px rgba(0,0,0,.6)}
.frame.is-delete img{filter:grayscale(1) brightness(.5)}
.scell.delete img{filter:grayscale(1) brightness(.42)}
.sframe.delete img{filter:grayscale(1) brightness(.4)}

/* ===== login ===== */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}
.login-card{width:100%;max-width:390px;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:32px}
.login-card .brand{justify-content:center;margin-bottom:18px}
.login-card h1{font-size:18px;font-weight:800;text-align:center;margin-bottom:4px}
.login-card .sub{text-align:center;margin-bottom:22px}
.login-field{margin-bottom:13px}
.login-field label{display:block;font-size:12px;color:var(--muted);margin-bottom:6px;font-weight:600}
.login-field input{width:100%;padding:12px 13px;border-radius:9px;background:var(--bg);border:1px solid var(--line);color:var(--text);font-size:14px}
.login-field input:focus{outline:none;border-color:var(--accent)}
.login-err{color:var(--delete);font-size:13px;margin:4px 0 12px;font-weight:600}
.login-card .btn{width:100%;justify-content:center;text-align:center;display:block;margin-top:6px}

/* ===== folder browser ===== */
.browser-crumbs{display:flex;gap:6px;flex-wrap:wrap;font-family:var(--mono);font-size:12px;margin-bottom:12px;color:var(--muted)}
.browser-crumbs button{color:var(--accent);font-weight:600}
.browser-crumbs .sep{color:var(--faint)}
.browser-list{max-height:46vh;overflow:auto;border:1px solid var(--line);border-radius:9px;background:var(--bg)}
.browser-item{display:flex;align-items:center;gap:11px;padding:11px 13px;border-bottom:1px solid var(--line);cursor:pointer;width:100%;text-align:left}
.browser-item:last-child{border-bottom:none}
.browser-item:hover{background:var(--panel-2)}
.browser-item .ic{width:22px;height:18px;border-radius:3px;background:var(--panel-3);border:1px solid var(--line-2);flex:0 0 auto;position:relative}
.browser-item .ic::before{content:"";position:absolute;top:-3px;left:2px;width:8px;height:3px;border-radius:2px 2px 0 0;background:var(--panel-3);border:1px solid var(--line-2);border-bottom:none}
.browser-item .nm{font-size:13.5px;font-weight:600}
.browser-item .badge{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--keep);background:var(--keep-dim);padding:2px 8px;border-radius:5px}
.browser-empty{padding:24px;text-align:center;color:var(--faint);font-size:13px}

/* ===== misc ===== */
.loading{padding:64px 20px;text-align:center;color:var(--muted)}
.spinner{width:26px;height:26px;border:3px solid var(--line-2);border-top-color:var(--accent);border-radius:50%;display:inline-block;animation:spin .8s linear infinite;margin-bottom:12px}
@keyframes spin{to{transform:rotate(360deg)}}
.topbar .logout{color:var(--muted);font-size:12px;font-weight:600;padding:6px 10px;border-radius:7px;border:1px solid var(--line)}
.topbar .logout:hover{color:var(--text);border-color:var(--line-2)}
.whoami{font-size:12px;color:var(--muted)}.whoami b{color:var(--text)}
.upload-list{margin-top:10px;font-family:var(--mono);font-size:11.5px;color:var(--muted)}
