/* ================================================================
   Alchive v5 — Dark Alchemy · App-Store Ready
   ================================================================ */
:root {
  --bg:#070608; --s1:#0D0C13; --s2:#131220; --s3:#19182A; --s4:#1F1E30;
  --gold:#C49A2E; --gold-hi:#E0B84A; --gold-lo:#8A6B1D; --gold-dim:#7A5818;
  --cream:#EDE8DF; --c2:#A8A199; --c3:#7C766E; --c4:#2E2C28;
  --b1:rgba(237,232,223,.055); --b2:rgba(237,232,223,.11); --b3:rgba(237,232,223,.2);
  --ga:rgba(196,154,46,.09); --gb:rgba(196,154,46,.2); --gc:rgba(196,154,46,.04);
  --ok:#52C07A; --err:#E05252; --info:#5B8DEF;
  --ff-d:'Playfair Display',Georgia,serif;
  --ff-b:'DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;
  --ff-m:'Space Mono','Courier New',monospace;
  --nav:68px; --hdr:54px;
  --ease:cubic-bezier(.4,0,.2,1); --spring:cubic-bezier(.34,1.56,.64,1);
  --slide:cubic-bezier(.32,.72,0,1);
}

/* ── Light Theme ── */
[data-theme="light"] {
  --bg:#F7F5F0; --s1:#FFFFFF; --s2:#F0EDE6; --s3:#E8E4DB; --s4:#E0DBD0;
  --gold:#9A7518; --gold-hi:#B8902E; --gold-lo:#7A5C12; --gold-dim:#6A4E10;
  --cream:#1A1814; --c2:#5C564D; --c3:#85807A; --c4:#D8D3C8;
  --b1:rgba(26,24,20,.08); --b2:rgba(26,24,20,.14); --b3:rgba(26,24,20,.24);
  --ga:rgba(154,117,24,.10); --gb:rgba(154,117,24,.28); --gc:rgba(154,117,24,.05);
}
[data-theme="light"] #grain{opacity:.015}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--ff-b);background:var(--bg);color:var(--cream);-webkit-font-smoothing:antialiased;overflow:hidden;height:100dvh}

/* Grain */
#grain{position:fixed;inset:0;pointer-events:none;z-index:9990;opacity:.022;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px}

/* Shell */
#app{max-width:440px;margin:0 auto;height:100dvh;display:flex;flex-direction:column;overflow:hidden;position:relative;background:var(--bg)}
@media(min-width:440px){#app{border-left:1px solid var(--b1);border-right:1px solid var(--b1)}}

/* ── Onboarding ── */
.onboarding{position:fixed;inset:0;z-index:9000;display:flex;align-items:flex-end;justify-content:center;background:var(--bg);transition:opacity .55s var(--ease),transform .55s var(--ease)}
.onboarding.gone{opacity:0;transform:scale(.96);pointer-events:none}
.ob-radial{position:absolute;inset:0;background:radial-gradient(ellipse 160% 70% at 50% -5%,rgba(196,154,46,.08) 0%,transparent 65%);pointer-events:none}
.ob-inner{position:relative;width:100%;max-width:440px;padding:40px 30px 56px;padding-bottom:max(56px,calc(env(safe-area-inset-bottom,0px) + 32px))}
.ob-logo-wrap{margin-bottom:28px}
.ob-title{font-family:var(--ff-d);font-size:48px;font-weight:700;letter-spacing:-1.5px;line-height:1;
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-hi) 45%,var(--gold) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:4px}
.ob-dot{-webkit-text-fill-color:var(--c4);color:var(--c4)}
.ob-tagline{font-family:var(--ff-m);font-size:10px;letter-spacing:.2em;color:var(--gold);text-transform:uppercase;opacity:.7;margin-bottom:20px}
.ob-desc{font-size:15px;font-weight:300;line-height:1.85;color:var(--c2);margin-bottom:30px}
.ob-feats{display:flex;flex-direction:column;gap:13px;margin-bottom:40px}
.ob-feat{display:flex;align-items:center;gap:14px;font-size:14px;font-weight:300;color:var(--c2)}
.ob-feat-dot{width:5px;height:5px;border-radius:50%;background:var(--gold);flex-shrink:0}
.ob-btn{width:100%;height:56px;background:var(--gold);border:none;border-radius:16px;color:#07060A;
  font-size:15px;font-weight:500;font-family:var(--ff-b);letter-spacing:.03em;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:10px;
  position:relative;overflow:hidden;transition:opacity .15s,transform .1s}
.ob-btn::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.18),transparent 55%)}
.ob-btn:hover{opacity:.9}.ob-btn:active{transform:scale(.98)}
.ob-legal{text-align:center;font-size:11px;font-weight:300;color:var(--c4);margin-top:16px}

/* ── Header ── */
.hdr{height:var(--hdr);flex-shrink:0;z-index:30}
.hdr-inner{height:calc(var(--hdr) - 1px);padding:0 18px;display:flex;align-items:center;gap:10px}
.logo{flex:1;display:flex;align-items:baseline}
.logo-t{font-family:var(--ff-d);font-size:26px;font-weight:700;letter-spacing:-.5px;
  background:linear-gradient(135deg,var(--gold),var(--gold-hi) 50%,var(--gold));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.logo-d{font-family:var(--ff-d);font-size:26px;font-weight:700;color:var(--c4);-webkit-text-fill-color:var(--c4)}
.hdr-actions{display:flex;gap:6px}
.hdr-btn{width:38px;height:38px;background:var(--ga);border:1px solid var(--gb);border-radius:10px;
  color:var(--gold);display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:background .15s,transform .1s;flex-shrink:0}
.hdr-btn:hover{background:rgba(196,154,46,.17)}.hdr-btn:active{transform:scale(.93)}
.hdr-line{height:1px;background:linear-gradient(90deg,transparent,var(--b2) 20%,var(--b2) 80%,transparent)}

/* ── Main / Views ── */
.app-main{flex:1;overflow:hidden;position:relative}
.view{position:absolute;inset:0;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;
  -webkit-overflow-scrolling:touch;padding-bottom:28px;
  opacity:0;pointer-events:none;transform:translateX(30px);
  transition:opacity .28s var(--ease),transform .28s var(--ease)}
.view::-webkit-scrollbar{display:none}
.view.active{opacity:1;pointer-events:auto;transform:translateX(0)}
.view.exit{opacity:0;transform:translateX(-30px)}

/* ── Hero ── */
.hero{padding:24px 18px 14px}
.eyebrow{font-family:var(--ff-m);font-size:10px;letter-spacing:.2em;color:var(--gold);text-transform:uppercase;opacity:.72;margin-bottom:10px}
.hero-h{font-family:var(--ff-d);font-size:40px;font-weight:400;line-height:1.07;letter-spacing:-.5px;color:var(--cream)}
.hero-h em{font-style:italic;color:var(--gold-hi)}

/* ── Search ── */
.search-wrap{padding:0 18px 10px}
.sfield{position:relative;display:flex;align-items:center;background:var(--s1);border:1px solid var(--b2);border-radius:13px;transition:border-color .2s,box-shadow .2s}
.sfield:focus-within{border-color:rgba(196,154,46,.42);box-shadow:0 0 0 3px rgba(196,154,46,.07)}
.s-ico{position:absolute;left:14px;color:var(--c3);pointer-events:none}
.sfield input{flex:1;height:50px;padding:0 42px;background:transparent;border:none;outline:none;
  color:var(--cream);font-family:var(--ff-b);font-size:14px;font-weight:300;-webkit-appearance:none}
.sfield input::placeholder{color:var(--c4)}
.s-clear{position:absolute;right:12px;width:24px;height:24px;background:var(--s2);border:1px solid var(--b1);
  border-radius:50%;color:var(--c3);font-size:10px;cursor:pointer;display:none;align-items:center;justify-content:center}
.s-clear:hover{background:var(--s3);color:var(--cream)}

/* ── Chips ── */
.chips-row{display:flex;gap:7px;padding:2px 18px 14px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.chips-row::-webkit-scrollbar{display:none}
.chip{flex-shrink:0;font-family:var(--ff-m);font-size:10px;letter-spacing:.06em;white-space:nowrap;
  background:var(--s1);border:1px solid var(--b2);border-radius:20px;color:var(--c2);
  padding:6px 14px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}
.chip.on{background:var(--ga);border-color:var(--gb);color:var(--gold)}
.chip:hover:not(.on){background:var(--s2);color:var(--cream)}

/* ── List ── */
.list-meta{padding:0 18px 10px}
.list-count{font-family:var(--ff-m);font-size:10px;letter-spacing:.12em;color:var(--c3);text-transform:uppercase}
.gin-list{padding:0 18px}
.gin-row{display:flex;align-items:center;gap:13px;padding:13px 0;border-bottom:1px solid var(--b1);
  cursor:pointer;position:relative;transition:padding-left .2s var(--ease);-webkit-tap-highlight-color:transparent}
.gin-row:last-child{border-bottom:none}
.gin-row::before{content:'';position:absolute;left:-18px;top:0;bottom:0;width:2px;
  background:linear-gradient(to bottom,var(--gold-lo),var(--gold));opacity:0;transition:opacity .18s}
.gin-row:hover{padding-left:7px}.gin-row:hover::before{opacity:1}
.row-ico{width:46px;height:46px;flex-shrink:0;border-radius:9px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.row-ico svg,.row-ico img{display:block;border-radius:9px}
.gin-row:hover .row-ico{transform:scale(1.04);transition:transform .18s}
.row-info{flex:1;min-width:0}
.row-name{font-family:var(--ff-d);font-size:16px;color:var(--cream);margin-bottom:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.1px}
.row-sub{font-size:11px;font-weight:300;color:var(--c2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.row-sub .sep{color:var(--c3);margin:0 3px}
.row-abv{font-family:var(--ff-m);font-size:10px;color:var(--gold);flex-shrink:0;background:var(--ga);border:1px solid var(--gb);padding:4px 9px;border-radius:6px}
.row-nores{text-align:center;padding:60px 16px;color:var(--c3);font-size:14px;font-weight:300;line-height:1.9}

/* ── View layout ── */
.vtop{padding:26px 18px 18px;border-bottom:1px solid var(--b1)}
.vtitle{font-family:var(--ff-d);font-size:34px;font-weight:400;letter-spacing:-.3px;color:var(--cream);margin:8px 0 5px}
.vsub{font-size:13px;font-weight:300;color:var(--c2)}

/* ── Collection Grid ── */
.coll-grid{padding:14px 18px;display:grid;grid-template-columns:1fr 1fr;gap:9px}
.coll-card{background:var(--s1);border:1px solid var(--b1);border-radius:16px;padding:14px 13px;cursor:pointer;
  transition:border-color .2s,background .2s;position:relative;overflow:hidden;-webkit-tap-highlight-color:transparent}
.coll-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--gold-lo),var(--gold-hi));opacity:0;transition:opacity .22s}
.coll-card:hover{border-color:var(--b2);background:var(--s2)}.coll-card:hover::after{opacity:1}
.coll-emoji{display:block;margin-bottom:8px;line-height:0}
.coll-emoji svg,.coll-emoji img{display:inline-block;border-radius:10px}
.coll-style{font-family:var(--ff-m);font-size:10px;letter-spacing:.08em;color:var(--gold);text-transform:uppercase;display:block;margin-bottom:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.coll-name{font-family:var(--ff-d);font-size:14px;color:var(--cream);line-height:1.25;margin-bottom:3px}
.coll-brand{font-size:11px;font-weight:300;color:var(--c2);margin-bottom:8px}
.coll-stars{font-size:13px;color:var(--gold);letter-spacing:1px}
.coll-badge{position:absolute;top:10px;right:10px;font-family:var(--ff-m);font-size:10.5px;background:var(--s3);color:var(--c2);padding:2px 7px;border-radius:20px;border:1px solid var(--b1)}

/* ── Stats ── */
.stats-pad{padding:14px 18px}
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:22px}
.stat-card{background:var(--s1);border:1px solid var(--b1);border-radius:14px;padding:14px 13px}
.stat-lbl{font-family:var(--ff-m);font-size:10.5px;letter-spacing:.14em;color:var(--c3);text-transform:uppercase;display:block;margin-bottom:7px}
.stat-val{font-family:var(--ff-d);font-size:30px;font-weight:400;color:var(--gold);line-height:1}
.stat-sup{font-size:11px;font-weight:300;color:var(--c3);margin-top:2px}
.sec-label{font-family:var(--ff-m);font-size:10px;letter-spacing:.18em;color:var(--c3);text-transform:uppercase;margin-bottom:12px}
.sbar-row{display:flex;align-items:center;gap:9px;margin-bottom:8px}
.sbar-lbl{font-size:12px;font-weight:300;color:var(--c2);width:118px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sbar-track{flex:1;height:4px;background:var(--s3);border-radius:2px;overflow:hidden}
.sbar-fill{height:100%;background:var(--gold);border-radius:2px;width:0;transition:width .8s var(--ease)}
.sbar-n{font-family:var(--ff-m);font-size:10px;color:var(--c3);width:18px;text-align:right;flex-shrink:0}
.log-group{margin-bottom:22px}
.log-date{font-family:var(--ff-m);font-size:10.5px;letter-spacing:.14em;color:var(--c3);text-transform:uppercase;display:flex;align-items:center;gap:8px;margin-bottom:8px}
.log-date::after{content:'';flex:1;height:1px;background:var(--b1)}
.log-item{display:flex;align-items:center;gap:11px;padding:11px 13px;background:var(--s1);border:1px solid var(--b1);border-radius:10px;margin-bottom:5px;cursor:pointer;transition:border-color .2s;-webkit-tap-highlight-color:transparent}
.log-item:hover{border-color:var(--b2)}
.log-pip{width:7px;height:7px;border-radius:50%;background:var(--gold);flex-shrink:0}
.log-name{font-family:var(--ff-d);font-size:14px;color:var(--cream);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:2px}
.log-meta{font-size:11px;font-weight:300;color:var(--c2)}
.log-time{font-family:var(--ff-m);font-size:10px;color:var(--c3);flex-shrink:0}

/* ── Profile ── */
.profile-hero{padding:30px 18px 24px;background:linear-gradient(to bottom,var(--s1),transparent);border-bottom:1px solid var(--b1)}
.profile-avatar{width:64px;height:64px;border-radius:20px;background:var(--s2);border:1px solid var(--gb);
  display:flex;align-items:center;justify-content:center;font-size:28px;margin-bottom:16px}
.profile-name{font-family:var(--ff-d);font-size:28px;font-weight:400;color:var(--cream);letter-spacing:-.3px;margin-bottom:3px}
.profile-level{display:inline-flex;align-items:center;gap:7px;background:var(--ga);border:1px solid var(--gb);border-radius:20px;padding:4px 12px;margin-bottom:18px}
.level-dot{width:6px;height:6px;border-radius:50%;background:var(--gold)}
.level-txt{font-family:var(--ff-m);font-size:10px;letter-spacing:.08em;color:var(--gold);text-transform:uppercase}
.profile-bio{font-size:13px;font-weight:300;color:var(--c2);line-height:1.7}
.profile-pad{padding:18px 18px}
.flavor-radar-profile{display:flex;justify-content:center;margin-bottom:20px}
.pref-label{font-family:var(--ff-m);font-size:10.5px;letter-spacing:.18em;color:var(--c3);text-transform:uppercase;margin-bottom:12px}
.pref-row{display:flex;align-items:center;gap:9px;margin-bottom:9px}
.pref-name{font-size:12px;font-weight:300;color:var(--c2);width:80px;flex-shrink:0}
.pref-track{flex:1;height:4px;background:var(--s3);border-radius:2px;overflow:hidden}
.pref-fill{height:100%;border-radius:2px;width:0;transition:width .9s var(--ease)}
.pref-fill.sweet{background:#D4875C}
.pref-fill.acid{background:#7BC8A4}
.pref-fill.bitter{background:#5B8DEF}
.pref-fill.spice{background:#E0915A}
.pref-fill.fresh{background:#6CC98D}
.pref-pct{font-family:var(--ff-m);font-size:10px;color:var(--c3);width:28px;text-align:right;flex-shrink:0}
.badges-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:4px}
.badge-card{background:var(--s1);border:1px solid var(--b1);border-radius:14px;padding:14px 10px;text-align:center}
.badge-icon{font-size:26px;margin-bottom:7px}
.badge-name{font-size:11px;font-weight:400;color:var(--cream);margin-bottom:2px}
.badge-desc{font-size:10px;font-weight:300;color:var(--c3);line-height:1.4}
.badge-card.locked{opacity:.35}
.profile-div{height:1px;background:linear-gradient(90deg,var(--b2),transparent 70%);margin:20px 0}

/* ── Empty ── */
.empty{display:flex;flex-direction:column;align-items:center;padding:60px 24px;color:var(--c3);text-align:center;gap:12px}
.empty .ei{font-size:44px;opacity:.42}
.empty p{font-size:14px;font-weight:300;line-height:1.8}

/* ── Nav ── */
.bnav{height:var(--nav);flex-shrink:0;display:flex;padding:0 6px;padding-bottom:env(safe-area-inset-bottom,0);
  position:relative;background:var(--bg)}
.bnav::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--b2) 20%,var(--b2) 80%,transparent)}
.nb{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;
  border:none;background:none;color:var(--c3);cursor:pointer;font-family:var(--ff-b);font-size:10px;
  font-weight:400;letter-spacing:.04em;transition:color .18s;-webkit-tap-highlight-color:transparent;padding:6px 0}
.nb.active{color:var(--gold)}

/* ── Scanner ── */
.scan-modal{position:fixed;inset:0;z-index:8000;background:rgba(5,4,8,.95);display:flex;
  align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s var(--ease)}
.scan-modal.open{opacity:1;pointer-events:auto}
.scan-sheet{width:100%;max-width:440px;background:var(--s1);border-radius:24px 24px 0 0;border-top:1px solid var(--b2);
  padding:18px 18px 36px;padding-bottom:max(36px,calc(env(safe-area-inset-bottom,0px) + 20px))}
.scan-bar-handle{width:38px;height:4px;background:var(--b2);border-radius:2px;margin:0 auto 16px}
.scan-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.scan-title{font-family:var(--ff-d);font-size:20px;color:var(--cream)}
.scan-vp{position:relative;width:100%;aspect-ratio:1;border-radius:16px;overflow:hidden;background:#000;margin-bottom:12px}
#scanVideo{width:100%;height:100%;object-fit:cover}
.scan-frame-ui{position:absolute;inset:0;pointer-events:none}
.sf-corner{position:absolute;width:22px;height:22px;border-color:var(--gold);border-style:solid}
.sf-corner.tl{top:14px;left:14px;border-width:2px 0 0 2px;border-radius:4px 0 0 0}
.sf-corner.tr{top:14px;right:14px;border-width:2px 2px 0 0;border-radius:0 4px 0 0}
.sf-corner.bl{bottom:14px;left:14px;border-width:0 0 2px 2px;border-radius:0 0 0 4px}
.sf-corner.br{bottom:14px;right:14px;border-width:0 2px 2px 0;border-radius:0 0 4px 0}
.sf-scanline{position:absolute;left:18px;right:18px;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold) 30%,var(--gold) 70%,transparent);
  animation:scan 2s ease-in-out infinite;top:50%;opacity:.85}
@keyframes scan{0%,100%{transform:translateY(-56px);opacity:.3}50%{transform:translateY(56px);opacity:1}}
.scan-hint{position:absolute;bottom:12px;left:0;right:0;text-align:center;font-size:12px;font-weight:300;color:rgba(237,232,223,.5)}
.scan-status{font-family:var(--ff-m);font-size:11px;color:var(--gold);text-align:center;min-height:20px;margin-bottom:14px;letter-spacing:.06em}
.scan-manual-label{font-size:12px;font-weight:300;color:var(--c3);margin-bottom:8px}
.scan-manual-row{display:flex;gap:8px}
.scan-manual-row input{flex:1;height:44px;padding:0 14px;background:var(--s2);border:1px solid var(--b2);border-radius:10px;color:var(--cream);font-family:var(--ff-b);font-size:14px;outline:none;-webkit-appearance:none;transition:border-color .2s}
.scan-manual-row input:focus{border-color:rgba(196,154,46,.4)}
.scan-manual-row input::placeholder{color:var(--c4)}
.scan-manual-row button{height:44px;padding:0 18px;background:var(--gold);border:none;border-radius:10px;color:#07060A;font-size:13px;font-weight:500;font-family:var(--ff-b);cursor:pointer;white-space:nowrap}

/* ── Toast ── */
.toast{position:fixed;bottom:calc(var(--nav) + 10px);left:50%;transform:translateX(-50%) translateY(16px);
  max-width:340px;width:calc(100% - 36px);background:var(--s2);border:1px solid var(--b2);border-radius:14px;
  padding:13px 18px;font-size:13px;font-weight:300;color:var(--cream);text-align:center;z-index:7000;
  opacity:0;transition:opacity .25s,transform .25s var(--spring);pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.ok{border-color:rgba(82,192,122,.35);color:var(--ok)}
.toast.err{border-color:rgba(224,82,82,.35);color:var(--err)}

/* ── Overlay ── */
.overlay{position:fixed;inset:0;background:transparent;z-index:100;pointer-events:none;
  transition:background .3s,-webkit-backdrop-filter .3s,backdrop-filter .3s}
.overlay.on{background:rgba(4,3,7,.78);pointer-events:auto;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}

/* ── Detail Sheet ── */
.detail-sheet{position:fixed;bottom:0;left:50%;transform:translateX(-50%) translateY(108%);
  width:100%;max-width:440px;max-height:94dvh;background:var(--s1);
  border-radius:24px 24px 0 0;border-top:1px solid var(--b2);border-left:1px solid var(--b1);border-right:1px solid var(--b1);
  z-index:101;display:flex;flex-direction:column;transition:transform .44s var(--slide)}
.detail-sheet.open{transform:translateX(-50%) translateY(0)}
.ds-handle{width:38px;height:4px;background:var(--b2);border-radius:2px;margin:12px auto 0;flex-shrink:0}
.sheet-close-btn{position:absolute;top:14px;right:14px;width:32px;height:32px;background:var(--s2);border:1px solid var(--b2);
  border-radius:50%;color:var(--c2);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;transition:background .15s}
.sheet-close-btn:hover{background:var(--s3);color:var(--cream)}
.ds-scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:22px 18px 80px}
.ds-scroll::-webkit-scrollbar{display:none}

/* ── Detail Content ── */
.dc-toprow{display:flex;align-items:center;gap:8px;margin-bottom:13px}
.dc-style-tag{font-family:var(--ff-m);font-size:10.5px;letter-spacing:.12em;color:var(--gold);text-transform:uppercase;background:var(--ga);border:1px solid var(--gb);padding:3px 10px;border-radius:20px}
.dc-flag{font-family:var(--ff-m);font-size:10px;color:var(--c3)}
.dc-name{font-family:var(--ff-d);font-size:32px;font-weight:400;font-style:italic;line-height:1.07;letter-spacing:-.3px;color:var(--cream);margin-bottom:4px}
.dc-sub{font-size:13px;font-weight:300;color:var(--c2);margin-bottom:18px}
.dc-statrow{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:20px}
.dc-stat{background:var(--s2);border:1px solid var(--b1);border-radius:9px;padding:8px 12px}
.dc-stat-l{font-family:var(--ff-m);font-size:10px;letter-spacing:.16em;color:var(--c3);text-transform:uppercase;display:block;margin-bottom:3px}
.dc-stat-v{font-family:var(--ff-m);font-size:15px;color:var(--gold)}
.dc-div{height:1px;background:linear-gradient(90deg,var(--b2),transparent 70%);margin:18px 0}
.dc-sec{font-family:var(--ff-m);font-size:10.5px;letter-spacing:.2em;color:var(--c3);text-transform:uppercase;margin-bottom:12px}
.dc-desc{font-size:14px;font-weight:300;line-height:1.9;color:var(--c2)}
.radar-center{display:flex;justify-content:center;padding:2px 0}
.bots{display:flex;flex-wrap:wrap;gap:7px}
.bot{font-size:12px;font-weight:300;background:var(--s2);color:var(--c2);border:1px solid var(--b2);border-radius:20px;padding:5px 12px;transition:border-color .15s,color .15s}
.bot:hover{border-color:var(--gb);color:var(--cream)}
/* Cocktail suggestions */
.cocktail-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}
.cocktail-row::-webkit-scrollbar{display:none}
.cocktail-card{flex-shrink:0;background:var(--s2);border:1px solid var(--b2);border-radius:12px;padding:12px 14px;width:130px;cursor:default}
.cc-name{font-family:var(--ff-d);font-size:14px;color:var(--cream);margin-bottom:4px}
.cc-ratio{font-family:var(--ff-m);font-size:12px;letter-spacing:.06em;color:var(--c2);line-height:1.6}
/* Similar gins */
.similar-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}
.similar-row::-webkit-scrollbar{display:none}
.sim-card{flex-shrink:0;background:var(--s2);border:1px solid var(--b1);border-radius:12px;padding:11px 13px;width:120px;cursor:pointer;transition:border-color .18s}
.sim-card:hover{border-color:var(--gb)}
.sim-emoji{display:block;margin-bottom:6px;line-height:0}
.sim-emoji svg,.sim-emoji img{display:inline-block;border-radius:8px}
.sim-name{font-family:var(--ff-d);font-size:13px;color:var(--cream);line-height:1.25;margin-bottom:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sim-style{font-size:10px;font-weight:300;color:var(--c2)}
/* Rating */
.gen-row{display:flex;align-items:baseline;gap:9px}
.gen-stars{font-size:17px;color:var(--gold);letter-spacing:2px}
.gen-lbl{font-family:var(--ff-m);font-size:11px;color:var(--c2)}
.user-stars-row{display:flex;align-items:center;gap:1px}
.star{font-size:28px;color:var(--s4);cursor:pointer;transition:color .12s,transform .15s var(--spring);padding:2px 3px;line-height:1;-webkit-tap-highlight-color:transparent;border:none;background:none}
.star.on{color:var(--gold)}.star:hover{transform:scale(1.22);color:var(--gold-hi)}
.rating-txt{margin-left:10px;font-family:var(--ff-m);font-size:11px;color:var(--c2);min-width:80px}
.note-ta{width:100%;min-height:88px;background:var(--s2);border:1px solid var(--b2);border-radius:12px;
  padding:12px 14px;font-size:14px;font-family:var(--ff-b);font-weight:300;color:var(--cream);line-height:1.75;resize:vertical;outline:none;transition:border-color .2s;-webkit-appearance:none}
.note-ta:focus{border-color:rgba(196,154,46,.38)}.note-ta::placeholder{color:var(--c4)}
.note-footer{display:flex;align-items:center;gap:10px;margin-top:9px;flex-wrap:wrap}
.btn-save{padding:9px 18px;background:var(--ga);border:1px solid var(--gb);border-radius:8px;color:var(--gold);font-size:13px;font-family:var(--ff-b);font-weight:400;cursor:pointer;transition:background .15s}
.btn-save:hover{background:rgba(196,154,46,.18)}
.saved-flash{font-family:var(--ff-m);font-size:11px;color:var(--ok);opacity:0;transition:opacity .2s}
.saved-flash.on{opacity:1}
.note-ts{margin-left:auto;font-size:11px;font-weight:300;color:var(--c3)}
.tags-wrap{display:flex;flex-wrap:wrap;gap:7px}
.tag{font-size:11px;font-weight:300;background:var(--s2);color:var(--c3);border:1px solid var(--b1);border-radius:20px;padding:3px 10px}
.btn-drink{width:100%;padding:16px;background:var(--gold);border:none;border-radius:14px;color:#070509;
  font-size:15px;font-weight:500;font-family:var(--ff-b);letter-spacing:.02em;cursor:pointer;
  transition:opacity .2s,transform .1s;display:flex;align-items:center;justify-content:center;gap:9px;
  position:relative;overflow:hidden;-webkit-tap-highlight-color:transparent}
.btn-drink::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.16),transparent 55%)}
.btn-drink:hover{opacity:.9}.btn-drink:active{transform:scale(.98)}
.btn-drink.done{background:var(--s2);color:var(--gold);border:1px solid var(--gb)}

/* ── Scanner Tabs & Label Mode (v2 API) ── */
.scan-tabs{display:flex;gap:6px;margin-bottom:14px;background:var(--s2);border:1px solid var(--b1);border-radius:12px;padding:4px}
.scan-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;height:38px;border:none;background:none;
  color:var(--c2);font-family:var(--ff-b);font-size:13px;font-weight:400;cursor:pointer;border-radius:9px;transition:background .18s,color .18s}
.scan-tab.on{background:var(--ga);color:var(--gold)}
.label-frame-ui{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  height:86%;aspect-ratio:10/16;border:2px dashed rgba(196,154,46,.5);border-radius:16px;
  display:flex;align-items:flex-end;justify-content:center;padding-bottom:14px;pointer-events:none}
.lf-guide{font-size:12px;font-weight:300;color:rgba(237,232,223,.7);text-align:center;line-height:1.6;
  background:rgba(7,6,8,.55);padding:8px 14px;border-radius:10px}
.btn-capture{width:100%;height:52px;background:var(--gold);border:none;border-radius:13px;color:#070509;
  font-size:15px;font-weight:500;font-family:var(--ff-b);letter-spacing:.02em;cursor:pointer;margin-bottom:14px;
  display:flex;align-items:center;justify-content:center;gap:9px;position:relative;overflow:hidden;
  transition:opacity .2s,transform .1s;-webkit-tap-highlight-color:transparent}
.btn-capture::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.16),transparent 55%)}
.btn-capture:active{transform:scale(.98)}
.btn-capture:disabled{opacity:.5;cursor:wait}
.recognize-result{background:var(--s2);border:1px solid var(--gb);border-radius:12px;padding:14px;margin-bottom:14px}
.rr-detected{font-family:var(--ff-m);font-size:11px;color:var(--c2);margin-bottom:6px}
.rr-name{font-family:var(--ff-d);font-size:18px;color:var(--cream);font-style:italic}

/* ════════════════════════════════════════════
   P1-A: Age Gate / Settings / Sort / Theme
   ════════════════════════════════════════════ */

/* ── Age Gate ── */
.age-gate{position:fixed;inset:0;z-index:1000;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:32px}
.ag-inner{max-width:380px;text-align:center}
.ag-title{font-family:var(--ff-d);font-size:26px;color:var(--cream);margin:18px 0 14px;letter-spacing:.01em}
.ag-desc{font-size:15px;line-height:1.85;color:var(--c2);margin-bottom:30px}
.ag-btns{display:flex;flex-direction:column;gap:11px;margin-bottom:24px}
.ag-yes{height:54px;background:var(--gold);border:none;border-radius:13px;color:#070509;font-size:16px;font-weight:600;font-family:var(--ff-b);cursor:pointer;-webkit-tap-highlight-color:transparent}
.ag-no{height:50px;background:none;border:1px solid var(--b2);border-radius:13px;color:var(--c2);font-size:15px;font-family:var(--ff-b);cursor:pointer;-webkit-tap-highlight-color:transparent}
.ag-note{font-size:12px;line-height:1.7;color:var(--c3)}

/* ── Settings ── */
.settings-pad{padding:0 20px 40px}
.set-group-label{font-family:var(--ff-m);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--c2);margin:24px 0 10px;padding-left:4px}
.set-card{background:var(--s1);border:1px solid var(--b1);border-radius:14px;overflow:hidden}
.set-row{display:flex;align-items:center;gap:12px;padding:15px 16px;border-bottom:1px solid var(--b1);cursor:pointer;text-decoration:none;-webkit-tap-highlight-color:transparent;transition:background .15s}
.set-row:last-child{border-bottom:none}
.set-row:active{background:var(--s2)}
.set-row-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.set-row-title{font-size:15px;color:var(--cream);font-weight:400}
.set-row-sub{font-size:12.5px;color:var(--c2);line-height:1.4}
.set-chevron{color:var(--c3);flex-shrink:0}
.set-version{text-align:center;font-family:var(--ff-m);font-size:11px;color:var(--c3);margin-top:28px}
.set-caution{text-align:center;font-size:11.5px;color:var(--c3);line-height:1.7;margin-top:10px}

/* ── Sort button ── */
.list-meta{display:flex;align-items:center;justify-content:space-between}
.sort-btn{display:flex;align-items:center;gap:6px;height:32px;padding:0 12px;background:var(--s1);border:1px solid var(--b1);border-radius:9px;color:var(--c2);font-size:12.5px;font-family:var(--ff-b);cursor:pointer;-webkit-tap-highlight-color:transparent}
.sort-btn:active{background:var(--s2)}

/* ── Mini sheets (sort / theme) ── */
.mini-sheet{position:fixed;left:0;right:0;bottom:0;z-index:200;background:var(--s1);border-top:1px solid var(--b2);border-radius:22px 22px 0 0;padding:8px 16px calc(20px + env(safe-area-inset-bottom));transform:translateY(110%);transition:transform .3s cubic-bezier(.32,.72,0,1);max-width:480px;margin:0 auto}
.mini-sheet.open{transform:translateY(0)}
.ms-handle{width:38px;height:4px;background:var(--b2);border-radius:2px;margin:8px auto 14px}
.ms-title{font-family:var(--ff-m);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--c2);text-align:center;margin-bottom:12px}
.ms-opt{display:block;width:100%;height:50px;background:none;border:none;border-radius:11px;color:var(--cream);font-size:15px;font-family:var(--ff-b);text-align:left;padding:0 16px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s}
.ms-opt:active{background:var(--s2)}
.ms-opt.on{color:var(--gold);background:var(--ga)}
.ms-opt.on::after{content:'✓';float:right}

/* ── Delete UI (journal) ── */
.log-item{position:relative}
.log-del-hint{font-size:11px;color:var(--c3);text-align:center;padding:8px;opacity:.7}
.log-item.deleting{animation:logOut .3s ease forwards}
@keyframes logOut{to{opacity:0;transform:translateX(-30px);height:0;padding:0;margin:0}}
.toast .toast-undo{margin-left:14px;color:var(--gold);font-weight:600;cursor:pointer;text-decoration:underline}

/* ── Photo adoption prompt ── */
.adopt-prompt{background:var(--s2);border:1px solid var(--gb);border-radius:13px;padding:16px;text-align:center}
.adopt-q{font-family:var(--ff-d);font-size:17px;color:var(--gold);margin-bottom:8px}
.adopt-sub{font-size:13px;color:var(--c2);line-height:1.7;margin-bottom:14px}
.adopt-btns{display:flex;gap:9px}
.adopt-yes{flex:1;height:44px;background:var(--gold);border:none;border-radius:11px;color:#070509;font-size:14px;font-weight:600;font-family:var(--ff-b);cursor:pointer}
.adopt-no{flex:1;height:44px;background:none;border:1px solid var(--b2);border-radius:11px;color:var(--c2);font-size:14px;font-family:var(--ff-b);cursor:pointer}
