/* ════════════════════════════════════════════════════════════
   THE GARDEN OF US — apothecary date planner
   Design system / theme
   ════════════════════════════════════════════════════════════ */
:root{
  /* warm aubergine / plum-brown ground */
  --ink:#140b12;
  --night:#1d111a;
  --night-2:#241620;
  --plum:#2b1925;
  --plum-soft:#3a2433;
  --panel:rgba(48,29,40,.5);
  --panel-2:rgba(30,18,26,.55);
  /* antique gold engraving */
  --gold:#c9a05a;
  --gold-bright:#ead09a;
  --gold-dim:#9a7842;
  --gold-line:rgba(201,160,90,.36);
  --gold-line-soft:rgba(201,160,90,.16);
  /* parchment */
  --parch:#dcc9a4;
  --parch-2:#cdb88e;
  --parch-edge:#b6a172;
  --sepia:#473420;
  --sepia-soft:#6a5234;
  /* botanical accents */
  --orchid:#9a72b8;
  --orchid-deep:#6e4f8c;
  --lavender:#c0a8da;
  --wax:#6a2c46;
  --wax-hi:#8a3a5c;
  /* text on dark */
  --bone:#ede0c8;
  --bone-dim:#c2ad9e;
  --muted:#9a8478;
  --r-lg:22px; --r-md:14px; --r-sm:9px;
  --serif:'Cormorant Garamond',Georgia,serif;
  --body:'EB Garamond',Georgia,serif;
  --script:'Pinyon Script',cursive;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);
  color:var(--bone);
  background:
    radial-gradient(125% 95% at 50% -10%, #3a2433 0%, #271621 40%, #190e16 74%, #120a10 100%);
  background-attachment:fixed;
  min-height:100vh;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}

/* ─── shared atoms ─── */
.smallcaps{font-family:var(--body);text-transform:uppercase;letter-spacing:.22em;font-size:11px;font-weight:600;color:var(--gold)}
.script{font-family:var(--script)}
.serif{font-family:var(--serif)}
.flourish{color:var(--gold);opacity:.85;font-size:13px;letter-spacing:.3em}
.starfield{position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    radial-gradient(1.4px 1.4px at 12% 22%, rgba(230,205,146,.8) 0, transparent 100%),
    radial-gradient(1.2px 1.2px at 78% 14%, rgba(230,205,146,.6) 0, transparent 100%),
    radial-gradient(1.1px 1.1px at 33% 64%, rgba(230,205,146,.5) 0, transparent 100%),
    radial-gradient(1.3px 1.3px at 64% 78%, rgba(230,205,146,.55) 0, transparent 100%),
    radial-gradient(1px 1px at 88% 56%, rgba(230,205,146,.5) 0, transparent 100%),
    radial-gradient(1px 1px at 50% 8%, rgba(230,205,146,.45) 0, transparent 100%),
    radial-gradient(1.1px 1.1px at 22% 88%, rgba(230,205,146,.45) 0, transparent 100%);
}

/* ════════════ PAGE / PRESENTATION SHELL ════════════ */
.page{position:relative;z-index:1;max-width:1400px;margin:0 auto;padding:54px 28px 100px}
.page-head{text-align:center;margin-bottom:14px}
.page-kicker{font-family:var(--body);text-transform:uppercase;letter-spacing:.4em;font-size:11px;color:var(--gold-dim);margin-bottom:18px}
.page-title{font-family:var(--serif);font-weight:600;font-size:clamp(2.4rem,6vw,4rem);line-height:1.04;color:var(--bone);letter-spacing:.01em}
.page-title em{font-style:italic;color:var(--gold-bright)}
.page-sub{font-family:var(--serif);font-style:italic;font-size:clamp(1.05rem,2.2vw,1.4rem);color:var(--bone-dim);margin-top:10px}
.rule{display:flex;align-items:center;justify-content:center;gap:14px;color:var(--gold);margin:26px auto 0;max-width:340px}
.rule::before,.rule::after{content:'';height:1px;flex:1;background:linear-gradient(90deg,transparent,var(--gold-line),transparent)}

.section-label{display:flex;align-items:center;gap:16px;margin:64px 0 26px}
.section-label .n{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:1.5rem;opacity:.9}
.section-label h2{font-family:var(--serif);font-weight:600;font-size:1.7rem;color:var(--bone);white-space:nowrap}
.section-label::after{content:'';height:1px;flex:1;background:linear-gradient(90deg,var(--gold-line),transparent)}

/* ─── design-note card (junior designer to manager) ─── */
.note-card{background:var(--panel-2);border:1px solid var(--gold-line);border-radius:var(--r-lg);padding:30px 34px;
  box-shadow:0 24px 60px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.03)}
.note-card h3{font-family:var(--serif);font-size:1.5rem;color:var(--gold-bright);font-weight:600;margin-bottom:4px}
.note-card .who{font-size:13px;color:var(--muted);font-style:italic;margin-bottom:18px}
.note-card p{font-size:1.05rem;color:var(--bone-dim);margin-bottom:13px;max-width:74ch;clear:both}
.note-card p strong{color:var(--bone);font-weight:600}
.note-card .lede::first-letter{font-family:var(--serif);font-size:3.2rem;float:left;line-height:.8;color:var(--gold);padding:6px 10px 0 0;font-weight:600}
.note-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:22px}
.note-pill{border:1px solid var(--gold-line-soft);border-radius:var(--r-md);padding:15px 17px;background:rgba(20,12,30,.4)}
.note-pill h4{font-family:var(--body);text-transform:uppercase;letter-spacing:.14em;font-size:10.5px;color:var(--gold);margin-bottom:7px;font-weight:600}
.note-pill p{font-size:.96rem;color:var(--bone-dim);margin:0}

/* ─── swatch row ─── */
.spec-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}
.spec{background:var(--panel);border:1px solid var(--gold-line);border-radius:var(--r-md);padding:22px;box-shadow:0 14px 40px rgba(0,0,0,.3)}
.spec .cap{font-family:var(--body);text-transform:uppercase;letter-spacing:.18em;font-size:10px;color:var(--gold-dim);margin-bottom:16px}
.swatches{display:flex;gap:10px;flex-wrap:wrap}
.sw{width:60px}
.sw i{display:block;height:54px;border-radius:8px;border:1px solid rgba(255,255,255,.08);box-shadow:inset 0 1px 0 rgba(255,255,255,.08)}
.sw span{display:block;font-size:9.5px;color:var(--muted);margin-top:6px;text-align:center;letter-spacing:.02em}
.type-spec p{margin:0}
.type-xl{font-family:var(--serif);font-size:2.6rem;color:var(--bone);line-height:1.05}
.type-xl em{font-style:italic;color:var(--gold-bright)}
.type-script{font-family:var(--script);font-size:2rem;color:var(--gold-bright);line-height:1.2;margin-top:6px}
.type-body{font-family:var(--body);font-size:1.05rem;color:var(--bone-dim);margin-top:10px}
.type-sc{margin-top:12px}

/* component preview chips */
.comp-row{display:flex;gap:18px;flex-wrap:wrap;align-items:flex-end}
.comp{display:flex;flex-direction:column;align-items:center;gap:9px}
.comp small{font-size:10px;color:var(--muted);letter-spacing:.04em}

/* ════════════ DEVICE FRAME ════════════ */
.stage{display:flex;flex-wrap:wrap;gap:46px;justify-content:center;align-items:flex-start}
.device-col{display:flex;flex-direction:column;align-items:center;gap:16px}
.device-tag{font-family:var(--body);text-transform:uppercase;letter-spacing:.2em;font-size:11px;color:var(--gold-dim)}
.phone{
  width:390px;flex:0 0 390px;height:844px;border-radius:54px;
  background:linear-gradient(150deg,#241a30,#0c0812);
  padding:13px;position:relative;
  box-shadow:0 0 0 2px #2c2438, 0 0 0 6px #0a0710, 0 40px 90px rgba(0,0,0,.6),
    inset 0 0 4px rgba(255,255,255,.08);
}
.phone-screen{position:relative;width:100%;height:100%;border-radius:42px;overflow:hidden;
  background:radial-gradient(130% 80% at 50% -8%, #36202f 0%, #241520 42%, #190e16 78%, #120a10 100%);
  display:flex;flex-direction:column}
.phone-notch{position:absolute;top:0;left:50%;transform:translateX(-50%);width:138px;height:30px;
  background:#0a0710;border-radius:0 0 18px 18px;z-index:40}
.statusbar{position:relative;z-index:30;display:flex;justify-content:space-between;align-items:center;
  padding:14px 30px 4px;font-family:var(--body);font-size:14px;font-weight:600;color:var(--bone);flex:0 0 auto}
.statusbar .icons{display:flex;gap:6px;align-items:center}
.statusbar svg{width:17px;height:17px;fill:var(--bone)}

/* scroll body */
.screen-scroll{flex:1;overflow-y:auto;overflow-x:hidden;scrollbar-width:none}
.screen-scroll::-webkit-scrollbar{display:none}
.screen{display:none;padding:6px 18px 26px}
.screen.active{display:block;animation:fade .4s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ─── app top bar (crest) ─── */
.appbar{display:flex;align-items:center;justify-content:space-between;padding:6px 2px 2px}
.appbar .ic-btn{width:34px;height:34px;display:grid;place-items:center;border-radius:10px;cursor:pointer;
  color:var(--gold);background:transparent;border:1px solid transparent;transition:.2s}
.appbar .ic-btn:hover{border-color:var(--gold-line);background:rgba(201,162,90,.06)}
.appbar .ic-btn svg{width:21px;height:21px}
.wordmark{display:flex;flex-direction:column;align-items:center;gap:2px}
.wordmark .crestline{display:flex;align-items:center;gap:8px;color:var(--gold);opacity:.8}
.wordmark .crestline svg{width:12px;height:12px}
.wordmark h1{font-family:var(--serif);font-weight:600;font-size:1.18rem;letter-spacing:.16em;color:var(--bone);text-transform:uppercase;line-height:1;text-align:center}
.dot-badge{position:absolute;top:7px;right:9px;width:7px;height:7px;border-radius:50%;background:var(--orchid);box-shadow:0 0 7px var(--orchid)}

/* ─── ornamental frame mixin ─── */
.frame{position:relative;border:1px solid var(--gold-line);border-radius:var(--r-md);background:var(--panel)}
.frame::before{content:'';position:absolute;inset:4px;border:1px solid var(--gold-line-soft);border-radius:calc(var(--r-md) - 4px);pointer-events:none}
.corner{position:absolute;color:var(--gold);font-size:11px;opacity:.6;line-height:1}
.corner.tl{top:5px;left:7px}.corner.tr{top:5px;right:7px}
.corner.bl{bottom:5px;left:7px}.corner.br{bottom:5px;right:7px}

/* ════════════ HOME ════════════ */
.profile-crest{display:flex;flex-direction:column;align-items:center;margin:14px 0 6px;position:relative}
.portrait{width:92px;height:92px;border-radius:50%;position:relative;
  background:linear-gradient(160deg,#3a2a4e,#241733);border:2px solid var(--gold);
  box-shadow:0 0 0 5px rgba(201,162,90,.12),0 10px 30px rgba(0,0,0,.4);
  display:grid;place-items:center;overflow:hidden}
.portrait .ph{font-family:var(--script);font-size:2.1rem;color:var(--gold-bright);opacity:.9}
.portrait img{width:100%;height:100%;object-fit:cover}
.profile-wings{position:absolute;top:46px;color:var(--gold);opacity:.45;display:flex;gap:108px}
.profile-wings svg{width:54px;height:30px}
.greeting{text-align:center;margin:18px 4px 4px}
.greeting h2{font-family:var(--serif);font-size:1.9rem;font-weight:600;color:var(--bone);line-height:1.12}
.greeting h2 em{font-style:italic;color:var(--gold-bright)}
.greeting p{font-family:var(--serif);font-style:italic;color:var(--bone-dim);font-size:1.05rem;margin-top:2px}

/* parchment card */
.parch{position:relative;border-radius:var(--r-sm);color:var(--sepia);
  background:
    radial-gradient(120% 130% at 18% 8%, rgba(255,250,235,.55), transparent 45%),
    radial-gradient(90% 90% at 92% 96%, rgba(120,96,58,.35), transparent 50%),
    linear-gradient(155deg,#e2d2af 0%,#d3c195 48%,#c5b187 100%);
  box-shadow:0 12px 30px rgba(0,0,0,.4),inset 0 0 0 1px rgba(120,96,58,.4),inset 0 0 26px rgba(120,96,58,.22);
  border:1px solid #8f7a4f}
.parch::after{content:'';position:absolute;inset:4px;border:1px solid rgba(120,96,58,.45);border-radius:5px;pointer-events:none}
.parch .pc-cap{font-family:var(--body);text-transform:uppercase;letter-spacing:.2em;font-size:10px;color:var(--sepia-soft);font-weight:600}

/* stat cards row */
.stat-row{display:grid;grid-template-columns:1fr 1fr;gap:13px;margin-top:18px}
.stat{padding:18px 14px 16px;text-align:center}
.stat .pc-cap{margin-bottom:6px}
.stat .big{font-family:var(--serif);font-size:3.1rem;font-weight:600;line-height:.9;color:var(--sepia)}
.stat .unit{font-family:var(--serif);font-style:italic;font-size:1.1rem;color:var(--sepia-soft)}
.stat .meta{font-size:11px;color:var(--sepia-soft);margin-top:8px;letter-spacing:.02em}
.stat .sprig{margin:8px auto 2px;width:46px;height:18px;color:var(--orchid-deep);opacity:.8}
.arch{border-radius:38px 38px var(--r-sm) var(--r-sm)}

/* generic dark section card */
.card{background:var(--panel);border:1px solid var(--gold-line);border-radius:var(--r-md);padding:16px 16px 17px;margin-top:16px;
  box-shadow:0 12px 34px rgba(0,0,0,.28)}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:13px}
.card-head .smallcaps{display:flex;align-items:center;gap:8px}
.card-head .smallcaps svg{width:14px;height:14px;color:var(--gold)}
.link{font-family:var(--body);font-size:12px;color:var(--gold-dim);letter-spacing:.04em;cursor:pointer;display:inline-flex;align-items:center;gap:4px;white-space:nowrap}
.link:hover{color:var(--gold-bright)}

/* mini calendar strip */
.cal-nav{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:10px}
.cal-nav .m{font-family:var(--serif);font-style:italic;font-size:1.15rem;color:var(--gold-bright);white-space:nowrap}
.cal-nav svg{width:14px;height:14px;color:var(--gold);cursor:pointer}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;text-align:center}
.cal-grid .dow{font-size:8.5px;letter-spacing:.08em;color:var(--gold-dim);text-transform:uppercase;padding-bottom:4px}
.cal-grid .d{font-family:var(--serif);font-size:.96rem;color:var(--bone-dim);padding:5px 0;border-radius:7px;position:relative;cursor:pointer}
.cal-grid .d:hover{background:rgba(201,162,90,.08)}
.cal-grid .d.muted{color:var(--muted);opacity:.4}
.cal-grid .d.today{color:var(--ink);background:radial-gradient(circle,var(--gold-bright),var(--gold));font-weight:600;box-shadow:0 0 12px rgba(201,162,90,.5)}
.cal-grid .d.evt::after{content:'';position:absolute;bottom:2px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--orchid)}

/* love note (parchment with wax seal) */
.note-paper{padding:20px 22px 22px;margin-top:14px;text-align:center;position:relative;min-height:120px}
.note-paper .quote{font-family:var(--script);font-size:1.7rem;color:#4a3a24;line-height:1.25;margin:6px 18px}
.note-paper .sign{font-family:var(--script);font-size:1.15rem;color:var(--sepia-soft);margin-top:10px}
.note-paper .heart-min{color:var(--wax);font-size:14px;margin:6px 0}
.wax{position:absolute;width:54px;height:54px;border-radius:50%;
  background:radial-gradient(circle at 38% 32%,var(--wax-hi),var(--wax) 55%,#491e32 100%);
  box-shadow:0 6px 16px rgba(0,0,0,.45),inset 0 2px 6px rgba(255,255,255,.18),inset 0 -4px 8px rgba(0,0,0,.4);
  display:grid;place-items:center;color:rgba(255,225,238,.65)}
.wax svg{width:26px;height:26px}
.wax.br{bottom:-14px;right:-8px}

/* list rows (date ideas / notifications) */
.row{display:flex;align-items:center;gap:13px;padding:13px 4px;border-bottom:1px solid var(--gold-line-soft)}
.row:last-child{border-bottom:none}
.row .glyph{width:42px;height:42px;flex:0 0 42px;border-radius:11px;display:grid;place-items:center;
  border:1px solid var(--gold-line);background:radial-gradient(circle at 50% 30%,rgba(201,162,90,.14),rgba(20,12,30,.5));color:var(--gold)}
.row .glyph svg{width:23px;height:23px}
.row .rbody{flex:1;min-width:0}
.row .rtitle{font-family:var(--serif);font-size:1.15rem;color:var(--bone);font-weight:600;line-height:1.15}
.row .rsub{font-size:.92rem;color:var(--bone-dim);line-height:1.3;margin-top:1px}
.row .rtime{font-size:10px;color:var(--muted);flex:0 0 auto;align-self:flex-start;margin-top:3px}
.bookmark{color:var(--gold-dim);cursor:pointer;flex:0 0 auto}
.bookmark svg{width:19px;height:19px}
.bookmark.on{color:var(--gold-bright)}

/* countdown mini rows */
.cd-row{display:flex;align-items:center;gap:13px;padding:11px 0;border-bottom:1px solid var(--gold-line-soft)}
.cd-row:last-child{border-bottom:none}
.cd-row .moon-ic{width:38px;height:38px;color:var(--gold);flex:0 0 38px}
.cd-row .cd-name{font-family:var(--serif);font-size:1.1rem;color:var(--bone)}
.cd-row .cd-days{font-family:var(--serif);font-size:1.5rem;color:var(--gold-bright);font-weight:600;margin-left:auto;line-height:1}
.cd-row .cd-days small{font-family:var(--body);font-size:.7rem;font-style:italic;color:var(--bone-dim)}
.cd-row .cd-date{font-size:11px;color:var(--muted);display:block;text-align:right}

/* ════════════ DATE IDEAS ════════════ */
.screen-head{text-align:center;padding:8px 0 2px}
.screen-head .smallcaps{color:var(--gold-dim)}
.screen-head h2{font-family:var(--serif);font-size:1.85rem;font-weight:600;color:var(--bone);margin-top:4px}
.screen-head h2 em{font-style:italic;color:var(--gold-bright)}
.screen-head p{font-family:var(--serif);font-style:italic;color:var(--bone-dim);font-size:1rem;margin-top:2px}
.seg{display:flex;gap:7px;flex-wrap:wrap;justify-content:center;margin:16px 0 4px}
.seg button{font-family:var(--body);font-size:12px;letter-spacing:.05em;color:var(--bone-dim);background:transparent;
  border:1px solid var(--gold-line);border-radius:999px;padding:6px 14px;cursor:pointer;transition:.2s}
.seg button:hover{border-color:var(--gold);color:var(--bone)}
.seg button.on{background:rgba(201,162,90,.14);border-color:var(--gold);color:var(--gold-bright)}

.idea{position:relative;display:flex;gap:14px;padding:16px;margin-top:14px;cursor:pointer;transition:.2s}
.idea:hover{border-color:var(--gold-line);transform:translateY(-2px)}
.idea.picked{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold-line),0 14px 34px rgba(0,0,0,.4)}
.idea .cloche{width:64px;height:64px;flex:0 0 64px;border-radius:12px;display:grid;place-items:center;
  border:1px solid var(--gold-line);background:radial-gradient(circle at 50% 26%,rgba(201,162,90,.16),rgba(18,11,28,.6));color:var(--gold)}
.idea .cloche svg{width:38px;height:38px}
.idea .ibody{flex:1;min-width:0;padding-right:30px}
.idea .ititle{font-family:var(--serif);font-size:1.3rem;font-weight:600;color:var(--bone);line-height:1.1}
.idea .idesc{font-size:.96rem;color:var(--bone-dim);line-height:1.34;margin:4px 0 11px;padding-right:0}
.tags{display:flex;flex-wrap:wrap;gap:5px}
.tag{font-family:var(--body);font-size:10px;text-transform:uppercase;letter-spacing:.1em;padding:3px 9px;border-radius:999px;border:1px solid var(--gold-line-soft);color:var(--gold-dim)}
.tag.food{color:#cf9bb0;border-color:rgba(207,155,176,.3)}
.tag.cozy{color:var(--lavender);border-color:rgba(185,166,212,.3)}
.tag.air{color:#9ab4cf;border-color:rgba(154,180,207,.3)}
.idea .cost{position:absolute;top:14px;right:14px;font-family:var(--serif);font-size:1.05rem;color:var(--gold);letter-spacing:.04em}
.idea .seal-pick{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:50%;display:none;place-items:center;
  background:radial-gradient(circle at 38% 32%,var(--wax-hi),var(--wax) 60%);color:rgba(255,225,238,.8);box-shadow:0 4px 12px rgba(0,0,0,.4)}
.idea.picked .seal-pick{display:grid}.idea.picked .cost{display:none}
.idea .seal-pick svg{width:18px;height:18px}

/* availability mini */
.avail{margin-top:18px;padding:18px}
.avail h4{font-family:var(--serif);font-size:1.15rem;color:var(--bone);margin-bottom:3px;display:flex;align-items:center;gap:8px}
.avail h4 svg{width:16px;height:16px;color:var(--gold)}
.avail .hint{font-size:.9rem;color:var(--bone-dim);font-style:italic;margin-bottom:13px}
.chip-grid{display:flex;flex-wrap:wrap;gap:7px}
.chip{font-family:var(--body);font-size:12px;color:var(--bone-dim);border:1px solid var(--gold-line);border-radius:8px;padding:8px 13px;cursor:pointer;transition:.18s}
.chip:hover{border-color:var(--gold);color:var(--bone)}
.chip.on{background:rgba(154,114,184,.2);border-color:var(--orchid);color:var(--lavender)}
.chip.on.gold{background:rgba(201,162,90,.16);border-color:var(--gold);color:var(--gold-bright)}
.cta{margin-top:16px;width:100%;padding:14px;border:none;border-radius:12px;cursor:pointer;
  font-family:var(--serif);font-size:1.15rem;font-weight:600;letter-spacing:.04em;color:#1c1226;
  background:linear-gradient(150deg,var(--gold-bright),var(--gold) 55%,var(--gold-dim));
  box-shadow:0 12px 28px rgba(201,162,90,.28);transition:.2s}
.cta:hover{transform:translateY(-2px);box-shadow:0 16px 36px rgba(201,162,90,.4)}

/* ════════════ OUR VAULT ════════════ */
.vault-grid{display:grid;grid-template-columns:1fr 1fr;gap:13px;margin-top:16px}
.vault-tile{position:relative;border:1px solid var(--gold-line);border-radius:var(--r-md);padding:18px 15px 16px;cursor:pointer;
  background:linear-gradient(160deg,rgba(48,32,68,.6),rgba(22,14,34,.6));transition:.22s;overflow:hidden}
.vault-tile::before{content:'';position:absolute;inset:4px;border:1px solid var(--gold-line-soft);border-radius:9px;pointer-events:none}
.vault-tile:hover{transform:translateY(-3px);border-color:var(--gold)}
.vault-tile .bottle{width:46px;height:54px;margin-bottom:10px;color:var(--gold)}
.vault-tile h4{font-family:var(--serif);font-size:1.18rem;font-weight:600;color:var(--bone);line-height:1.08}
.vault-tile p{font-size:.86rem;color:var(--bone-dim);line-height:1.3;margin-top:3px}
.vault-tile .cnt{position:absolute;top:12px;right:13px;font-family:var(--serif);font-size:1.05rem;color:var(--gold-bright)}
.vault-tile.wide{grid-column:1/-1;display:flex;align-items:center;gap:16px;padding:16px 18px}
.vault-tile.wide .bottle{margin-bottom:0;flex:0 0 auto}
.vault-tile.wide .vt-body{flex:1}

/* photo book mini strip */
.photo-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-top:12px}
.photo{aspect-ratio:1;border-radius:9px;border:1px solid var(--gold-line);position:relative;overflow:hidden;
  background:repeating-linear-gradient(45deg,#2a1d3e,#2a1d3e 7px,#251934 7px,#251934 14px);display:grid;place-items:center}
.photo span{font-family:var(--body);font-size:8.5px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}
.photo.taped::before{content:'';position:absolute;top:-6px;left:50%;transform:translateX(-50%) rotate(-3deg);width:34px;height:13px;background:rgba(220,204,170,.3);border:1px solid rgba(201,162,90,.2)}

/* ════════════ BOTTOM NAV ════════════ */
.tabbar{flex:0 0 auto;display:flex;justify-content:space-around;align-items:center;padding:10px 8px 26px;
  background:linear-gradient(0deg,rgba(16,10,26,.96),rgba(16,10,26,.7));
  border-top:1px solid var(--gold-line);backdrop-filter:blur(6px);position:relative}
.tabbar::before{content:'❧';position:absolute;top:-1px;left:50%;transform:translate(-50%,-60%);color:var(--gold);font-size:13px;background:#160e23;padding:0 10px}
.tab{display:flex;flex-direction:column;align-items:center;gap:4px;background:none;border:none;cursor:pointer;
  color:var(--muted);transition:.2s;flex:1;padding:2px 0}
.tab svg{width:23px;height:23px}
.tab span{font-family:var(--body);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase}
.tab.on{color:var(--gold-bright)}
.tab.on svg{filter:drop-shadow(0 0 7px rgba(201,162,90,.5))}

/* footer ornament */
.foot-orn{text-align:center;color:var(--gold-dim);font-family:var(--body);text-transform:uppercase;
  letter-spacing:.34em;font-size:10.5px;margin:48px 0 0;display:flex;align-items:center;justify-content:center;gap:14px}
.foot-orn::before,.foot-orn::after{content:'❦';font-size:12px;color:var(--gold);opacity:.7}

@media(max-width:520px){
  .page{padding:34px 16px 80px}
  .phone{width:100%;max-width:390px;flex-basis:auto}
}
