/* ════════════════════════════════════════════════════════════
   THE GARDEN OF US — desktop dashboard
   ════════════════════════════════════════════════════════════ */
.dash-scaler{width:100%;max-width:1340px;margin:0 auto;overflow:hidden}
.dashboard{
  position:relative;width:1340px;transform-origin:top left;
  border-radius:20px;padding:3px;
  background:linear-gradient(150deg,rgba(201,160,90,.5),rgba(201,160,90,.12) 30%,rgba(201,160,90,.06) 60%,rgba(201,160,90,.4));
  box-shadow:0 50px 120px rgba(0,0,0,.6);
}
.dash-inner{
  position:relative;display:flex;border-radius:18px;overflow:hidden;min-height:840px;
  background:
    radial-gradient(80% 60% at 78% 8%, rgba(120,80,150,.16), transparent 60%),
    radial-gradient(120% 100% at 50% 0%, #311d2b 0%, #241520 42%, #190f17 78%, #140b11 100%);
  border:1px solid var(--gold-line);
}
.dash-inner::before{content:'';position:absolute;inset:9px;border:1px solid var(--gold-line-soft);border-radius:12px;pointer-events:none;z-index:5}
/* corner filigree */
.dash-corner{position:absolute;width:88px;height:88px;color:var(--gold);opacity:.62;z-index:6;pointer-events:none}
.dash-corner.tl{top:10px;left:10px}
.dash-corner.tr{top:10px;right:10px;transform:scaleX(-1)}
.dash-corner.bl{bottom:10px;left:10px;transform:scaleY(-1)}
.dash-corner.br{bottom:10px;right:10px;transform:scale(-1)}
/* moon + ivy top-right of header area */
.dash-moon{position:absolute;top:30px;right:64px;width:96px;height:96px;color:var(--gold-bright);opacity:.85;z-index:3}
.dash-ivy{position:absolute;color:var(--gold);opacity:.4;z-index:2}

/* ─── SIDEBAR ─── */
.dash-sidebar{flex:0 0 236px;padding:30px 22px;display:flex;flex-direction:column;
  border-right:1px solid var(--gold-line);position:relative;z-index:7;
  background:linear-gradient(180deg,rgba(20,11,17,.3),rgba(20,11,17,0))}
.crest{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:8px}
.crest .emblem{width:118px;height:130px;color:var(--gold);margin-bottom:10px}
.crest h1{font-family:var(--serif);font-weight:600;font-size:1.24rem;letter-spacing:.08em;color:var(--bone);
  text-transform:uppercase;line-height:1.18}
.crest .crestrule{margin:16px auto 0;width:56%;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}

.dash-nav{margin-top:24px;display:flex;flex-direction:column;gap:3px}
.nav-item{position:relative;display:flex;align-items:center;gap:13px;padding:11px 14px;border-radius:10px;cursor:pointer;
  color:var(--bone-dim);font-family:var(--serif);font-size:1.18rem;transition:.18s;border:1px solid transparent}
.nav-item svg{width:21px;height:21px;flex:0 0 21px;color:var(--gold-dim);transition:.18s}
.nav-item:hover{color:var(--bone);background:rgba(201,160,90,.05)}
.nav-item:hover svg{color:var(--gold)}
.nav-item.active{color:var(--gold-bright);border-color:var(--gold-line);background:rgba(201,160,90,.08)}
.nav-item.active svg{color:var(--gold-bright)}
.nav-item .nc{display:none}
.nav-item.active .nc{display:block;position:absolute;color:var(--gold);font-size:8px;opacity:.7}
.nav-item.active .nc.a{top:3px;left:4px}.nav-item.active .nc.b{top:3px;right:4px}
.nav-item.active .nc.c{bottom:3px;left:4px}.nav-item.active .nc.d{bottom:3px;right:4px}

.dash-sidebar .spacer{flex:1}
.side-rule{height:1px;background:linear-gradient(90deg,transparent,var(--gold-line),transparent);margin:18px 0}
.side-profile{display:flex;align-items:center;gap:12px}
.side-portrait{width:48px;height:48px;border-radius:50%;flex:0 0 48px;border:1.5px 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:1.1rem;box-shadow:0 0 0 3px rgba(201,160,90,.12)}
.side-profile .sp-name{font-family:var(--serif);font-size:1.18rem;color:var(--bone);display:flex;align-items:center;gap:6px}
.side-profile .sp-name svg{width:13px;height:13px;color:var(--gold)}
.side-profile .sp-role{font-size:.86rem;color:var(--muted);letter-spacing:.02em}
.theme-slider{margin-top:16px;display:flex;align-items:center;gap:10px;color:var(--gold)}
.theme-slider svg{width:15px;height:15px}
.level-bar{margin-top:16px;display:flex;align-items:center;gap:10px;color:var(--gold);cursor:pointer}
.level-bar svg{width:15px;height:15px}
.level-track{flex:1;height:6px;border-radius:99px;background:rgba(201,160,90,.18);overflow:hidden}
.level-track > i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--gold),var(--gold-bright));transition:width .6s ease}
.level-label{text-align:center;font-family:var(--body);text-transform:uppercase;letter-spacing:.14em;font-size:9.5px;color:var(--gold-dim);margin-top:7px}
.theme-track{flex:1;height:5px;border-radius:99px;background:rgba(201,160,90,.18);position:relative}
.theme-track::after{content:'';position:absolute;left:46%;top:50%;transform:translateY(-50%);width:14px;height:14px;border-radius:50%;
  background:radial-gradient(circle at 40% 35%,var(--gold-bright),var(--gold));box-shadow:0 1px 4px rgba(0,0,0,.5)}

/* ─── MAIN ─── */
.dash-main{flex:1;min-width:0;padding:34px 40px 26px;position:relative;z-index:3;display:flex;flex-direction:column}
.dash-greet{text-align:center;margin-bottom:8px}
.dash-greet h2{font-family:var(--serif);font-size:2.5rem;font-weight:600;color:var(--bone);line-height:1.1}
.dash-greet h2 em{font-style:italic;color:var(--gold-bright)}
.dash-greet p{font-family:var(--serif);font-style:italic;font-size:1.2rem;color:var(--bone-dim);margin-top:2px}
.greet-rule{display:flex;align-items:center;justify-content:center;gap:10px;color:var(--gold);margin:14px auto 26px;max-width:230px;font-size:11px}
.greet-rule::before,.greet-rule::after{content:'';height:1px;flex:1;background:linear-gradient(90deg,transparent,var(--gold-line),transparent)}

.dash-row{display:grid;gap:22px;margin-bottom:22px}
.dash-row.top{grid-template-columns:300px 1fr 304px}
.dash-row.bot{grid-template-columns:1fr 1.04fr 1.12fr}

/* generic engraved panel */
.panel{position:relative;border:1px solid var(--gold-line);border-radius:14px;padding:20px 22px;
  background:linear-gradient(160deg,rgba(48,29,42,.5),rgba(24,14,21,.5));
  box-shadow:0 16px 40px rgba(0,0,0,.3),inset 0 1px 0 rgba(255,255,255,.03)}
.panel::before{content:'';position:absolute;inset:5px;border:1px solid var(--gold-line-soft);border-radius:10px;pointer-events:none}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;position:relative;z-index:1}
.panel-head .ph-title{font-family:var(--body);text-transform:uppercase;letter-spacing:.2em;font-size:12px;font-weight:600;color:var(--gold-bright)}
.panel-head .ph-link{font-family:var(--body);font-size:12.5px;color:var(--gold-dim);cursor:pointer;letter-spacing:.02em;position:relative;z-index:2;user-select:none}
.panel-head .ph-link:hover{color:var(--gold-bright)}
/* ph-link outside panel-head (e.g. pulse widget) */
.ph-link{cursor:pointer;color:var(--gold-dim);font-family:var(--body);font-size:13px;position:relative;z-index:2;user-select:none}
.ph-link:hover{color:var(--gold-bright)}
.panel-head .ph-add{width:24px;height:24px;border:1px solid var(--gold-line);border-radius:7px;display:grid;place-items:center;color:var(--gold);cursor:pointer}
.panel-head .ph-add svg{width:14px;height:14px}
.panel-content{position:relative;z-index:1}

/* Days Together parchment */
.days-panel{padding:0;border:none;background:none;box-shadow:none}
.days-panel::before{display:none}
.days-parch{padding:26px 20px 22px;text-align:center;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center}
.days-parch .cap{font-family:var(--body);text-transform:uppercase;letter-spacing:.22em;font-size:12px;color:var(--sepia-soft);font-weight:600;margin-bottom:6px}
.days-parch .num{font-family:var(--serif);font-size:5.4rem;font-weight:600;line-height:.86;color:#3c2c18}
.days-parch .u{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--sepia-soft);margin-top:2px}
.days-parch .lav{width:120px;height:64px;color:var(--orchid-deep);margin:14px 0 12px}
.days-parch .quote{font-family:var(--serif);font-style:italic;font-size:1.02rem;color:var(--sepia);line-height:1.35;max-width:22ch}
.days-parch .quote::before,.days-parch .quote::after{content:'"'}

/* Shared Calendar (desktop, full grid) */
.dcal-nav{display:flex;align-items:center;justify-content:center;gap:18px;margin-bottom:14px}
.dcal-nav .m{font-family:var(--serif);font-style:italic;font-size:1.4rem;color:var(--gold-bright);min-width:140px;text-align:center}
.dcal-nav svg{width:16px;height:16px;color:var(--gold);cursor:pointer}
.dcal{width:100%;border-collapse:collapse}
.dcal th{font-family:var(--body);text-transform:uppercase;letter-spacing:.08em;font-size:10px;color:var(--gold-dim);font-weight:600;padding-bottom:10px}
.dcal td{text-align:center;padding:3px 2px;height:48px;vertical-align:top}
.dcal td .dn{font-family:var(--serif);font-size:1.15rem;color:var(--bone-dim);position:relative;display:inline-grid;place-items:center;width:32px;height:32px;border-radius:50%;margin-top:2px}
.dcal td.muted .dn{color:var(--muted);opacity:.4}
.dcal td.today .dn{color:var(--ink);background:radial-gradient(circle,var(--gold-bright),var(--gold));font-weight:600;box-shadow:0 0 12px rgba(201,160,90,.45)}
.dcal td.has-evt{border-radius:10px;transition:background .15s}
.dcal td.has-evt:hover{background:rgba(201,160,90,.08)}
.dcal td.has-evt .dn{color:var(--bone)}
.dcal .ev-dots{display:flex;justify-content:center;gap:3px;margin-top:2px;height:6px}
.dcal .ev-dot{width:5px;height:5px;border-radius:50%;background:var(--gold)}
.dcal .ev-dot.rose{background:#d28aa6}
.dcal .ev-dot.gold{background:var(--gold-bright)}
.dcal-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;margin-top:14px;padding-top:12px;border-top:1px solid var(--gold-line-soft)}
.dcal-legend span{display:flex;align-items:center;gap:6px;font-family:var(--body);font-size:11px;color:var(--bone-dim);letter-spacing:.02em}
.dcal-legend i{width:7px;height:7px;border-radius:50%}
.dcal-legend i.rose{background:#d28aa6}.dcal-legend i.gold{background:var(--gold-bright)}.dcal-legend i.date{background:#d28aa6}

/* Notifications */
.notif{display:flex;gap:13px;padding:13px 2px;border-bottom:1px solid var(--gold-line-soft)}
.notif:last-child{border-bottom:none}
.notif .ni{width:24px;flex:0 0 24px;color:var(--gold);display:flex;justify-content:center;padding-top:2px}
.notif .ni svg{width:21px;height:21px}
.notif .nbody{flex:1;min-width:0}
.notif .nt{font-family:var(--serif);font-size:1.12rem;color:var(--bone);line-height:1.22}
.notif .nt b{color:var(--gold-bright);font-weight:600}
.notif .ntime{font-size:11px;color:var(--muted);flex:0 0 auto;white-space:nowrap}

/* Countdowns (desktop) */
.dcd{display:flex;align-items:center;gap:14px;padding:14px 14px;border:1px solid var(--gold-line);border-radius:11px;margin-bottom:12px;
  background:rgba(24,14,21,.4);position:relative}
.dcd:last-child{margin-bottom:0}
.dcd .dcd-ic{width:42px;height:42px;flex:0 0 42px;color:var(--gold);display:grid;place-items:center}
.dcd .dcd-ic svg{width:34px;height:34px}
.dcd .dcd-name{font-family:var(--serif);font-size:1.22rem;color:var(--bone)}
.dcd .dcd-num{font-family:var(--serif);font-size:1.7rem;color:var(--gold-bright);font-weight:600;line-height:1}
.dcd .dcd-num small{font-family:var(--body);font-style:italic;font-size:.62em;color:var(--bone-dim)}
.dcd .dcd-date{font-size:11.5px;color:var(--muted)}

/* Love Notes panel (tilted parchment) */
.lovenote-panel{display:flex;align-items:center;justify-content:center;overflow:visible}
.dnote{position:relative;width:92%;padding:26px 28px 30px;text-align:center;transform:rotate(-2deg);margin:6px 0}
.dnote .lav-l{position:absolute;left:14px;top:24px;width:54px;height:120px;color:var(--orchid-deep);opacity:.92}
.dnote .quote{font-family:var(--script);font-size:1.85rem;color:#41301d;line-height:1.3;margin:0 10px 0 40px}
.dnote .heart{color:var(--wax);font-size:15px;margin:10px 0}
.dnote .sign{font-family:var(--script);font-size:1.3rem;color:var(--sepia-soft);margin-left:30px}
.dnote .wax{position:absolute;bottom:-12px;right:6px;width:62px;height:62px;border-radius:50%;
  background:radial-gradient(circle at 38% 32%,var(--wax-hi),var(--wax) 55%,#491e32 100%);
  box-shadow:0 7px 18px rgba(0,0,0,.5),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,.7)}
.dnote .wax svg{width:30px;height:30px}

/* Date Ideas panel rows */
.didea{display:flex;align-items:center;gap:14px;padding:15px 4px;border-bottom:1px solid var(--gold-line-soft)}
.didea:last-child{border-bottom:none}
.didea .dcloche{width:50px;height:50px;flex:0 0 50px;border-radius:11px;display:grid;place-items:center;
  border:1px solid var(--gold-line);background:radial-gradient(circle at 50% 28%,rgba(201,160,90,.16),rgba(20,12,18,.6));color:var(--gold)}
.didea .dcloche svg{width:30px;height:30px}
.didea .di-body{flex:1;min-width:0}
.didea .di-title{font-family:var(--serif);font-size:1.2rem;font-weight:600;color:var(--bone);line-height:1.12}
.didea .di-sub{font-size:.92rem;color:var(--bone-dim);line-height:1.32;margin-top:3px}
.didea .di-mark{color:var(--gold-dim);cursor:pointer;flex:0 0 auto}
.didea .di-mark svg{width:21px;height:21px}
.didea .di-mark.on{color:var(--gold-bright)}

/* footer */
.dash-foot{margin-top:auto;padding-top:22px;text-align:center;font-family:var(--body);text-transform:uppercase;
  letter-spacing:.34em;font-size:11px;color:var(--gold-dim);display:flex;align-items:center;justify-content:center;gap:16px}
.dash-foot::before,.dash-foot::after{content:'';width:80px;height:1px;background:linear-gradient(90deg,transparent,var(--gold-line),transparent)}

/* composition: desktop + phone like the reference */
.composition{display:flex;gap:30px;align-items:center;justify-content:center;flex-wrap:wrap}
.composition .device-col{flex:0 0 auto}

/* dashboard renders at fixed 1340px and is scaled to fit by JS (scaleDash) */

/* anniversary countdown badge on days-together card */
.anniv-badge{font-family:var(--body);font-size:11px;letter-spacing:.1em;color:var(--sepia);background:rgba(201,160,90,.15);border:1px solid rgba(201,160,90,.3);border-radius:999px;padding:3px 10px;margin-top:8px;text-align:center;line-height:1.4}
