/* ════════════════════════════════════════════════════════════
   THE GARDEN OF US — application shell
   Responsive: sidebar dashboard on desktop, bottom-nav on mobile.
   Builds on garden/styles.css (tokens + atoms) + garden/dashboard.css.
   ════════════════════════════════════════════════════════════ */
/* ─── PREVENT APP FLASH BEFORE AUTH ─── */
html:not(.app-ready) .app-shell,
html:not(.app-ready) .app-bottomnav{visibility:hidden}
.app-shell{position:relative;z-index:1;display:flex;min-height:100vh;max-width:1340px;margin:0 auto}

/* ─── SIDEBAR (desktop) ─── */
.app-sidebar{flex:0 0 244px;position:sticky;top:0;align-self:flex-start;height:100vh;overflow-y:auto;
  padding:28px 20px;display:flex;flex-direction:column;border-right:1px solid var(--gold-line);
  background:linear-gradient(180deg,rgba(20,11,17,.45),rgba(20,11,17,.05));scrollbar-width:none}
.app-sidebar::-webkit-scrollbar{display:none}
.app-sidebar .crest .emblem{width:104px;height:116px}
.app-nav{margin-top:20px;display:flex;flex-direction:column;gap:3px}

/* ─── TOP BAR (mobile only) ─── */
.app-topbar{display:none;position:sticky;top:0;z-index:30;align-items:center;justify-content:space-between;
  padding:12px 18px;background:linear-gradient(180deg,rgba(20,11,17,.96),rgba(20,11,17,.7));
  backdrop-filter:blur(8px);border-bottom:1px solid var(--gold-line)}
.app-topbar .tb-crest{display:flex;flex-direction:column;align-items:center;gap:1px}
.app-topbar .tb-crest .cl{display:flex;gap:7px;color:var(--gold);opacity:.8}
.app-topbar .tb-crest .cl svg{width:11px;height:11px}
.app-topbar .tb-crest h1{font-family:var(--serif);font-weight:600;font-size:1.02rem;letter-spacing:.13em;
  color:var(--bone);text-transform:uppercase;line-height:1}
.app-topbar .ic-btn{width:38px;height:38px;display:grid;place-items:center;border-radius:10px;cursor:pointer;
  color:var(--gold);border:1px solid transparent;background:none;position:relative}
.app-topbar .ic-btn:hover{border-color:var(--gold-line)}
.app-topbar .ic-btn svg{width:22px;height:22px}

/* ─── BOTTOM NAV (mobile only) ─── */
.app-bottomnav{display:none;position:fixed;left:0;right:0;bottom:0;z-index:40;justify-content:space-around;
  align-items:center;padding:9px 6px calc(8px + env(safe-area-inset-bottom));
  background:linear-gradient(0deg,rgba(16,9,14,.98),rgba(16,9,14,.82));
  border-top:1px solid var(--gold-line);backdrop-filter:blur(8px)}
.app-bottomnav .tab{display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:none;
  cursor:pointer;color:var(--muted);flex:1;padding:2px 0;transition:.2s}
.app-bottomnav .tab svg{width:23px;height:23px}
.app-bottomnav .tab span{font-family:var(--body);font-size:9.5px;letter-spacing:.07em;text-transform:uppercase}
.app-bottomnav .tab.on{color:var(--gold-bright)}
.app-bottomnav .tab.on svg{filter:drop-shadow(0 0 6px rgba(201,160,90,.5))}

/* ─── MAIN ─── */
.app-main{flex:1;min-width:0;padding:32px 40px 80px;position:relative}
.view{display:none;opacity:1}
.view.active{display:block}
@media (prefers-reduced-motion: no-preference){
  .view.active{animation:vfade .35s ease}
}
@keyframes vfade{from{transform:translateY(8px)}to{transform:none}}

/* view header */
.view-head{margin-bottom:24px}
.view-head .vh-kicker{font-family:var(--body);text-transform:uppercase;letter-spacing:.28em;font-size:11px;color:var(--gold-dim);margin-bottom:8px}
.view-head h2{font-family:var(--serif);font-size:2.4rem;font-weight:600;color:var(--bone);line-height:1.04}
.view-head h2 em{font-style:italic;color:var(--gold-bright)}
.view-head p{font-family:var(--serif);font-style:italic;color:var(--bone-dim);font-size:1.12rem;margin-top:3px}
.view-back{display:none;align-items:center;gap:7px;font-family:var(--body);font-size:13px;color:var(--gold-dim);
  cursor:pointer;margin-bottom:16px;letter-spacing:.04em}
.view-back svg{width:15px;height:15px}
.view-back:hover{color:var(--gold-bright)}

/* generic content card */
.c-card{background:var(--panel);border:1px solid var(--gold-line);border-radius:14px;padding:20px 22px;margin-bottom:18px;
  position:relative;box-shadow:0 14px 38px rgba(0,0,0,.26)}
.c-card.tight{padding:6px 18px}
.c-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.c-card-head .smallcaps{display:flex;align-items:center;gap:8px}
.c-card-head .smallcaps svg{width:15px;height:15px;color:var(--gold)}

/* list rows (bucket, wishlist, watch/read, etc.) */
.lrow{display:flex;align-items:center;gap:13px;padding:14px 2px;border-bottom:1px solid var(--gold-line-soft)}
.lrow:last-child{border-bottom:none}
/* icon sizing safety net — list-row icon chips must never blow up */
.lrow .dcloche svg,
.lrow .dcd-ic svg,
.dcd-ic svg{width:22px;height:22px}
.lrow .dcloche,
.lrow .dcd-ic{display:grid;place-items:center;height:42px}
.lcheck{width:24px;height:24px;flex:0 0 24px;border-radius:7px;border:1.5px solid var(--gold-line);cursor:pointer;
  display:grid;place-items:center;color:transparent;transition:.18s}
.lcheck:hover{border-color:var(--gold)}
.lcheck.on{background:rgba(201,160,90,.18);border-color:var(--gold);color:var(--gold-bright)}
.lcheck svg{width:15px;height:15px}
.ltext{flex:1;min-width:0;font-family:var(--serif);font-size:1.2rem;color:var(--bone)}
.lrow.done .ltext{text-decoration:line-through;color:var(--muted)}
.lkind{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);flex:0 0 auto}
.ldel{color:var(--gold-dim);cursor:pointer;flex:0 0 auto;width:30px;height:30px;display:grid;place-items:center;border-radius:8px;background:none;border:none;padding:0;font:inherit;-webkit-appearance:none;appearance:none}
.ldel:hover{color:#d28aa6;background:rgba(210,138,166,.08)}
.ldel svg{width:17px;height:17px;color:inherit}

/* inline add row */
.addbar{display:flex;gap:10px;margin-top:6px}
.input,.textarea,select.input{flex:1;background:rgba(16,9,14,.6);border:1px solid var(--gold-line);border-radius:10px;
  padding:11px 14px;color:var(--bone);font-family:var(--body);font-size:1.02rem;outline:none;transition:.18s;width:100%}
.input::placeholder,.textarea::placeholder{color:var(--muted)}
.input:focus,.textarea:focus,select.input:focus{border-color:var(--gold);background:rgba(16,9,14,.8)}
.textarea{resize:vertical;min-height:96px;line-height:1.5}
.field{margin-bottom:14px}
.field label{display:block;font-family:var(--body);text-transform:uppercase;letter-spacing:.14em;font-size:10.5px;
  color:var(--gold-dim);margin-bottom:7px;font-weight:600}
.btn{padding:11px 22px;border:none;border-radius:11px;cursor:pointer;font-family:var(--serif);font-size:1.1rem;
  font-weight:600;letter-spacing:.03em;color:#1c1014;white-space:nowrap;transition:.2s;
  background:linear-gradient(150deg,var(--gold-bright),var(--gold) 55%,var(--gold-dim));box-shadow:0 8px 22px rgba(201,160,90,.24)}
.btn:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(201,160,90,.36)}
.btn.ghost{background:none;border:1px solid var(--gold-line);color:var(--gold);box-shadow:none}
.btn.ghost:hover{background:rgba(201,160,90,.08);transform:none}
.btn.sm{padding:8px 15px;font-size:.98rem;border-radius:9px}
.btn.block{width:100%;text-align:center;display:block}
.btn svg{width:18px;height:18px;vertical-align:-3px}
.btn.sm svg{width:15px;height:15px;vertical-align:-2px}
.btn.danger{background:none;border:1px solid rgba(210,138,166,.4);color:#d9a3b5;box-shadow:none}
.btn.danger:hover{background:rgba(210,138,166,.1);transform:none}

/* stat / progress */
.progress{height:12px;border-radius:99px;background:rgba(201,160,90,.14);overflow:hidden;border:1px solid var(--gold-line-soft)}
.progress > i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--gold),var(--gold-bright))}
.kv{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}
.kv .big{font-family:var(--serif);font-size:2.4rem;font-weight:600;color:var(--gold-bright);line-height:1}
.kv .sub{font-family:var(--serif);font-style:italic;color:var(--bone-dim)}

/* vault grid (reuses .vault-tile from styles.css) */
.app-vault-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}

/* memory photo grid */
.mem-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.mem{position:relative;border-radius:11px;overflow:hidden;border:1px solid var(--gold-line);aspect-ratio:1;
  background:repeating-linear-gradient(45deg,#2a1b26,#2a1b26 7px,#241620 7px,#241620 14px);display:grid;place-items:center;cursor:pointer}
.mem img{width:100%;height:100%;object-fit:cover}
.mem .mem-cap{position:absolute;left:0;right:0;bottom:0;padding:7px 9px;font-family:var(--serif);font-size:.92rem;color:#fff;
  background:linear-gradient(0deg,rgba(0,0,0,.75),transparent)}
.mem.add{color:var(--gold-dim);flex-direction:column;gap:6px;font-family:var(--body);font-size:11px;letter-spacing:.06em;text-transform:uppercase}
.mem.add svg{width:26px;height:26px}

/* MODAL */
.modal-bg{position:fixed;inset:0;z-index:90;background:rgba(10,6,10,.7);backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;padding:20px}
.modal-bg.open{display:flex;animation:vfade .25s ease}
.modal{width:100%;max-width:480px;max-height:88vh;overflow-y:auto;border:1px solid var(--gold-line);border-radius:18px;
  padding:26px 28px;background:radial-gradient(120% 80% at 50% 0%,#2e1b28,#1c1018);box-shadow:0 40px 100px rgba(0,0,0,.6);scrollbar-width:thin}
.modal h3{font-family:var(--serif);font-size:1.7rem;font-weight:600;color:var(--gold-bright);margin-bottom:4px}
.modal .msub{font-family:var(--serif);font-style:italic;color:var(--bone-dim);margin-bottom:18px}
.modal .mclose{position:absolute;top:18px;right:20px;color:var(--muted);cursor:pointer;font-size:22px;background:none;border:none}
.modal-actions{display:flex;gap:10px;margin-top:20px}
.modal-actions .btn{flex:1;text-align:center}

/* ─── MOBILE MODAL BOTTOM-SHEET ─── */
@media(max-width:860px){
  .modal-bg{align-items:flex-end;padding:0}
  .modal{border-radius:22px 22px 0 0;max-height:94vh;width:100%;max-width:100%;
    border-bottom:none;padding:20px 20px 32px}
  .modal h3{font-size:1.55rem}
}
/* ─── FILTER BAR HORIZONTAL SCROLL (mobile) ─── */
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px;align-items:center}
@media(max-width:860px){
  .filter-bar{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;
    padding-bottom:6px;margin-left:-16px;margin-right:-16px;padding-left:16px;padding-right:16px;scrollbar-width:none}
  .filter-bar::-webkit-scrollbar{display:none}
  .filter-bar .fsel,.filter-bar .chip{flex-shrink:0}
}
/* ─── VAULT SECTION HEADERS ─── */
.vault-section-head{font-family:var(--body);text-transform:uppercase;letter-spacing:.22em;
  font-size:10px;color:var(--gold-dim);margin:20px 0 10px;padding-bottom:6px;
  border-bottom:1px solid var(--gold-line-soft)}
.vault-section-head:first-child{margin-top:0}
/* ─── DESKTOP 2-COL ─── */
@media(min-width:861px){
  .two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px}
  .two-col .c-card{margin-bottom:0}
  .settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}
  .settings-grid .c-card{margin-bottom:0}
}
/* ─── BETTER TOUCH TARGETS ON MOBILE ─── */
@media(max-width:860px){
  .lcheck{width:32px;height:32px;flex:0 0 32px;border-radius:9px}
  .ldel{width:38px;height:38px}
  .lrow{padding:16px 2px}
  .nav-item,.app-bottomnav .tab{min-height:44px}
  .btn{min-height:44px}
}
/* ─── VAULT TILE IMPROVEMENTS ─── */
.app-vault-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
@media(min-width:861px){.app-vault-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}}
/* ─── BUDGET TOTALS ─── */
.budget-totals{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:18px}
@media(min-width:861px){.budget-totals{grid-template-columns:repeat(4,1fr)}}
.bt-card{background:var(--panel);border:1px solid var(--gold-line);border-radius:14px;padding:16px 18px;text-align:center}
.bt-card .big{font-family:var(--serif);font-size:1.9rem;font-weight:600;color:var(--gold-bright);line-height:1}
.bt-card .lbl{font-family:var(--body);font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-top:4px}
/* ─── ICON BASE ─── */
svg.ic{width:20px;height:20px;flex-shrink:0;vertical-align:-3px}
/* ─── HOME BOTTOM CARDS (spark + conjure) ─── */
.home-bot-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:18px}
@media(max-width:860px){ .home-bot-cards{grid-template-columns:1fr} }
.spark-card{background:linear-gradient(140deg,rgba(50,25,45,.65),rgba(28,12,24,.8));border-color:rgba(201,160,90,.3)}
.conjure-card{background:linear-gradient(140deg,rgba(35,20,50,.65),rgba(20,12,28,.8));border-color:rgba(192,168,218,.28)}
/* ─── FIX: SVG icons inside .btn keep correct size ─── */
.btn svg.ic{vertical-align:-2px;width:18px;height:18px}
.btn.sm svg.ic{width:16px;height:16px;vertical-align:-2px}
/* ─── FIX: nav-item SVG should be 20px ─── */
.nav-item svg{width:20px;height:20px;flex-shrink:0;color:var(--gold-dim)}
.nav-item.active svg{color:var(--gold-bright)}
/* ─── FIX: bottom-nav tab SVG ─── */
.app-bottomnav .tab svg{width:24px;height:24px}
/* ─── FIX: smallcaps icon ─── */
.smallcaps svg.ic{width:16px;height:16px;vertical-align:-2px}
/* ─── FIX: ni (notification) icon ─── */
.ni svg.ic{width:18px;height:18px}
.chart-tabs{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:0}
.chart-tab{padding:7px 14px;border-radius:999px;border:1px solid var(--gold-line-soft);background:none;
  font-family:var(--body);font-size:12.5px;cursor:pointer;color:var(--bone-dim);transition:.18s;letter-spacing:.03em}
.chart-tab:hover{border-color:var(--gold-line);color:var(--bone)}
.chart-tab.on{background:rgba(201,160,90,.15);border-color:var(--gold);color:var(--gold-bright);font-weight:600}
/* ─── TONIGHT'S SPARK ─── */
@media(max-width:860px){
  .chart-tabs{overflow-x:auto;flex-wrap:nowrap;scrollbar-width:none;-webkit-overflow-scrolling:touch}
  .chart-tabs::-webkit-scrollbar{display:none}
  .chart-tab{flex-shrink:0}
}
/* ─── PULSE HOME QUICK BUTTONS ─── */
.pulse-home-btn{font-size:1.8rem;background:none;border:2px solid transparent;cursor:pointer;
  opacity:.65;padding:4px 6px;border-radius:10px;transition:.18s;line-height:1}
.pulse-home-btn:hover{opacity:1;border-color:rgba(192,168,218,.4);background:rgba(192,168,218,.1)}
/* ─── GENERAL MOBILE POLISH ─── */
@media(max-width:860px){
  .addbar{flex-wrap:wrap}
  .addbar .btn{width:100%}
  .c-card-head{flex-wrap:wrap;gap:8px}
  .bt-card .big{font-size:1.6rem}
  .view-head h2{font-size:1.75rem}
  .onb-card{padding:28px 20px 24px;max-width:96vw;border-radius:20px}
  .onb-code{font-size:2rem;letter-spacing:.18em;padding:16px 20px}
  .modal{padding:20px 18px 28px}
  .fsel{flex-direction:column}
  .fsel select{width:100%;max-width:none}
}
/* ─── GENERAL DESKTOP POLISH ─── */
@media(min-width:861px){
  .c-card{border-radius:16px}
  .addbar .btn{width:auto;min-width:54px}
  .dash-row.top{grid-template-columns:280px 1fr 1fr}
  .dash-row.bot{grid-template-columns:1fr 1fr 1fr}
}
.pulse-card{background:linear-gradient(135deg,rgba(46,20,38,.7),rgba(28,12,24,.8));border:1px solid rgba(192,168,218,.25);
  border-radius:14px;padding:18px 20px;margin-bottom:18px}
.pulse-emoji-row{display:flex;justify-content:space-between;gap:6px;margin:10px 0 6px}
.pulse-emoji-row span{font-size:1.7rem;cursor:pointer;opacity:.5;transition:.18s;flex:1;text-align:center;border-radius:10px;padding:4px 0}
.pulse-emoji-row span.on{opacity:1;background:rgba(192,168,218,.15)}
.pulse-emoji-row span:hover{opacity:.85}
/* ─── LOVE LANGUAGE QUIZ ─── */
.lang-quiz-row{margin-bottom:18px;padding-bottom:16px;border-bottom:1px solid var(--gold-line-soft)}
.lang-quiz-row:last-of-type{border-bottom:none}
.lang-quiz-title{font-family:var(--serif);font-size:1.15rem;color:var(--bone);font-weight:600;margin-bottom:3px}
.lang-quiz-desc{font-family:var(--body);font-size:.88rem;color:var(--bone-dim);margin-bottom:10px;line-height:1.4}
.lang-num-row{display:flex;gap:8px}
.lang-num{width:44px;height:44px;display:grid;place-items:center;border-radius:10px;
  border:1.5px solid var(--gold-line);background:none;cursor:pointer;font-family:var(--serif);
  font-size:1.3rem;font-weight:600;color:var(--bone-dim);transition:.18s;flex:0 0 44px}
.lang-num:hover{border-color:var(--gold);color:var(--gold)}
.lang-num.on{background:rgba(201,160,90,.18);border-color:var(--gold-bright);color:var(--gold-bright);box-shadow:0 0 14px rgba(201,160,90,.2)}
.lang-num-label{font-family:var(--body);font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);text-align:center;margin-top:3px}
/* onboarding kicker */
.onb-kicker{font-family:var(--body);font-size:11px;text-transform:uppercase;letter-spacing:.22em;color:var(--gold-dim);margin-bottom:8px;text-align:center}
/* profile page */
.profile-duo{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px}
@media(max-width:600px){.profile-duo{grid-template-columns:1fr}}
.pcard{background:var(--panel);border:1px solid var(--gold-line);border-radius:14px;padding:20px;text-align:center}
.pcard .av{width:72px;height:72px;border-radius:50%;margin:0 auto 10px;border:2px solid var(--gold-line);display:grid;place-items:center;overflow:hidden;font-family:var(--serif);font-size:1.6rem;color:var(--gold-bright);background:rgba(201,160,90,.1)}
.pcard .av img{width:100%;height:100%;object-fit:cover}
.pcard .pname{font-family:var(--serif);font-size:1.4rem;color:var(--bone);font-weight:600}
.pcard .ptag{font-family:var(--body);font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--gold-dim);margin-top:4px}
.pcard .plang{font-family:var(--serif);font-style:italic;color:var(--bone-dim);font-size:.95rem;margin-top:8px}

.fab{display:none;place-items:center;position:fixed;right:18px;bottom:84px;z-index:45;width:58px;height:58px;border-radius:50%;border:none;cursor:pointer;
  color:#1c1014;background:linear-gradient(150deg,var(--gold-bright),var(--gold));box-shadow:0 12px 30px rgba(0,0,0,.5)}
.fab svg{width:26px;height:26px}

/* empty state */
.empty{text-align:center;padding:40px 20px;color:var(--bone-dim)}
.empty .e-ic{color:var(--gold);font-size:30px;opacity:.7}
.empty p{font-family:var(--serif);font-style:italic;margin-top:8px}

/* segmented (reuse .seg) spacing in app */
.app-seg{justify-content:flex-start}

/* date-idea filter bar */
.filter-bar{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}
.fsel{display:flex;flex-direction:column;gap:5px}
.fsel > span{font-family:var(--body);text-transform:uppercase;letter-spacing:.12em;font-size:9.5px;color:var(--gold-dim);font-weight:600}
.fsel select.input{padding:8px 30px 8px 12px;font-size:.95rem;min-width:120px;background-image:none}
.idea-meta{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-top:6px;font-family:var(--body);font-size:.85rem;color:var(--gold-dim)}
.idea-meta i{opacity:.5;font-style:normal}
.idea-loc{display:flex;align-items:center;gap:5px;margin-top:6px;font-size:.86rem;color:var(--bone-dim)}
.idea-loc svg{width:13px;height:13px;color:var(--gold-dim)}

/* rich form chips (multi/single select pills) */
.form-chips{gap:7px;max-height:none}
.form-chips .chip{font-size:11.5px;padding:7px 11px}
.form-chips.scroll{max-height:168px;overflow-y:auto;padding:4px;border:1px solid var(--gold-line-soft);border-radius:11px;align-content:flex-start}
.form-chips.scroll::-webkit-scrollbar{width:6px}
.form-chips.scroll::-webkit-scrollbar-thumb{background:var(--gold-line);border-radius:3px}
.emoji-row{gap:6px}
.emoji-chip{font-size:18px;padding:5px 9px;line-height:1}
.emoji-chip.on{background:rgba(201,160,90,.18);border-color:var(--gold);transform:scale(1.08)}
.chip-count{font-family:var(--body);font-size:10px;color:var(--gold-dim);margin-left:6px;letter-spacing:0;text-transform:none}

/* rich list cards (bucket / wishlist / watch&read / idea board) */
.rl-card{background:var(--panel);border:1px solid var(--gold-line);border-radius:13px;padding:15px 16px;margin-bottom:12px;
  box-shadow:0 10px 28px rgba(0,0,0,.22);transition:.18s}
.rl-card:hover{border-color:var(--gold-line)}
.rl-top{display:flex;align-items:flex-start;gap:12px}
.rl-main{flex:1;min-width:0}
.rl-title{font-family:var(--serif);font-size:1.28rem;font-weight:600;color:var(--bone);line-height:1.15}
.rl-card.done .rl-title{text-decoration:line-through;color:var(--muted)}
.rl-badges{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-top:8px;font-family:var(--body);font-size:11px;color:var(--gold-dim)}
.rl-note{font-size:.98rem;color:var(--bone-dim);line-height:1.45;margin-top:9px}
.rl-link{display:inline-flex;align-items:center;gap:5px;margin-top:10px;font-family:var(--body);font-size:12.5px;color:var(--gold);text-decoration:none}
.rl-link svg{width:13px;height:13px}
.rl-link:hover{color:var(--gold-bright)}
.rl-card .lcheck{margin-top:2px}

/* footer ornament inside views */
.view-foot{text-align:center;color:var(--gold-dim);font-family:var(--body);text-transform:uppercase;
  letter-spacing:.32em;font-size:10px;margin-top:40px;opacity:.8}

/* ─── SURVEY ─── */
.star-row{display:flex;gap:6px;margin:4px 0}
.star-btn{font-size:1.8rem;color:var(--gold-dim);background:none;border:none;cursor:pointer;padding:2px 4px;transition:.15s;line-height:1}
.star-btn.lit{color:var(--gold-bright);text-shadow:0 0 10px rgba(234,208,154,.5)}
.star-btn:hover{color:var(--gold-bright)}
.scale-row{display:flex;gap:6px;flex-wrap:wrap;margin:6px 0}
.scale-btn{width:38px;height:38px;border-radius:9px;border:1px solid var(--gold-line);background:none;color:var(--bone-dim);
  font-family:var(--serif);font-size:1.1rem;cursor:pointer;transition:.18s;display:grid;place-items:center}
.scale-btn:hover{border-color:var(--gold);color:var(--gold-bright)}
.scale-btn.on{background:rgba(201,160,90,.18);border-color:var(--gold-bright);color:var(--gold-bright);box-shadow:0 0 10px rgba(201,160,90,.3)}

/* ─── BUDGET / SAVINGS CHARTS ─── */
.chart-wrap{position:relative;height:220px;margin:14px 0 6px}
.chart-legend{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.chart-legend .li{display:flex;align-items:center;gap:6px;font-family:var(--body);font-size:11.5px;color:var(--bone-dim)}
.chart-legend .dot{width:10px;height:10px;border-radius:50%;flex:0 0 10px}
.budget-totals{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px;margin-bottom:20px}
.bt-card{background:var(--panel);border:1px solid var(--gold-line);border-radius:13px;padding:16px 18px;text-align:center}
.bt-card .big{font-family:var(--serif);font-size:2.2rem;font-weight:600;color:var(--gold-bright);line-height:1}
.bt-card .lbl{font-family:var(--body);text-transform:uppercase;letter-spacing:.14em;font-size:10px;color:var(--gold-dim);margin-top:5px}
.chart-tabs{display:flex;gap:8px;margin-bottom:16px}
.chart-tab{font-family:var(--body);font-size:12.5px;padding:6px 14px;border-radius:999px;border:1px solid var(--gold-line);
  color:var(--bone-dim);cursor:pointer;transition:.18s;background:none}
.chart-tab.on{background:rgba(201,160,90,.12);border-color:var(--gold);color:var(--gold-bright)}

/* ─── Icon sizing: prevent overflow in fixed-size containers ─── */
/* Default SVG icon size when used via the icon() helper */
.app-nav svg { width: 18px; height: 18px; flex-shrink: 0; }
.app-bottomnav .tab svg { width: 22px; height: 22px; flex-shrink: 0; }
.modal svg:not(.emblem):not(.lav-l):not(.lav):not([class*="hero"]) { max-width: 22px; max-height: 22px; flex-shrink: 0; }
.vault-tile svg.bottle { width: 40px; height: 40px; }
.c-card-head svg, .smallcaps svg, .ni svg { width: 16px; height: 16px; }
.btn svg, .btn-sm svg { width: 16px; height: 16px; vertical-align: -2px; flex-shrink: 0; }
.nav-item svg { width: 18px; height: 18px; }
.ldel svg { width: 15px; height: 15px; }
.lcheck svg { width: 14px; height: 14px; }
.onb-card svg:not(.emblem) { max-width: 22px; max-height: 22px; }
@media(max-width:860px){
  .app-sidebar{display:none}
  .app-topbar{display:flex}
  .app-bottomnav{display:flex}
  .fab{display:grid}
  .app-main{padding:18px 16px 110px}
  .view-head h2{font-size:1.95rem}
  .view-head .vh-kicker{letter-spacing:.2em}
  /* home dashboard grid collapses to single column on mobile */
  .dash-row.top,.dash-row.bot{grid-template-columns:1fr !important}
}
@media(min-width:861px){
  .home-mobile-only{display:none}
}
/* ─── small-phone polish ─── */
@media(max-width:480px){
  .app-main{padding:14px 12px 104px}
  .view-head h2{font-size:1.7rem}
  .modal{padding:22px 18px;border-radius:16px}
  .budget-totals{grid-template-columns:1fr 1fr;gap:10px}
  .bt-card .big{font-size:1.8rem}
  .c-card{padding:16px 15px}
  .modal-actions{flex-wrap:wrap}
  .modal-actions .btn{min-width:calc(50% - 5px)}
  .seg{flex-wrap:wrap}
  .app-bottomnav .tab span{font-size:9px}
  .dash-greet h2{font-size:2rem}
}
/* tap targets ≥44px on mobile */
@media(max-width:860px){
  .nav-item,.tab,.btn,.lcheck,.chip{min-height:40px}
  .ldel{width:38px;height:38px}
  .ph-link{padding:6px 4px;display:inline-block}
}
/* prevent horizontal scroll anywhere */
html,body{overflow-x:hidden;max-width:100%}
.modal{overscroll-behavior:contain}

/* ─── ONBOARDING ─── */
.onb-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;overflow:auto;
  background:radial-gradient(125% 95% at 50% -10%,#3a2433,#271621 40%,#190e16 74%,#120a10)}
.onb-card{width:100%;max-width:460px;border:1px solid var(--gold-line);border-radius:20px;padding:34px 30px;position:relative;text-align:center;
  background:radial-gradient(120% 80% at 50% 0%,#2e1b28,#1c1018);box-shadow:0 40px 100px rgba(0,0,0,.6)}
.onb-card::before{content:'';position:absolute;inset:7px;border:1px solid var(--gold-line-soft);border-radius:14px;pointer-events:none}
.onb-card .emblem{width:92px;height:102px;color:var(--gold);margin:0 auto 4px}
.onb-title{font-family:var(--serif);font-size:1.85rem;color:var(--bone);font-weight:600;line-height:1.12;margin-bottom:6px}
.onb-title em{font-style:italic;color:var(--gold-bright)}
.onb-sub{font-family:var(--serif);font-style:italic;color:var(--bone-dim);font-size:1.06rem;margin-bottom:22px;line-height:1.4}
.onb-body{text-align:left}
.onb-actions{display:flex;gap:10px;margin-top:22px}
.onb-actions .btn{flex:1;text-align:center}
.onb-skip{display:inline-block;margin-top:16px;color:var(--gold-dim);font-family:var(--body);font-size:13.5px;cursor:pointer;letter-spacing:.02em}
.onb-skip:hover{color:var(--gold-bright)}
.onb-dots{display:flex;justify-content:center;gap:7px;margin-top:22px}
.onb-dots i{width:7px;height:7px;border-radius:50%;background:rgba(201,160,90,.25);transition:.2s}
.onb-dots i.on{background:var(--gold-bright);box-shadow:0 0 8px rgba(201,160,90,.5)}
.onb-code{font-family:var(--serif);font-size:2.3rem;letter-spacing:.28em;color:var(--gold-bright);font-weight:600;text-align:center;
  background:rgba(201,160,90,.08);border:1px solid var(--gold-line);border-radius:12px;padding:16px 10px;margin:6px 0 4px}
.onb-portrait{width:96px;height:96px;border-radius:50%;margin:0 auto 6px;border:2px solid var(--gold);overflow:hidden;
  background:linear-gradient(160deg,#3a2a3e,#241620);display:grid;place-items:center;color:var(--gold-bright);font-family:var(--script);font-size:2rem;box-shadow:0 0 0 4px rgba(201,160,90,.12)}
.onb-portrait img{width:100%;height:100%;object-fit:cover}

/* v52 polish: mobile-safe cards, invite code, and better tap targets */
.settings-code{font-family:var(--serif);font-weight:700;letter-spacing:.22em;text-align:center;font-size:1.75rem;color:var(--gold-bright);background:rgba(0,0,0,.22);border:1px solid var(--gold-line);border-radius:14px;padding:14px 12px;overflow-wrap:anywhere}
.input, textarea, select{font-size:16px;max-width:100%}
.c-card, .panel, .modal-card{max-width:100%;box-sizing:border-box}
@media(max-width:860px){
  .settings-grid{grid-template-columns:1fr!important;gap:14px!important}
  .settings-code{font-size:1.45rem;letter-spacing:.16em}
  .modal-card{width:min(94vw,560px);max-height:88dvh;overflow:auto}
  .chart-tabs,.seg,.app-seg{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px}
  .chart-tabs button,.seg button{white-space:nowrap}
}
@media(max-width:420px){
  .btn,.btn.sm,.btn.ghost.sm{width:100%;justify-content:center;text-align:center}
  .modal-actions .btn{width:auto}
}

/* v53 photo fit editor */
.photo-fit-preview{width:100%;aspect-ratio:4/3;border-radius:14px;overflow:hidden;border:1px solid var(--gold-line);background:rgba(0,0,0,.22);display:flex;align-items:center;justify-content:center}
.photo-fit-preview img{width:100%;height:100%;display:block}
.photo-fit-tools{display:grid;grid-template-columns:1fr;gap:10px;margin-top:12px}
.photo-fit-tools .field{margin:0}
.photo-fit-tools input[type="range"]{accent-color:var(--gold);padding:0;background:transparent}
@media(min-width:620px){.photo-fit-tools{grid-template-columns:1fr 1fr}.photo-fit-tools .field:first-child{grid-column:1/-1}}

/* v55 auth boot: covers background immediately while auth bundle loads */
.auth-boot{position:fixed;inset:0;z-index:190;display:flex;align-items:center;justify-content:center;padding:18px;background:radial-gradient(120% 100% at 50% 0%,rgba(46,20,38,.98),rgba(18,10,16,1));transition:opacity .18s ease,visibility .18s ease}
.auth-boot-card{text-align:center;border:1px solid rgba(226,194,128,.24);background:linear-gradient(160deg,rgba(50,27,44,.82),rgba(28,15,24,.92));border-radius:22px;padding:26px 28px;box-shadow:0 30px 80px rgba(0,0,0,.62)}
.auth-boot-brand{font-family:var(--serif);font-size:2rem;font-weight:700;color:var(--bone)}
.auth-boot-brand em{color:var(--gold-bright);font-style:italic}.auth-boot-sub{margin-top:6px;color:var(--bone-dim);font-family:var(--serif);font-style:italic}
html.app-ready .auth-boot,.auth-resolved .auth-boot{opacity:0;visibility:hidden;pointer-events:none}
@media(max-width:480px){.auth-boot{align-items:flex-end}.auth-boot-card{width:100%;border-radius:22px 22px 0 0}}

/* v55 mobile/desktop centering + overflow hardening */
html, body { width:100%; max-width:100%; overflow-x:hidden; }
body { position:relative; }
.app-shell, .app-main, #app-view, .view, .dash-row, .home-bot-cards, .settings-grid, .profile-duo, .panel, .c-card { box-sizing:border-box; }
.dash-row, .home-bot-cards, .settings-grid, .profile-duo { min-width:0; }
.panel, .c-card, .days-panel, .lovenote-panel { min-width:0; max-width:100%; }
.app-main { width:100%; }

@media(max-width:860px){
  html, body { overscroll-behavior-x:none; }
  .starfield { overflow:hidden; }
  .app-shell { display:block; width:100%; max-width:100%; margin:0; min-height:100dvh; overflow-x:hidden; }
  .app-main { display:block; width:100%; max-width:100%; margin:0 auto; padding-left:max(14px, env(safe-area-inset-left)); padding-right:max(14px, env(safe-area-inset-right)); overflow-x:hidden; }
  #app-view, .view.active { width:100%; max-width:100%; overflow-x:hidden; }
  .dash-greet, .greet-rule, .view-head { width:100%; max-width:100%; margin-left:auto; margin-right:auto; text-align:center; }
  .dash-row, .dash-row.top, .dash-row.bot, .home-bot-cards, .settings-grid, .profile-duo { display:grid; grid-template-columns:minmax(0,1fr)!important; width:100%; max-width:100%; margin-left:0; margin-right:0; gap:16px; }
  .panel, .c-card { width:100%; max-width:100%; overflow:hidden; }
  .panel-head { gap:10px; }
  .panel-head .ph-title { min-width:0; overflow-wrap:anywhere; }
  .panel-head .ph-link { flex:0 0 auto; }
  .days-parch .num { font-size:clamp(3.3rem,18vw,4.7rem); }
  .dcal { width:100%; table-layout:fixed; }
  .dcal th { font-size:9px; letter-spacing:.04em; }
  .dcal td { height:40px; padding:2px 0; }
  .dcal td .dn { width:30px; height:30px; font-size:1.05rem; }
  .dcal-nav { gap:10px; }
  .dcal-nav .m { min-width:0; font-size:1.2rem; }
  .dnote { width:100%; transform:none; margin:0; }
  .dnote .quote { margin-left:28px; font-size:1.65rem; }
  .notif, .didea, .dcd, .lrow, .rl-top { min-width:0; }
  .modal-bg { overflow-x:hidden; }
  .modal { max-width:calc(100vw - 24px); }
  .fab { right:max(18px, env(safe-area-inset-right)); }
}
@media(max-width:390px){
  .app-main { padding-left:10px; padding-right:10px; }
  .panel, .c-card { padding-left:14px; padding-right:14px; }
  .panel-head { flex-direction:column; align-items:flex-start; }
  .panel-head .ph-link { align-self:flex-start; }
  .app-bottomnav .tab svg { width:21px; height:21px; }
  .app-bottomnav .tab span { font-size:8.5px; }
}
