/* TOPS Cellar Selection Club — admin app component styles.
   Ported from the approved cellar-club-admin-prototype.html with the device frame
   removed. Colour/type tokens come from css/tokens.css (LOCKED). */

[hidden]{display:none!important}
*,*::before,*::after{box-sizing:border-box}
/* iOS Safari zooms in (and stays zoomed) when focusing inputs under 16px — keep form controls at 16px. */
input,textarea,select{font-size:16px}
html,body{height:100%;max-width:100%;overflow-x:hidden}
body{background:radial-gradient(circle at 50% 0%,#17171b,#0a0a0c 70%);min-height:100%;color:var(--paper);overscroll-behavior-y:none}
#admin{display:flex;flex-direction:column;height:100vh;height:100dvh;max-width:520px;margin:0 auto;background:var(--bg);position:relative}
.vp{flex:1;overflow-y:auto;scrollbar-width:none;padding-top:env(safe-area-inset-top)}
.vp::-webkit-scrollbar{display:none}
.view{display:none}.view.on{display:block}

.label{display:flex;align-items:center;gap:11px;padding:20px 20px 11px}
.label span{font-size:9px;letter-spacing:2.2px;color:var(--gold);font-weight:700;text-transform:uppercase}
.label .ln{flex:1;height:1px;background:var(--hair)}
.btn{border:none;padding:13px 18px;border-radius:30px;cursor:pointer;font-size:13px;font-weight:700;background:linear-gradient(180deg,var(--gold-br),var(--gold));color:#241a08;letter-spacing:.2px}
.btn.block{width:100%;padding:15px;font-size:14px}
.btn[disabled]{opacity:.5;pointer-events:none}
.ghost{background:transparent;border:1px solid var(--hair);color:var(--gold-br);font-weight:600}
.bhead{display:flex;align-items:center;gap:13px;padding:14px 20px 4px}
.bhead .bk{width:34px;height:34px;border-radius:50%;border:1px solid var(--hair);display:flex;align-items:center;justify-content:center;color:var(--gold-br);font-size:16px;cursor:pointer}
.bhead .ti{font-family:var(--disp);font-size:23px;font-weight:600;color:var(--paper)}
.muted{color:var(--muted)}
.toast{position:fixed;left:50%;bottom:84px;transform:translateX(-50%) translateY(20px);background:var(--surface2);border:1px solid var(--hair);color:var(--paper);padding:12px 18px;border-radius:30px;font-size:12.5px;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;z-index:60;max-width:88vw;text-align:center}
.toast.on{opacity:1;transform:translateX(-50%) translateY(0)}

/* login */
.login{padding:30px 26px calc(30px + env(safe-area-inset-bottom));min-height:100%;display:flex;flex-direction:column;text-align:center}
.login .crest{width:64px;height:64px;border-radius:50%;border:1px solid var(--hair);display:flex;align-items:center;justify-content:center;margin:30px auto 0;color:var(--gold-br);font-size:26px}
.login h1{font-family:var(--disp);font-size:30px;font-weight:600;margin-top:18px;line-height:1.05}
.login .sub{font-size:12px;color:var(--muted);margin-top:10px}
.login .pf{margin-top:28px}
.login input{background:var(--surface);border:1px solid var(--cardbd);border-radius:12px;padding:14px 16px;font-size:16px;color:var(--paper);width:100%;text-align:center;letter-spacing:2px;font-family:var(--body)}
.login .err{color:#e98a8a;font-size:11px;margin-top:10px;min-height:14px}
.login .cta{margin-top:auto;padding-top:30px}

/* dashboard */
.dtop{padding:8px 20px 6px}
.dtop .who{font-size:10px;letter-spacing:1.4px;color:var(--muted);text-transform:uppercase;font-weight:600}
.dtop h1{font-family:var(--disp);font-size:27px;font-weight:600;margin-top:5px}
.createbtn{margin:12px 20px 0;width:calc(100% - 40px);border-radius:18px;padding:18px;cursor:pointer;background:linear-gradient(160deg,var(--wine),var(--wine2));border:1px solid rgba(194,162,90,.3);color:var(--paper);display:flex;align-items:center;gap:13px;text-align:left}
.createbtn .ic{width:42px;height:42px;border-radius:12px;background:rgba(0,0,0,.25);display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--gold-br)}
.createbtn .tx b{font-family:var(--disp);font-size:19px;font-weight:600;display:block}
.createbtn .tx span{font-size:10.5px;color:rgba(247,244,238,.7)}
.stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:14px 20px 0}
.stat{background:var(--surface);border:1px solid var(--cardbd);border-radius:14px;padding:14px}
.stat .k{font-size:9px;letter-spacing:1.2px;color:var(--muted);text-transform:uppercase;font-weight:600}
.stat .v{font-family:var(--disp);font-size:26px;color:var(--paper);margin-top:5px;line-height:1}
.stat .v small{font-size:12px;color:var(--muted)}
.stat .delta{font-size:10px;color:var(--green);margin-top:3px}
.jump{display:flex;flex-direction:column;gap:9px;padding:0 20px}
.jrow{display:flex;align-items:center;gap:13px;background:var(--surface);border:1px solid var(--cardbd);border-radius:14px;padding:14px;cursor:pointer}
.jrow .ji{width:34px;height:34px;border-radius:10px;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--gold-br)}
.jrow .jt{flex:1}.jrow .jt h4{font-size:13px;font-weight:600}.jrow .jt p{font-size:10px;color:var(--muted);margin-top:2px}
.jrow .ch{color:var(--muted);font-size:16px}

/* create (AI post) */
.body{padding:2px 18px 24px}
.flabel{font-size:9px;letter-spacing:2px;color:var(--gold);font-weight:700;text-transform:uppercase;margin:16px 4px 9px}
.chips{display:flex;gap:7px;flex-wrap:wrap}
.chip{font-size:11px;padding:8px 13px;border-radius:30px;border:1px solid var(--cardbd);background:var(--surface);color:var(--muted);font-weight:500;cursor:pointer}
.chip.on{border-color:var(--gold);color:#241a08;background:linear-gradient(180deg,var(--gold-br),var(--gold));font-weight:600}
.photo{margin-top:2px;border-radius:16px;border:1px dashed var(--hair);overflow:hidden;position:relative;height:170px;background:linear-gradient(180deg,rgba(0,0,0,.25),rgba(0,0,0,.55)),conic-gradient(from 200deg at 60% 40%,#3a3a40,#26262b,#42413a,#2c2b30,#3a3a40);cursor:pointer;display:flex;align-items:center;justify-content:center}
.photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.photo .cap{position:relative;z-index:2;font-size:11px;color:rgba(247,244,238,.85);background:rgba(0,0,0,.4);padding:6px 12px;border-radius:20px}
.photo input[type=file]{display:none}
.tinput{margin-top:10px;background:var(--surface);border:1px solid var(--cardbd);border-radius:14px;padding:13px 14px;font-size:16px;color:var(--paper);width:100%;font-family:var(--body)}
textarea.tinput{min-height:64px;resize:vertical}
.hint{font-size:10px;color:var(--muted);margin-top:6px;font-style:italic;font-family:var(--disp)}
.gen{margin-top:16px;width:100%;border:none;padding:15px;border-radius:30px;cursor:pointer;background:linear-gradient(180deg,var(--gold-br),var(--gold));color:#241a08;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;gap:9px}

/* generated post card */
.post{margin:0 4px;border-radius:20px;overflow:hidden;border:1px solid var(--hair);background:linear-gradient(165deg,var(--wine),var(--wine2) 58%,#1f0a0f);position:relative;padding:20px 18px 18px}
.post::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 80% 0%,rgba(194,162,90,.22),transparent 55%),repeating-linear-gradient(115deg,rgba(255,255,255,.022) 0 2px,transparent 2px 9px)}
.ribbon{position:absolute;top:14px;left:14px;font-size:8px;letter-spacing:2.2px;font-weight:700;color:#241a08;background:linear-gradient(180deg,var(--gold-br),var(--gold));padding:4px 10px;border-radius:20px;z-index:2}
.pbadge{position:absolute;top:12px;right:14px;width:58px;height:58px;border-radius:50%;background:var(--bg);border:1.5px solid var(--gold);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2}
.pbadge .c{font-size:7.5px;color:var(--gold-br);letter-spacing:.5px}.pbadge .v{font-family:var(--disp);font-size:17px;color:var(--paper);font-weight:600;line-height:1}
.pbadge.warn{border-color:var(--amber);border-style:dashed}.pbadge.warn .v{font-size:20px;color:var(--amber)}
.post .clean{display:flex;justify-content:center;margin:16px 0 12px;position:relative;z-index:2}
.post .clean img{max-height:150px;max-width:60%;object-fit:contain;filter:drop-shadow(0 12px 16px rgba(0,0,0,.55))}
.cbottle{width:42px;height:140px;position:relative;filter:drop-shadow(0 12px 16px rgba(0,0,0,.55))}
.cbottle .nk{position:absolute;top:0;left:50%;transform:translateX(-50%);width:14px;height:31px;background:linear-gradient(90deg,#0c0c0e,#2c2c33,#0c0c0e);border-radius:5px 5px 0 0}
.cbottle .bd{position:absolute;bottom:0;width:42px;height:113px;background:linear-gradient(90deg,#07070a,#3a3a44 45%,#0d0d10);border-radius:8px}
.cbottle .lb{position:absolute;bottom:24px;left:5px;width:32px;height:50px;background:linear-gradient(180deg,#efe9dc,#cfc6b2);border-radius:2px}
.cbottle .lb::before{content:"";position:absolute;top:8px;left:5px;right:5px;height:1px;background:var(--wine)}
.post .pe{position:relative;font-size:8px;letter-spacing:2.2px;color:var(--gold-br);font-weight:700;text-align:center;z-index:2}
.post h2{position:relative;font-family:var(--disp);font-weight:600;font-size:23px;color:var(--paper);text-align:center;line-height:1.05;margin-top:5px;z-index:2}
.post .bt{position:relative;font-size:11.5px;line-height:1.5;color:rgba(247,244,238,.82);text-align:center;margin-top:9px;padding:0 6px;z-index:2}
.okchip{display:flex;align-items:center;gap:6px;margin:13px auto 0;font-size:10px;color:var(--green);background:rgba(120,190,110,.1);border:1px solid rgba(120,190,110,.3);padding:6px 11px;border-radius:20px;width:fit-content}
.warnbox{margin:13px 4px 0;background:rgba(224,169,59,.1);border:1px solid rgba(224,169,59,.4);border-radius:12px;padding:12px 14px}
.warnbox .wh{font-size:11px;color:var(--amber);font-weight:600;display:flex;align-items:center;gap:7px}
.warnbox .wi{margin-top:8px;background:var(--bg);border:1px solid var(--hair);border-radius:10px;padding:10px 12px;font-size:16px;color:var(--paper);width:100%}

/* broadcast */
.audience{display:flex;flex-direction:column;gap:8px}
.aud{display:flex;align-items:center;gap:11px;background:var(--surface);border:1px solid var(--cardbd);border-radius:12px;padding:12px 14px;font-size:12.5px;color:var(--paper);cursor:pointer}
.aud .rd{width:18px;height:18px;border-radius:50%;border:1px solid var(--hair);flex-shrink:0}
.aud.on{border-color:var(--gold)}.aud.on .rd{border-color:var(--gold);background:radial-gradient(circle,var(--gold-br) 40%,transparent 45%)}
.aud .sm{font-size:10px;color:var(--muted);margin-top:2px}
.aud .opt{flex:1}
.toggles{display:flex;gap:8px;flex-wrap:wrap}
.tog{display:flex;align-items:center;gap:7px;font-size:11px;padding:8px 12px;border-radius:30px;border:1px solid var(--cardbd);background:var(--surface);color:var(--muted);font-weight:500;cursor:pointer}
.tog.on{border-color:var(--gold);color:var(--paper)}.tog .dot{width:8px;height:8px;border-radius:50%;background:#3a3a40}.tog.on .dot{background:var(--gold-br)}
.tasteopts{margin-top:8px}
.tasteopts select{width:100%}

/* prize draw */
.drawcard{margin:6px 20px 0;border-radius:18px;background:linear-gradient(160deg,#1d1d22,#100f12);border:1px solid rgba(194,162,90,.3);padding:22px;text-align:center;position:relative;overflow:hidden}
.drawcard::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 70% at 50% 0%,rgba(194,162,90,.16),transparent 55%)}
.drawcard .tr{position:relative;font-size:34px}
.drawcard h2{position:relative;font-family:var(--disp);font-size:24px;font-weight:600;margin-top:8px}
.drawcard .pz{position:relative;font-size:12px;color:var(--gold-br);margin-top:5px}
.drawcard .en{position:relative;font-size:11px;color:var(--muted);margin-top:12px}
.winner{position:relative;margin-top:16px;padding-top:16px;border-top:1px solid var(--hair)}
.winner .wl{font-size:9px;letter-spacing:2px;color:var(--gold);text-transform:uppercase;font-weight:700}
.winner .wn{font-family:var(--disp);font-size:26px;font-weight:600;margin-top:5px}
.winner .wm{font-size:11px;color:var(--muted);margin-top:3px}
.pastw{padding:0 20px 22px}
.pw{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--cardbd);font-size:12px}
.pw .mo{color:var(--muted)}.pw .nm{color:var(--paper)}

/* staff leaderboard */
.lead{padding:4px 20px 22px}
.lrow2{display:flex;align-items:center;gap:13px;padding:13px 0;border-bottom:1px solid var(--cardbd)}
.lrow2 .rk{width:26px;font-family:var(--disp);font-size:20px;color:var(--gold-br);text-align:center}
.lrow2 .nm{flex:1;font-size:13px;font-weight:600}
.lrow2 .ct{font-family:var(--disp);font-size:20px;color:var(--paper)}
.lrow2 .ct small{font-size:10px;color:var(--muted);font-family:var(--body)}
.lrow2.top{background:linear-gradient(90deg,rgba(194,162,90,.1),transparent);border-radius:12px;padding:13px 12px;border-bottom:none;margin-bottom:4px}

/* insights */
.ins{padding:4px 20px 22px}
.prog{background:var(--surface);border:1px solid var(--cardbd);border-radius:14px;padding:16px;margin-top:8px}
.prog .k{font-size:10px;letter-spacing:1.2px;color:var(--muted);text-transform:uppercase;font-weight:600}
.prog .v{font-family:var(--disp);font-size:24px;margin-top:5px}.prog .v small{font-size:13px;color:var(--muted)}
.bar{height:8px;border-radius:6px;background:var(--surface2);margin-top:10px;overflow:hidden}
.bar i{display:block;height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-br));border-radius:6px}
.zones{margin-top:8px}
.zone{display:flex;align-items:center;gap:10px;margin-top:11px}
.zone .zl{width:74px;font-size:11px;color:var(--paper)}
.zone .zb{flex:1;height:7px;border-radius:6px;background:var(--surface2);overflow:hidden}
.zone .zb i{display:block;height:100%;background:var(--gold-br)}
.zone .zv{font-size:11px;color:var(--muted);width:30px;text-align:right}
.kpi{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}
.kpi .b{background:var(--surface);border:1px solid var(--cardbd);border-radius:14px;padding:14px}
.kpi .b .k{font-size:9px;letter-spacing:1px;color:var(--muted);text-transform:uppercase;font-weight:600}
.kpi .b .v{font-family:var(--disp);font-size:24px;margin-top:5px}

/* members */
.mrow{display:flex;align-items:center;gap:12px;padding:13px 20px;border-bottom:1px solid var(--cardbd)}
.mrow .av{width:34px;height:34px;border-radius:50%;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-family:var(--disp);color:var(--gold-br);font-size:15px;flex-shrink:0}
.mrow .mi{flex:1}.mrow .mi h4{font-size:13px;font-weight:600}.mrow .mi p{font-size:10px;color:var(--muted);margin-top:2px}
.mrow .src{font-size:8px;letter-spacing:1px;color:var(--gold);border:1px solid var(--hair);padding:3px 8px;border-radius:20px;text-transform:uppercase}

/* suppliers */
.sup{display:flex;align-items:center;gap:12px;padding:13px 20px;border-bottom:1px solid var(--cardbd)}
.sup .si{flex:1}.sup .si h4{font-size:13px;font-weight:600}.sup .si p{font-size:10px;color:var(--muted);margin-top:2px}
.tier{font-size:8px;letter-spacing:1px;padding:4px 9px;border-radius:20px;font-weight:700;text-transform:uppercase;cursor:pointer}
.tier.f{background:rgba(176,141,87,.2);color:#cda86a;border:1px solid rgba(176,141,87,.4)}
.tier.d{background:rgba(170,170,180,.15);color:#c9c9d2;border:1px solid rgba(170,170,180,.35)}
.tier.p{background:linear-gradient(180deg,var(--gold-br),var(--gold));color:#241a08}

.empty{padding:40px 30px;text-align:center;color:var(--muted);font-style:italic;font-family:var(--disp);font-size:14px}
.sp{height:20px}

/* nav */
.nav{display:flex;justify-content:space-around;padding:11px 6px calc(16px + env(safe-area-inset-bottom));background:rgba(16,15,18,.94);backdrop-filter:saturate(160%) blur(12px);-webkit-backdrop-filter:saturate(160%) blur(12px);border-top:1px solid var(--hair);flex-shrink:0}
.nav.hidden{display:none}
.ni2{display:flex;flex-direction:column;align-items:center;gap:4px;font-size:8.5px;letter-spacing:.4px;color:var(--muted);font-weight:600;cursor:pointer}
.ni2 .g{font-size:16px}.ni2.on{color:var(--gold-br)}

/* ---- Manage catalogue (wines / events / boxes) ---- */
.frow{display:flex;gap:10px}
.frow>div{flex:1;min-width:0}
.cform{margin-top:4px}
.crow{display:flex;align-items:center;gap:12px;padding:13px 14px;background:var(--surface);border:1px solid var(--cardbd);border-radius:13px;margin-bottom:9px;cursor:pointer;touch-action:manipulation}
.crow:active{opacity:.7}
.crow .ci{flex:1;min-width:0}
.crow .ci h4{font-size:13.5px;color:var(--paper);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.crow .ci p{font-size:11px;color:var(--muted);margin:3px 0 0}
.crow .ch{color:var(--gold-br);font-size:18px;flex-shrink:0}
.btn.ghost.danger{border-color:#5a2020;color:#c06060}
