@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&family=Jost:wght@300;400;500&family=Playfair+Display:ital,wght@0,400;0,700;1,400;1,700&family=Outfit:wght@300;400;600;700&family=DM+Serif+Display:ital@0;1&family=Dancing+Script:wght@600;700&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);min-height:100vh;overflow-x:hidden;transition:background .4s,color .4s}
#app{min-height:100vh;background:var(--app-bg)}
button{-webkit-tap-highlight-color:transparent;touch-action:manipulation;font-family:var(--font-ui)}

/* ═══════════════════════════════════════════════════════
   THEME TOKENS — each theme sets these on :root or [data-theme]
   ═══════════════════════════════════════════════════════ */

/* ── CLASSY (default — dark gold luxury) ── */
[data-theme="classy"], :root {
  --bg: #0a0805;
  --app-bg: radial-gradient(ellipse at top, #1a1208 0%, #0a0805 65%);
  --card-bg: #0a0805;
  --card-bg-hover: #130f0a;
  --card-border: rgba(201,168,76,.15);
  --surface: #0e0b07;
  --header-bg: rgba(10,8,5,.97);
  --text: #f5efe6;
  --text-muted: #8a7a62;
  --text-sub: #4a3f2f;
  --accent: #c9a84c;
  --accent-light: #e8c97a;
  --accent-dim: #7a5f2a;
  --accent-glow: rgba(201,168,76,.15);
  --border: rgba(201,168,76,.18);
  --border-hover: rgba(201,168,76,.45);
  --divider: rgba(201,168,76,.1);
  --ing-bg: rgba(201,168,76,.05);
  --font-display: 'Cormorant Garamond', serif;
  --font-body: 'Jost', sans-serif;
  --font-ui: 'Jost', sans-serif;
  --hero-title-style: italic;
  --card-radius: 0px;
  --btn-radius: 0px;
  --img-filter: saturate(.82) brightness(.88);
  --img-filter-hover: saturate(1) brightness(.94);
  --overlay: linear-gradient(to top, rgba(10,8,5,.95) 0%, rgba(10,8,5,.12) 55%, transparent 100%);
  --modal-overlay: linear-gradient(to bottom, transparent 30%, #0e0b07 100%);
  --theme-name: "Classy";
}

/* ── CONTEMPORARY (clean minimal — slate + electric blue) ── */
[data-theme="contemporary"] {
  --bg: #0d0f14;
  --app-bg: linear-gradient(160deg, #0d0f14 0%, #131820 100%);
  --card-bg: #111520;
  --card-bg-hover: #161b28;
  --card-border: rgba(96,165,250,.15);
  --surface: #141820;
  --header-bg: rgba(13,15,20,.97);
  --text: #e8edf5;
  --text-muted: #6b7a99;
  --text-sub: #374060;
  --accent: #60a5fa;
  --accent-light: #93c5fd;
  --accent-dim: #3b6cb5;
  --accent-glow: rgba(96,165,250,.12);
  --border: rgba(96,165,250,.2);
  --border-hover: rgba(96,165,250,.5);
  --divider: rgba(96,165,250,.08);
  --ing-bg: rgba(96,165,250,.05);
  --font-display: 'Outfit', sans-serif;
  --font-body: 'Outfit', sans-serif;
  --font-ui: 'Outfit', sans-serif;
  --hero-title-style: normal;
  --card-radius: 8px;
  --btn-radius: 4px;
  --img-filter: saturate(.9) brightness(.85) hue-rotate(10deg);
  --img-filter-hover: saturate(1.05) brightness(.95);
  --overlay: linear-gradient(to top, rgba(13,15,20,.97) 0%, rgba(13,15,20,.1) 50%, transparent 100%);
  --modal-overlay: linear-gradient(to bottom, transparent 25%, #141820 100%);
  --theme-name: "Contemporary";
}

/* ── CLASSIC (cream + burgundy + serif — old-world restaurant) ── */
[data-theme="classic"] {
  --bg: #f5f0e8;
  --app-bg: linear-gradient(180deg, #f5f0e8 0%, #ede5d4 100%);
  --card-bg: #faf7f2;
  --card-bg-hover: #f5f0e8;
  --card-border: rgba(120,30,45,.18);
  --surface: #faf7f2;
  --header-bg: rgba(245,240,232,.98);
  --text: #1a0a08;
  --text-muted: #6b4040;
  --text-sub: #a07060;
  --accent: #8b1a2a;
  --accent-light: #c0364a;
  --accent-dim: #5a1018;
  --accent-glow: rgba(139,26,42,.08);
  --border: rgba(139,26,42,.2);
  --border-hover: rgba(139,26,42,.5);
  --divider: rgba(139,26,42,.1);
  --ing-bg: rgba(139,26,42,.04);
  --font-display: 'Playfair Display', serif;
  --font-body: 'Jost', sans-serif;
  --font-ui: 'Jost', sans-serif;
  --hero-title-style: italic;
  --card-radius: 0px;
  --btn-radius: 0px;
  --img-filter: saturate(.85) brightness(.92) sepia(.15);
  --img-filter-hover: saturate(.95) brightness(.98) sepia(.05);
  --overlay: linear-gradient(to top, rgba(245,240,232,.97) 0%, rgba(245,240,232,.1) 55%, transparent 100%);
  --modal-overlay: linear-gradient(to bottom, transparent 30%, #faf7f2 100%);
  --theme-name: "Classic";
}

/* ── SEXY (deep rose + champagne — sultry velvet lounge) ── */
[data-theme="sexy"] {
  --bg: #0f0610;
  --app-bg: radial-gradient(ellipse at top left, #1e0820 0%, #0f0610 60%);
  --card-bg: #130a15;
  --card-bg-hover: #1a0d1c;
  --card-border: rgba(220,130,180,.15);
  --surface: #180c1a;
  --header-bg: rgba(15,6,16,.97);
  --text: #f8eaf0;
  --text-muted: #9a6f88;
  --text-sub: #4a2a3a;
  --accent: #e8829a;
  --accent-light: #f5b8cc;
  --accent-dim: #8a3050;
  --accent-glow: rgba(232,130,154,.14);
  --border: rgba(232,130,154,.2);
  --border-hover: rgba(232,130,154,.5);
  --divider: rgba(232,130,154,.09);
  --ing-bg: rgba(232,130,154,.05);
  --font-display: 'DM Serif Display', serif;
  --font-body: 'Jost', sans-serif;
  --font-ui: 'Jost', sans-serif;
  --hero-title-style: italic;
  --card-radius: 2px;
  --btn-radius: 20px;
  --img-filter: saturate(.9) brightness(.82) hue-rotate(-10deg);
  --img-filter-hover: saturate(1.1) brightness(.92) hue-rotate(-5deg);
  --overlay: linear-gradient(to top, rgba(15,6,16,.97) 0%, rgba(15,6,16,.1) 55%, transparent 100%);
  --modal-overlay: linear-gradient(to bottom, transparent 28%, #180c1a 100%);
  --theme-name: "Sexy";
}

/* ── FUN (neon brights + dark — cocktail party energy) ── */
[data-theme="fun"] {
  --bg: #0a0a12;
  --app-bg: linear-gradient(135deg, #0a0a12 0%, #100a18 50%, #0a100a 100%);
  --card-bg: #0e0e18;
  --card-bg-hover: #14142a;
  --card-border: rgba(168,85,247,.2);
  --surface: #12121e;
  --header-bg: rgba(10,10,18,.97);
  --text: #f0f0ff;
  --text-muted: #7070b0;
  --text-sub: #3a3a70;
  --accent: #a855f7;
  --accent-light: #c084fc;
  --accent-dim: #6b21a8;
  --accent-glow: rgba(168,85,247,.15);
  --border: rgba(168,85,247,.25);
  --border-hover: rgba(168,85,247,.6);
  --divider: rgba(168,85,247,.1);
  --ing-bg: rgba(168,85,247,.06);
  --font-display: 'Outfit', sans-serif;
  --font-body: 'Outfit', sans-serif;
  --font-ui: 'Outfit', sans-serif;
  --hero-title-style: normal;
  --card-radius: 12px;
  --btn-radius: 999px;
  --img-filter: saturate(1.1) brightness(.85) hue-rotate(20deg);
  --img-filter-hover: saturate(1.3) brightness(.95) hue-rotate(10deg);
  --overlay: linear-gradient(to top, rgba(10,10,18,.97) 0%, rgba(10,10,18,.1) 50%, transparent 100%);
  --modal-overlay: linear-gradient(to bottom, transparent 25%, #12121e 100%);
  --theme-name: "Fun";
}

/* ── CONTEMPORARY (clean minimal — slate + electric blue) ── */
/* extra fun glow on cards */
[data-theme="fun"] .card { box-shadow: 0 0 0 transparent; transition: background .25s, box-shadow .3s; }
[data-theme="fun"] .card:hover { box-shadow: 0 0 24px rgba(168,85,247,.15); }
[data-theme="sexy"] .card:hover { box-shadow: 0 0 20px rgba(232,130,154,.12); }
[data-theme="contemporary"] .card:hover { box-shadow: 0 0 18px rgba(96,165,250,.1); }

/* ═══════════════════════════════════════════════════════
   LAYOUT
   ═══════════════════════════════════════════════════════ */

/* ── Header ── */
.header{border-bottom:1px solid var(--border);padding:0 1rem;position:sticky;top:0;z-index:200;background:var(--header-bg);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
.header-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:56px;gap:.5rem}
.logo{font-family:var(--font-display);font-size:1.1rem;font-weight:400;letter-spacing:.1em;color:var(--accent);text-transform:uppercase;white-space:nowrap;flex-shrink:0}
.logo span{font-style:italic;color:var(--text-muted);font-size:.85em;letter-spacing:.06em;text-transform:none}
[data-theme="fun"] .logo { letter-spacing: .06em; font-weight: 700; text-transform: none; }
[data-theme="fun"] .logo span { background: linear-gradient(135deg, #a855f7, #ec4899, #f59e0b); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.nav{display:flex;gap:.1rem}
.nav-btn{background:none;border:none;color:var(--text-muted);font-family:var(--font-ui);font-size:.6rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;padding:.4rem .9rem;cursor:pointer;transition:color .2s;position:relative;min-height:44px;display:flex;align-items:center}
.nav-btn:hover{color:var(--accent-light)}
.nav-btn.active{color:var(--accent)}
.nav-btn.active::after{content:'';position:absolute;bottom:-1px;left:.9rem;right:.9rem;height:1px;background:var(--accent)}
[data-theme="fun"] .nav-btn { letter-spacing: .08em; font-weight: 600; }

/* ── Theme Picker ── */
.theme-picker{display:flex;align-items:center;gap:.4rem;margin-left:auto}
.theme-label{font-size:.52rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-sub);white-space:nowrap;display:none}
@media(min-width:520px){.theme-label{display:block}}
.theme-swatch{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .2s,border-color .2s;flex-shrink:0;outline:none}
.theme-swatch:hover{transform:scale(1.18)}
.theme-swatch.active{border-color:var(--text);transform:scale(1.18)}
.theme-swatch[data-t="classy"]{background:radial-gradient(circle,#e8c97a,#7a5f2a)}
.theme-swatch[data-t="contemporary"]{background:radial-gradient(circle,#93c5fd,#1d4ed8)}
.theme-swatch[data-t="classic"]{background:radial-gradient(circle,#c0364a,#5a1018)}
.theme-swatch[data-t="sexy"]{background:radial-gradient(circle,#f5b8cc,#6b1030)}
.theme-swatch[data-t="fun"]{background:conic-gradient(#a855f7,#ec4899,#f59e0b,#22c55e,#a855f7)}

/* ── Hero ── */
.hero{text-align:center;padding:2.5rem 1.2rem 1.2rem;max-width:820px;margin:0 auto}
.hero-eyebrow{font-size:.58rem;letter-spacing:.35em;text-transform:uppercase;color:var(--accent);margin-bottom:.8rem;font-family:var(--font-ui)}
.hero-title{font-family:var(--font-display);font-size:clamp(2rem,8vw,4.2rem);font-weight:400;line-height:1.1;color:var(--text);margin-bottom:.7rem}
.hero-title em{font-style:var(--hero-title-style);color:var(--accent-light)}
[data-theme="fun"] .hero-title { font-weight:700 }
[data-theme="fun"] .hero-title em { background:linear-gradient(135deg,#a855f7,#ec4899); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; font-style:normal }
.hero-sub{font-size:.74rem;font-weight:300;letter-spacing:.1em;color:var(--text-muted)}

/* ── Stats ── */
.stats-bar{display:flex;align-items:center;justify-content:center;gap:1.5rem;padding:1rem 1.2rem;border-top:1px solid var(--divider);border-bottom:1px solid var(--divider);max-width:1200px;margin:0 auto}
.stat{text-align:center;min-width:60px}
.stat-num{font-family:var(--font-display);font-size:1.7rem;font-weight:400;color:var(--accent);line-height:1}
[data-theme="contemporary"] .stat-num,[data-theme="fun"] .stat-num{font-weight:700}
.stat-label{font-size:.52rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);margin-top:.12rem}
.stat-divider{width:1px;height:30px;background:var(--border);flex-shrink:0}

/* ── Action bar ── */
.action-bar{max-width:1200px;margin:0 auto;padding:.7rem 1.2rem;display:flex;align-items:center;justify-content:flex-end;gap:.6rem;border-bottom:1px solid var(--divider)}
.pdf-btn{display:flex;align-items:center;gap:.4rem;background:none;border:1px solid var(--border);color:var(--accent);font-family:var(--font-ui);font-size:.58rem;letter-spacing:.15em;text-transform:uppercase;padding:.42rem .9rem;cursor:pointer;transition:all .25s;min-height:36px;border-radius:var(--btn-radius)}
.pdf-btn:hover{background:var(--accent-glow);border-color:var(--accent)}
.pdf-btn svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;flex-shrink:0}

/* ── Filters ── */
.filters{max-width:1200px;margin:0 auto;padding:.9rem 1.2rem .6rem;display:flex;flex-direction:column;gap:.65rem}
.filter-row{display:flex;gap:.35rem;flex-wrap:wrap;align-items:center}
.filter-label{font-size:.55rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-sub)}
.filter-btn{background:none;border:1px solid var(--border);color:var(--text-muted);font-family:var(--font-ui);font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;padding:.3rem .65rem;cursor:pointer;transition:all .2s;min-height:32px;border-radius:var(--btn-radius)}
.filter-btn:hover,.filter-btn.active{background:var(--accent-glow);border-color:var(--border-hover);color:var(--accent)}
.search-input{width:100%;background:var(--accent-glow);border:1px solid var(--border);color:var(--text);font-family:var(--font-body);font-size:.8rem;font-weight:300;padding:.5rem .9rem;outline:none;transition:border-color .2s;-webkit-appearance:none;border-radius:var(--btn-radius);min-height:40px}
.search-input::placeholder{color:var(--text-sub)}
.search-input:focus{border-color:var(--border-hover)}

/* ── Section header ── */
.section-wrap{max-width:1200px;margin:0 auto;padding:1.2rem 1.2rem 2rem}
.section-header{display:flex;align-items:center;gap:.8rem;margin-bottom:1.2rem}
.section-title{font-family:var(--font-display);font-size:.75rem;font-weight:400;letter-spacing:.28em;text-transform:uppercase;color:var(--accent);white-space:nowrap}
[data-theme="fun"] .section-title,[data-theme="contemporary"] .section-title{letter-spacing:.1em;font-weight:700}
.section-line{flex:1;height:1px;background:linear-gradient(to right,var(--border),.5,transparent)}

/* ── Cocktail Grid ── */
.cocktail-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:var(--card-border);border:1px solid var(--card-border)}
[data-theme="fun"] .cocktail-grid,[data-theme="contemporary"] .cocktail-grid{gap:8px;background:transparent;border:none}
.card{background:var(--card-bg);cursor:pointer;overflow:hidden;transition:background .25s;border-radius:var(--card-radius)}
[data-theme="fun"] .card,[data-theme="contemporary"] .card{border:1px solid var(--card-border)}
.card:active{background:var(--card-bg-hover)}
.card-img-wrap{width:100%;height:160px;overflow:hidden;position:relative}
.card-img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;filter:var(--img-filter)}
.card:hover .card-img{transform:scale(1.05);filter:var(--img-filter-hover)}
.card-overlay{position:absolute;inset:0;background:var(--overlay)}
.card-badge{position:absolute;top:.6rem;right:.6rem;font-size:.45rem;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);background:var(--card-bg);border:1px solid var(--border);padding:.15rem .4rem;border-radius:calc(var(--btn-radius) * .5)}
[data-theme="fun"] .card-badge{background:var(--accent);color:#fff;border-color:transparent;font-weight:700;letter-spacing:.05em}
[data-theme="sexy"] .card-badge{color:var(--accent-light)}
.card-body{padding:.9rem 1rem}
.card-name{font-family:var(--font-display);font-size:1.25rem;font-weight:400;color:var(--text);margin-bottom:.25rem;line-height:1.15}
[data-theme="contemporary"] .card-name,[data-theme="fun"] .card-name{font-size:1.1rem;font-weight:700}
.card-desc{font-size:.62rem;font-weight:300;color:var(--text-muted);line-height:1.55;margin-bottom:.65rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-ings{display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:.65rem}
.ing-tag{font-size:.48rem;letter-spacing:.07em;text-transform:uppercase;color:var(--text-sub);background:var(--ing-bg);border:1px solid var(--border);padding:.12rem .35rem;border-radius:calc(var(--btn-radius) * .5)}
.ing-tag.missing{color:#8a4040;border-color:rgba(138,64,64,.3);text-decoration:line-through}
.card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:.6rem;border-top:1px solid var(--divider)}
.card-glass{font-size:.5rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-sub)}
.view-btn{font-size:.5rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);background:none;border:1px solid var(--border);padding:.28rem .55rem;cursor:pointer;transition:all .2s;border-radius:var(--btn-radius)}
.view-btn:hover{background:var(--accent-glow);border-color:var(--accent)}

/* ── Unavailable ── */
.unavail-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--divider);border:1px solid var(--divider)}
.unavail-card{background:var(--card-bg);padding:.8rem;opacity:.45}
.unavail-name{font-family:var(--font-display);font-size:.95rem;color:var(--text-muted);margin-bottom:.35rem}
.miss-list{font-size:.55rem;letter-spacing:.07em;text-transform:uppercase;color:var(--text-sub);line-height:1.8}
.unavail-toggle{background:none;border:none;display:flex;align-items:center;gap:.5rem;cursor:pointer;font-family:var(--font-ui);font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-sub);transition:color .2s;margin-bottom:.8rem;min-height:36px}
.unavail-toggle:hover{color:var(--text-muted)}
.unavail-toggle .arrow{transition:transform .22s;display:inline-block}
.unavail-toggle.open .arrow{transform:rotate(90deg)}

/* ── Empty ── */
.empty{text-align:center;padding:3rem 1.5rem}
.empty-title{font-family:var(--font-display);font-size:1.4rem;color:var(--text-muted);margin-bottom:.4rem}
.empty-sub{font-size:.68rem;color:var(--text-sub);letter-spacing:.08em}

/* ── Recipe Modal ── */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.88);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:300;display:flex;align-items:flex-start;justify-content:center;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0}
.modal-box{width:100%;max-width:800px;background:var(--surface);position:relative;overflow:hidden;animation:slideUp .35s ease;min-height:100svh;margin:0 auto;border-radius:0}
@media(min-width:600px){.modal-box{min-height:auto;margin:2rem auto;border:1px solid var(--border);border-radius:var(--card-radius)}}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.modal-img{width:100%;height:220px;object-fit:cover;display:block;filter:var(--img-filter)}
.modal-img-overlay{position:absolute;top:0;left:0;width:100%;height:220px;background:var(--modal-overlay)}
.close-btn{position:absolute;top:.9rem;right:.9rem;background:var(--surface);border:1px solid var(--border);color:var(--accent);width:40px;height:40px;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:10;border-radius:50%}
.close-btn:hover{background:var(--accent-glow)}
.modal-body{padding:1.3rem 1.2rem 2rem}
.rec-badge{display:inline-block;font-size:.5rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);border:1px solid var(--border);padding:.15rem .5rem;margin-bottom:.55rem;border-radius:calc(var(--btn-radius) * .5)}
[data-theme="fun"] .rec-badge{background:var(--accent);color:#fff;border-color:transparent;font-weight:700;letter-spacing:.05em}
.rec-name{font-family:var(--font-display);font-size:clamp(1.8rem,6vw,2.8rem);font-weight:400;color:var(--text);line-height:1;margin-bottom:.5rem}
[data-theme="fun"] .rec-name,[data-theme="contemporary"] .rec-name{font-weight:700}
.rec-desc{font-size:.76rem;color:var(--text-muted);line-height:1.7;margin-bottom:1.4rem;font-weight:300}
.rec-cols{display:grid;grid-template-columns:1fr;gap:1.5rem}
.rec-section-title{font-size:.56rem;letter-spacing:.28em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem;padding-bottom:.4rem;border-bottom:1px solid var(--border)}
.rec-ing{display:flex;justify-content:space-between;align-items:baseline;padding:.5rem 0;border-bottom:1px solid var(--divider)}
.rec-ing-name{font-size:.75rem;color:var(--text);font-weight:300}
.rec-ing-qty{font-family:var(--font-display);font-size:.95rem;color:var(--accent);white-space:nowrap;margin-left:.8rem}
.rec-step{display:flex;gap:.9rem;margin-bottom:1rem}
.rec-step-num{font-family:var(--font-display);font-size:1.5rem;color:var(--border);line-height:1.2;min-width:1.7rem;text-align:right;flex-shrink:0}
.rec-step-text{font-size:.75rem;color:var(--text-muted);line-height:1.8;font-weight:300;padding-top:.12rem}
.rec-footer{margin-top:1.5rem;padding-top:1.2rem;border-top:1px solid var(--border);display:flex;gap:2rem;flex-wrap:wrap}
.rec-detail-label{font-size:.55rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-sub);margin-bottom:.12rem}
.rec-detail-val{font-size:.72rem;color:var(--text);font-weight:300}

/* ── Inventory ── */
.inventory{max-width:960px;margin:0 auto;padding:1rem 1.2rem 5rem}
.inv-sticky-footer{position:fixed;bottom:0;left:0;right:0;z-index:100;background:var(--header-bg);border-top:1px solid var(--border);padding:.9rem 1.2rem;display:flex;align-items:center;justify-content:space-between;gap:.8rem;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.inv-changed-badge{font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-light);opacity:0;transition:opacity .3s}
.inv-changed-badge.visible{opacity:1}
.save-btn{display:flex;align-items:center;gap:.45rem;background:var(--accent);border:none;color:var(--bg);font-family:var(--font-ui);font-size:.62rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;padding:.65rem 1.4rem;cursor:pointer;transition:all .2s;min-height:42px;border-radius:var(--btn-radius)}
.save-btn:hover{opacity:.88}
.save-btn:disabled{opacity:.45;cursor:not-allowed;background:var(--accent-glow);color:var(--accent);border:1px solid var(--border)}
.save-btn svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2.5;flex-shrink:0}
.reset-btn{background:none;border:1px solid var(--border);color:var(--text-muted);font-family:var(--font-ui);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;padding:.6rem .9rem;cursor:pointer;transition:all .2s;min-height:42px;border-radius:var(--btn-radius)}
.reset-btn:hover{border-color:var(--border-hover);color:var(--text)}
.inv-cat{margin-bottom:1.8rem}
.inv-cat-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.7rem;padding-bottom:.45rem;border-bottom:1px solid var(--border)}
.inv-cat-name{font-family:var(--font-display);font-size:.95rem;font-weight:400;letter-spacing:.1em;color:var(--accent)}
[data-theme="fun"] .inv-cat-name,[data-theme="contemporary"] .inv-cat-name{font-weight:700;letter-spacing:.04em}
.inv-actions{display:flex;gap:.35rem}
.inv-act-btn{font-size:.5rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-sub);background:none;border:1px solid var(--border);padding:.2rem .45rem;cursor:pointer;font-family:var(--font-ui);transition:all .2s;min-height:28px;border-radius:var(--btn-radius)}
.inv-act-btn:hover{color:var(--accent);border-color:var(--border-hover)}
.inv-items{display:flex;flex-wrap:wrap;gap:.45rem}
.inv-item{display:flex;align-items:center;gap:.4rem;background:var(--ing-bg);border:1px solid var(--border);padding:.42rem .7rem;cursor:pointer;transition:all .2s;user-select:none;min-height:36px;-webkit-tap-highlight-color:transparent;border-radius:var(--btn-radius)}
.inv-item:hover,.inv-item:active{border-color:var(--border-hover)}
.inv-item.stocked{background:var(--accent-glow);border-color:var(--border-hover)}
.inv-dot{width:5px;height:5px;border-radius:50%;background:var(--border);transition:background .2s;flex-shrink:0}
.inv-item.stocked .inv-dot{background:var(--accent)}
.inv-name{font-size:.68rem;color:var(--text-muted);transition:color .2s;font-weight:300}
.inv-item.stocked .inv-name{color:var(--text)}

/* ── AI Suggestion ── */
.ai-section{max-width:1200px;margin:2rem auto 0;padding:1.2rem 1.2rem 3rem;border-top:1px solid var(--divider)}
.ai-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1rem;gap:.8rem}
.ai-btn{display:flex;align-items:center;gap:.4rem;background:var(--accent-glow);border:1px solid var(--border-hover);color:var(--accent-light);font-family:var(--font-ui);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;padding:.7rem 1.1rem;cursor:pointer;transition:all .3s;white-space:nowrap;min-height:40px;border-radius:var(--btn-radius)}
.ai-btn:hover{background:var(--border);border-color:var(--accent)}
.ai-btn:disabled{opacity:.45;cursor:not-allowed}
.spin{width:12px;height:12px;border:1.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}
.ai-card{background:var(--card-bg);border:1px solid var(--border);padding:1.4rem;animation:fadeUp .4s ease;border-radius:var(--card-radius)}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.ai-badge{display:inline-block;font-size:.5rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);border:1px solid var(--border);padding:.15rem .5rem;margin-bottom:.6rem;border-radius:calc(var(--btn-radius) * .5)}
[data-theme="fun"] .ai-badge{background:var(--accent);color:#fff;border-color:transparent}
.ai-name{font-family:var(--font-display);font-size:1.7rem;font-weight:400;color:var(--accent-light);margin-bottom:.35rem}
[data-theme="fun"] .ai-name,[data-theme="contemporary"] .ai-name{font-weight:700}
.ai-desc{font-size:.73rem;color:var(--text-muted);margin-bottom:1.2rem;font-weight:300;line-height:1.65}
.ai-grid{display:grid;grid-template-columns:1fr;gap:1.4rem}
.ai-sub{font-size:.56rem;letter-spacing:.25em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem}
.ai-ing{display:flex;justify-content:space-between;padding:.4rem 0;border-bottom:1px solid var(--divider);font-size:.7rem;color:var(--text)}
.ai-qty{font-family:var(--font-display);font-size:.88rem;color:var(--accent)}
.ai-step{display:flex;gap:.8rem;margin-bottom:.75rem}
.ai-snum{font-family:var(--font-display);font-size:1rem;color:var(--border);line-height:1;min-width:1.2rem;flex-shrink:0}
.ai-stext{font-size:.7rem;color:var(--text-muted);line-height:1.7;font-weight:300}
.ai-error{font-size:.72rem;color:#c06060;padding:.8rem .9rem;border:1px solid rgba(192,96,96,.25);margin-top:.5rem}

/* ── Toast ── */
.toast{position:fixed;bottom:5rem;left:50%;transform:translateX(-50%) translateY(10px);background:var(--card-bg);border:1px solid var(--border);color:var(--accent-light);font-family:var(--font-ui);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;padding:.6rem 1.2rem;z-index:500;opacity:0;transition:all .3s;white-space:nowrap;pointer-events:none;border-radius:var(--btn-radius)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── Tablet (600px+) ── */
@media(min-width:600px){
  .header{padding:0 1.5rem}
  .header-inner{height:64px}
  .logo{font-size:1.3rem}
  .hero{padding:3rem 1.5rem 1.5rem}
  .stats-bar{gap:2.5rem;padding:1.2rem 1.5rem}
  .stat-num{font-size:1.9rem}
  .filters{padding:1.2rem 1.5rem .6rem}
  .filter-row{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:.2rem}
  .filter-row::-webkit-scrollbar{display:none}
  .section-wrap{padding:1.4rem 1.5rem 2rem}
  .cocktail-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
  .card-img-wrap{height:190px}
  .card-name{font-size:1.4rem}
  .card-desc{font-size:.66rem}
  .rec-cols{grid-template-columns:1fr 1.4fr;gap:2rem}
  .ai-grid{grid-template-columns:1fr 1fr;gap:1.8rem}
  .inventory{padding:1.2rem 1.5rem 5rem}
  .inv-sticky-footer{padding:.9rem 1.5rem}
}

/* ── Desktop (960px+) ── */
@media(min-width:960px){
  .header{padding:0 2rem}
  .header-inner{height:68px}
  .hero{padding:3.5rem 2rem 1.5rem}
  .stats-bar{gap:3rem;padding:1.4rem 2rem}
  .stat-num{font-size:2rem}
  .filters{padding:1.4rem 2rem .6rem;flex-direction:row;align-items:center}
  .filter-row{flex-wrap:wrap}
  .search-input{width:220px}
  .section-wrap{padding:1.5rem 2rem 2.5rem}
  .cocktail-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
  .card-img-wrap{height:210px}
  .modal-body{padding:1.8rem 2rem 2.5rem}
  .ai-section{padding:1.5rem 2rem 3rem}
  .inventory{padding:1.5rem 2rem 5rem}
  .inv-sticky-footer{padding:.9rem 2rem}
}

/* ── classic theme light adjustments ── */
[data-theme="classic"] .header{border-bottom-color:rgba(139,26,42,.15)}
[data-theme="classic"] .hero-eyebrow{letter-spacing:.5em}
[data-theme="classic"] .section-line{background:linear-gradient(to right,rgba(139,26,42,.35),transparent)}
[data-theme="classic"] .modal-backdrop{background:rgba(20,5,5,.82)}
[data-theme="classic"] .ing-tag.missing{color:#a04040;border-color:rgba(160,64,64,.3)}

/* ── Font Size Controls ── */
.fsize-controls{display:flex;align-items:center;gap:.3rem}
.fsize-step{background:none;border:1px solid var(--border);color:var(--text-muted);font-family:var(--font-ui);font-size:.65rem;font-weight:600;padding:0 .6rem;cursor:pointer;transition:all .2s;min-height:30px;min-width:30px;border-radius:var(--btn-radius);line-height:1;white-space:nowrap}
.fsize-step:hover{border-color:var(--border-hover);color:var(--accent)}
.fsize-track{display:flex;gap:.2rem;align-items:center}
.fsize-btn{background:none;border:1px solid var(--border);color:var(--text-sub);font-family:var(--font-ui);font-size:.52rem;font-weight:500;padding:.18rem .35rem;cursor:pointer;transition:all .18s;min-height:26px;border-radius:var(--btn-radius);letter-spacing:.05em}
.fsize-btn:hover{border-color:var(--border-hover);color:var(--text-muted)}
.fsize-btn.active{background:var(--accent-glow);border-color:var(--border-hover);color:var(--accent);font-weight:700}
/* Hide full track on very small screens, just show step buttons */
@media(max-width:420px){.fsize-track{display:none}}


/* ═══════════════════════════════════════════════════════
   FONT OVERRIDE SYSTEM
   ═══════════════════════════════════════════════════════ */

[data-font] body,
[data-font] .card-name, [data-font] .card-desc,
[data-font] .rec-name, [data-font] .rec-desc,
[data-font] .rec-ing-name, [data-font] .rec-step-text,
[data-font] .hero-title, [data-font] .hero-sub,
[data-font] .stat-num, [data-font] .inv-name,
[data-font] .ai-name, [data-font] .ai-desc,
[data-font] .unavail-name {
  font-family: var(--font-override) !important;
}

:root { --lh-override: 1.6; --ls-override: 0em; }

.card-desc, .rec-desc, .rec-step-text, .rec-ing-name,
.ai-desc, .ai-stext, .inv-name, .miss-list {
  line-height: var(--lh-override) !important;
  letter-spacing: var(--ls-override) !important;
}

.card-name, .rec-name, .hero-title, .unavail-name, .ai-name {
  letter-spacing: calc(var(--ls-override) * 0.5) !important;
}

[data-font="mono"] .card-name,
[data-font="mono"] .rec-name,
[data-font="mono"] .hero-title { font-size: 92%; }

[data-font="dyslexic"] { word-spacing: 0.1em; }
[data-font="dyslexic"] .card-desc,
[data-font="dyslexic"] .rec-step-text { font-size: 105%; }

/* ── Typography Bar ── */
/* Single scrollable strip — never wraps, always visible */
.typo-bar {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1rem;
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: 0;
  border-bottom: 1px solid var(--divider);
  background: var(--card-bg);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  min-height: 44px;
}
.typo-bar::-webkit-scrollbar { display: none; }

.typo-group {
  display: flex;
  align-items: center;
  gap: .35rem;
  flex-shrink: 0;
  padding: .5rem .6rem;
}

.typo-label {
  font-size: .5rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--text-sub);
  white-space: nowrap;
}

.typo-divider {
  width: 1px;
  height: 18px;
  background: var(--border);
  flex-shrink: 0;
}

.typo-row {
  display: flex;
  gap: .2rem;
  align-items: center;
  flex-wrap: nowrap;
}

/* All picker buttons share these base styles */
.ffam-btn, .fsize-btn, .fsize-step, .lh-btn, .ls-btn {
  background: none;
  border: 1px solid var(--border);
  color: var(--text-sub);
  font-family: var(--font-body);
  font-size: .58rem;
  padding: .22rem .48rem;
  cursor: pointer;
  transition: all .15s;
  min-height: 28px;
  border-radius: var(--btn-radius);
  white-space: nowrap;
  letter-spacing: .03em;
  line-height: 1;
  display: inline-flex;
  align-items: center;
}
.ffam-btn:hover, .fsize-btn:hover, .fsize-step:hover, .lh-btn:hover, .ls-btn:hover {
  border-color: var(--border-hover);
  color: var(--text-muted);
}
.ffam-btn.active, .fsize-btn.active, .lh-btn.active, .ls-btn.active {
  background: var(--accent-glow);
  border-color: var(--border-hover);
  color: var(--accent);
  font-weight: 600;
}
.fsize-step {
  font-weight: 700;
  font-size: .65rem;
  min-width: 30px;
  justify-content: center;
}

/* ── PDF Export Bar ── */
.pdf-export-bar {
  max-width: 1200px;
  margin: 0 auto;
  padding: .55rem 1.2rem;
  display: flex;
  justify-content: flex-end;
  gap: .5rem;
  border-bottom: 1px solid var(--divider);
}

.table-menu-btn {
  background: var(--accent-glow) !important;
  border-color: var(--border-hover) !important;
}
.table-menu-btn:hover { filter: brightness(1.2); }

/* ── Fold instructions notice ── */
.fold-notice {
  position: fixed;
  bottom: 5.5rem;
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  background: var(--surface);
  border: 1px solid var(--border-hover);
  color: var(--text-muted);
  font-family: var(--font-body);
  font-size: .68rem;
  font-weight: 300;
  line-height: 1.6;
  padding: .8rem 1.4rem;
  z-index: 500;
  opacity: 0;
  transition: all .35s;
  pointer-events: none;
  max-width: 90vw;
  text-align: center;
  border-radius: var(--btn-radius);
}
.fold-notice.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.fold-notice strong { color: var(--accent); }

@media(min-width: 960px) {
  .typo-bar { padding: 0 2rem; }
  .pdf-export-bar { padding: .55rem 2rem; }
  .typo-group { padding: .5rem .8rem; }
}

/* ═══════════════════════════════════════════════════════
   NAV — hamburger + dropdown
   ═══════════════════════════════════════════════════════ */

.main-nav { position: relative; display: flex; align-items: center; gap: .5rem; }

.nav-hamburger {
  background: none;
  border: 1px solid var(--border);
  width: 40px; height: 40px;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 5px;
  cursor: pointer;
  border-radius: var(--btn-radius);
  transition: border-color .2s, background .2s;
  flex-shrink: 0;
}
.nav-hamburger:hover { border-color: var(--border-hover); background: var(--accent-glow); }
.ham-bar {
  display: block; width: 18px; height: 1.5px;
  background: var(--text-muted);
  transition: all .25s;
  transform-origin: center;
}
.nav-hamburger[aria-expanded="true"] .ham-bar:nth-child(1) { transform: translateY(6.5px) rotate(45deg); background: var(--accent); }
.nav-hamburger[aria-expanded="true"] .ham-bar:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav-hamburger[aria-expanded="true"] .ham-bar:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); background: var(--accent); }

.nav-label-current {
  font-family: var(--font-ui);
  font-size: .6rem;
  font-weight: 500;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--accent);
  white-space: nowrap;
}

.nav-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 180px;
  background: var(--surface);
  border: 1px solid var(--border-hover);
  z-index: 300;
  opacity: 0;
  transform: translateY(-8px) scale(.97);
  pointer-events: none;
  transition: opacity .2s, transform .2s;
  border-radius: var(--card-radius);
  overflow: hidden;
  box-shadow: 0 12px 40px rgba(0,0,0,.4);
}
.nav-dropdown.open {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: all;
}

.nav-item {
  display: flex;
  align-items: center;
  gap: .75rem;
  width: 100%;
  background: none;
  border: none;
  padding: .85rem 1.2rem;
  cursor: pointer;
  transition: background .15s;
  text-align: left;
  border-bottom: 1px solid var(--divider);
}
.nav-item:last-child { border-bottom: none; }
.nav-item:hover { background: var(--accent-glow); }
.nav-item.active { background: var(--accent-glow); }
.nav-item-icon {
  font-size: 1.1rem;
  width: 1.4rem;
  text-align: center;
  flex-shrink: 0;
}
.nav-item-label {
  font-family: var(--font-ui);
  font-size: .72rem;
  font-weight: 500;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--text-muted);
  transition: color .15s;
}
.nav-item.active .nav-item-label,
.nav-item:hover .nav-item-label { color: var(--accent); }

/* Close dropdown when clicking outside */
.nav-overlay {
  position: fixed; inset: 0; z-index: 299;
}

/* ═══════════════════════════════════════════════════════
   SHOTS GRID
   ═══════════════════════════════════════════════════════ */

.shots-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 2px;
  background: var(--card-border);
  border: 1px solid var(--card-border);
}
[data-theme="fun"] .shots-grid,
[data-theme="contemporary"] .shots-grid {
  gap: 8px; background: transparent; border: none;
}

.shot-card {
  background: var(--card-bg);
  cursor: pointer;
  overflow: hidden;
  transition: background .2s;
  border-radius: var(--card-radius);
}
[data-theme="fun"] .shot-card,
[data-theme="contemporary"] .shot-card { border: 1px solid var(--card-border); }
.shot-card:hover { background: var(--card-bg-hover); }
[data-theme="fun"] .shot-card:hover { box-shadow: 0 0 24px rgba(168,85,247,.15); }

.shot-img-wrap {
  width: 100%; height: 130px;
  overflow: hidden; position: relative;
}
.shot-img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .5s ease;
  filter: var(--img-filter);
}
.shot-card:hover .shot-img { transform: scale(1.06); filter: var(--img-filter-hover); }

.shot-glass-tag {
  position: absolute; bottom: .5rem; left: .5rem;
  font-size: .45rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--parchment, #f5efe6);
  background: rgba(0,0,0,.55);
  padding: .15rem .4rem;
  border-radius: 2px;
}

.shot-body { padding: .8rem .9rem; }
.shot-name {
  font-family: var(--font-display);
  font-size: 1.05rem; font-weight: 400;
  color: var(--text); margin-bottom: .2rem; line-height: 1.15;
}
[data-theme="contemporary"] .shot-name,
[data-theme="fun"] .shot-name { font-size: .95rem; font-weight: 700; }
.shot-desc {
  font-size: .6rem; font-weight: 300; color: var(--text-muted);
  line-height: 1.5; margin-bottom: .5rem;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}

/* ═══════════════════════════════════════════════════════
   SETTINGS PAGE
   ═══════════════════════════════════════════════════════ */

.settings-wrap {
  max-width: 800px;
  margin: 0 auto;
  padding: 1.5rem 1.2rem 3rem;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.settings-section {
  background: var(--card-bg);
  border: 1px solid var(--border);
  padding: 1.4rem;
  border-radius: var(--card-radius);
}

.settings-section-title {
  font-family: var(--font-display);
  font-size: 1rem; font-weight: 400;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--accent); margin-bottom: .4rem;
}
[data-theme="fun"] .settings-section-title,
[data-theme="contemporary"] .settings-section-title { font-weight: 700; letter-spacing: .05em; }

.settings-section-desc {
  font-size: .72rem; color: var(--text-muted); font-weight: 300;
  line-height: 1.6; margin-bottom: 1.2rem;
}

/* Theme grid */
.settings-theme-grid {
  display: flex; gap: .7rem; flex-wrap: wrap;
}
.settings-theme-btn {
  display: flex; flex-direction: column; align-items: center; gap: .45rem;
  background: var(--surface); border: 1px solid var(--border);
  padding: .7rem .9rem; cursor: pointer;
  transition: all .2s; border-radius: var(--btn-radius);
  min-width: 60px;
  font-family: var(--font-ui); font-size: .58rem;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--text-muted);
}
.settings-theme-btn:hover { border-color: var(--border-hover); color: var(--accent); }
.settings-theme-btn.active { border-color: var(--accent); color: var(--accent); background: var(--accent-glow); }
.theme-swatch-lg {
  width: 32px; height: 32px; border-radius: 50%;
}
.theme-swatch-lg[data-t="classy"]       { background: radial-gradient(circle,#e8c97a,#7a5f2a); }
.theme-swatch-lg[data-t="contemporary"] { background: radial-gradient(circle,#93c5fd,#1d4ed8); }
.theme-swatch-lg[data-t="classic"]      { background: radial-gradient(circle,#c0364a,#5a1018); }
.theme-swatch-lg[data-t="sexy"]         { background: radial-gradient(circle,#f5b8cc,#6b1030); }
.theme-swatch-lg[data-t="fun"]          { background: conic-gradient(#a855f7,#ec4899,#f59e0b,#22c55e,#a855f7); }

/* Typography settings */
.settings-typo-grid {
  display: flex; flex-direction: column; gap: .9rem;
}
.settings-typo-row {
  display: flex; align-items: center; gap: 1rem; flex-wrap: wrap;
}
.settings-typo-label {
  font-size: .6rem; letter-spacing: .15em; text-transform: uppercase;
  color: var(--text-sub); min-width: 80px; flex-shrink: 0;
}

/* Preview */
.settings-preview {
  margin-top: 1.2rem; padding: 1rem;
  background: var(--surface); border: 1px solid var(--divider);
  border-radius: var(--btn-radius);
}
.settings-preview-label {
  font-size: .52rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--accent); margin-bottom: .5rem;
}
.settings-preview-text {
  font-size: .82rem; color: var(--text-muted);
  line-height: var(--lh-override);
  letter-spacing: var(--ls-override);
  font-family: var(--font-override, var(--font-body));
  font-weight: 300;
  transition: all .2s;
}

/* Export row */
.settings-export-row { display: flex; gap: .6rem; flex-wrap: wrap; }

/* Stats */
.settings-stats { display: flex; flex-direction: column; gap: .55rem; }
.settings-stat-row {
  display: flex; align-items: center; gap: .8rem;
}
.settings-stat-label {
  font-size: .62rem; color: var(--text-muted);
  min-width: 100px; font-weight: 300;
}
.settings-stat-bar {
  flex: 1; height: 4px; background: var(--border);
  border-radius: 2px; overflow: hidden;
}
.settings-stat-fill {
  height: 100%; background: var(--accent);
  border-radius: 2px;
  transition: width .4s ease;
}
.settings-stat-count {
  font-size: .58rem; color: var(--text-sub);
  font-family: var(--font-display);
  min-width: 32px; text-align: right;
}

/* ── Responsive ── */
@media(min-width: 600px) {
  .shots-grid { grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); }
  .settings-wrap { padding: 1.5rem 1.5rem 3rem; }
  .shot-img-wrap { height: 150px; }
}
@media(min-width: 960px) {
  .settings-wrap { padding: 1.5rem 2rem 3rem; }
  .shots-grid { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }
  .shot-img-wrap { height: 160px; }
}
