:root{
  --ink:#0d0b0a;
  --ink-2:#15110f;
  --paper:#f4ece0;
  --paper-soft:#cdbfa9;
  --gold:#c9a24b;
  --gold-soft:#e6cf95;
  --line:rgba(201,162,75,.28);
  --shadow:0 30px 80px rgba(0,0,0,.55);
}

*{box-sizing:border-box;margin:0;padding:0}
#app{display:contents}   /* wrapper for in-place navigation; no layout box of its own */
html{background:#0a0706}
html,body{min-height:100%}
body{
  font-family:"Inter",system-ui,sans-serif;
  color:var(--paper);
  background:
    radial-gradient(130% 100% at 50% -20%, #241c14 0%, #140e0a 52%, #0a0706 100%) no-repeat;
  background-color:#0a0706;
  background-attachment:fixed;
  min-height:100dvh;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  padding:env(safe-area-inset-top) 0 env(safe-area-inset-bottom);
}
body.centered{display:flex;align-items:center;justify-content:center;
  padding:32px 20px;
  /* reserve the on-screen keyboard's height (set by JS) so vertically-centered
     content stays inside the *visible* viewport and its button is never covered */
  padding-bottom:calc(32px + var(--kb, 0px));
}
/* when the keyboard is up: let the card sink to just above the keyboard
   (margin-top:auto pushes it down to the reserved bottom gap = the 32px in
   padding-bottom, sitting above --kb), keep it fully visible, and allow scroll
   if the card is taller than the space above the keys (top stays reachable). */
body.centered.kb-open{overflow-y:auto}
body.centered.kb-open .card{margin-top:auto}

/* subtle film grain / vignette */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(140% 120% at 50% 30%, transparent 55%, rgba(0,0,0,.55) 100%);
  mix-blend-mode:multiply;
}

/* ─── Typography ─── */
.display{
  font-family:"Cormorant Garamond",serif;
  font-weight:500;
  letter-spacing:.01em;
  font-size:clamp(2.6rem,7vw,4.4rem);
  line-height:1.02;
  color:var(--paper);
}
.display.big{font-size:clamp(3.2rem,11vw,6rem)}
.eyebrow{
  text-transform:uppercase;
  letter-spacing:.42em;
  font-size:.66rem;
  font-weight:500;
  color:var(--gold);
  margin-bottom:1.1rem;
  padding-left:.42em;
}
.lede{
  font-family:"Cormorant Garamond",serif;
  font-size:clamp(1.18rem,2.4vw,1.5rem);
  color:var(--paper-soft);
  font-weight:400;
  margin:1.4rem 0;
}
.lede.center{max-width:38ch;margin-inline:auto}
.subtitle{
  font-family:"Cormorant Garamond",serif;
  font-style:italic;
  font-size:1.4rem;
  color:var(--gold-soft);
  margin-top:.4rem;
}
.footnote,.hint,.confirm-note{
  font-size:.82rem;color:var(--paper-soft);opacity:.7;letter-spacing:.02em;
}
.footnote{margin-top:1.8rem}
.rule{
  width:64px;height:1px;background:var(--gold);
  margin:1.6rem auto;opacity:.7;
  position:relative;
}
.rule::before,.rule::after{
  content:"";position:absolute;top:50%;width:5px;height:5px;border-radius:50%;
  background:var(--gold);transform:translateY(-50%);
}
.rule::before{left:-12px}.rule::after{right:-12px}

/* ─── Cards (login / invite / confirmed) ─── */
.card{
  position:relative;z-index:1;
  width:100%;max-width:560px;
  background:linear-gradient(160deg, rgba(32,25,18,.92), rgba(18,13,10,.96));
  border:1px solid var(--line);
  border-radius:18px;
  padding:clamp(2.4rem,6vw,3.6rem);
  text-align:center;
  box-shadow:var(--shadow);
}
.card::after{
  content:"";position:absolute;inset:8px;border:1px solid rgba(201,162,75,.14);
  border-radius:12px;pointer-events:none;
}

/* ─── Buttons & links ─── */
.btn-gold{
  display:inline-block;
  font-family:"Inter",sans-serif;
  font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  font-size:.78rem;
  color:#1a130a;
  text-decoration:none;
  background:linear-gradient(135deg,var(--gold-soft),var(--gold));
  border:none;border-radius:999px;
  padding:.95em 2.2em;
  cursor:pointer;
  transition:transform .25s ease, box-shadow .25s ease, filter .25s ease;
  box-shadow:0 12px 30px rgba(201,162,75,.22);
}
.btn-gold:hover{transform:translateY(-2px);filter:brightness(1.06);box-shadow:0 16px 38px rgba(201,162,75,.32)}
.btn-gold:disabled{opacity:.35;cursor:not-allowed;transform:none;box-shadow:none}
.btn-gold.large{padding:1.05em 2.8em;font-size:.82rem;margin-top:.6rem}
.card-close{
  position:absolute;top:12px;right:14px;z-index:3;
  width:34px;height:34px;display:grid;place-items:center;
  color:var(--paper-soft);text-decoration:none;font-size:1.5rem;line-height:1;
  border-radius:50%;transition:color .2s,background .2s;
}
.card-close:hover{color:var(--gold-soft);background:rgba(255,255,255,.06)}

.text-link{
  display:inline-block;margin-top:1.6rem;
  color:var(--paper-soft);font-size:.8rem;letter-spacing:.06em;
  text-decoration:none;border-bottom:1px solid transparent;
  transition:color .2s,border-color .2s;
}
.text-link:hover{color:var(--gold-soft);border-color:var(--line)}

/* ─── Login ─── */
.enter-form{display:flex;flex-direction:column;gap:1rem;margin:2rem auto 0;max-width:340px}
.code-input{
  font-family:"Cormorant Garamond",serif;
  font-size:1.5rem;text-align:center;letter-spacing:.12em;
  color:var(--paper);
  background:rgba(0,0,0,.25);
  border:1px solid var(--line);
  border-radius:10px;
  padding:.7em 1em;
  transition:border-color .2s, box-shadow .2s;
}
.code-input::placeholder{color:rgba(205,191,169,.4);font-style:italic}
.code-input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,75,.12)}

/* ─── Invite ─── */
.personal{
  font-family:"Cormorant Garamond",serif;font-style:italic;
  font-size:clamp(1.4rem,3.4vw,1.9rem);
  color:var(--paper);line-height:1.4;
  margin:1.6rem auto;max-width:30ch;
}
.signoff{font-family:"Cormorant Garamond",serif;font-style:italic;color:var(--gold-soft);font-size:1.15rem;margin-bottom:1.4rem}
.confirmed .signoff{font-size:1.7rem}

/* Invitation letter */
.invite-letter{text-align:left;margin:1.6rem auto 0;max-width:46ch}
.invite-letter p{
  font-family:"Cormorant Garamond",serif;
  font-size:clamp(1.18rem,2.6vw,1.3rem);
  line-height:1.62;color:var(--paper-soft);margin-bottom:1rem;
}
.invite-letter p:last-child{margin-bottom:0}
.thanks{font-family:"Cormorant Garamond",serif;font-style:italic;
  font-size:1.3rem;color:var(--gold-soft);margin-top:1.8rem}
.sign-lead{margin-bottom:.2rem}
.signature{display:block;width:min(56%,220px);height:auto;margin:.1rem auto 1.6rem;opacity:.95}

/* ─── Booking ─── */
.book{
  position:relative;z-index:1;
  max-width:880px;margin:0 auto;
  padding:clamp(2rem,6vw,4rem) clamp(1.1rem,4vw,2rem) 5rem;
}
.book-head{text-align:center;margin-bottom:2.6rem}
.book-sub{text-align:center;font-size:.85rem;color:var(--paper-soft);opacity:.7;margin-top:.5rem}
.step{margin-bottom:2.8rem}
.step-title{
  font-family:"Cormorant Garamond",serif;font-weight:500;
  font-size:1.7rem;color:var(--paper);
  display:flex;align-items:center;gap:.7rem;
  margin-bottom:1.2rem;padding-bottom:.7rem;
  border-bottom:1px solid var(--line);
}
.step-title span{
  display:grid;place-items:center;
  width:30px;height:30px;border-radius:50%;
  font-family:"Inter";font-size:.8rem;font-weight:500;
  color:var(--gold);border:1px solid var(--gold);
}

/* calendar: Monday–Sunday rows of 7 */
.cal-head{
  display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-bottom:8px;
}
.cal-head span{
  text-align:center;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold);opacity:.8;
}
.date-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}
.date-blank{aspect-ratio:1/1;border:none;background:none}
.date-cell{
  position:relative;cursor:pointer;aspect-ratio:1/1;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;
  padding:.5rem .3rem;border-radius:12px;
  background:rgba(255,255,255,.02);
  border:1px solid var(--line);
  transition:border-color .2s, background .2s, transform .15s;
}
.date-cell input{position:absolute;opacity:0;pointer-events:none}
.date-cell .dow{font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--paper-soft)}
.date-cell .dnum{font-family:"Cormorant Garamond",serif;font-size:1.7rem;color:var(--paper);line-height:1}
.date-cell .dmon{font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.date-cell:hover:not(.taken){border-color:var(--gold);transform:translateY(-2px)}
.date-cell:has(input:checked){
  background:linear-gradient(150deg,var(--gold-soft),var(--gold));
  border-color:var(--gold);
}
.date-cell:has(input:checked) .dow,
.date-cell:has(input:checked) .dnum,
.date-cell:has(input:checked) .dmon{color:#1a130a}
.date-cell.taken{
  cursor:not-allowed;opacity:.34;filter:grayscale(.6);
  background:repeating-linear-gradient(45deg,rgba(255,255,255,.02),rgba(255,255,255,.02) 6px,transparent 6px,transparent 12px);
}
.taken-tag{
  position:absolute;top:6px;right:6px;
  font-size:.52rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--paper-soft);
}
.date-cell.noted{opacity:.62;filter:grayscale(.25)}
.date-note{
  position:absolute;left:0;right:0;bottom:9px;text-align:center;
  font-size:.62rem;letter-spacing:.05em;text-transform:uppercase;color:var(--gold);
}

/* experience grid */
.exp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));grid-auto-rows:1fr;gap:12px}
.exp-cell{cursor:pointer;display:block}
.exp-cell input{position:absolute;opacity:0;pointer-events:none}
.exp-inner{
  display:flex;flex-direction:column;height:100%;
  padding:1.3rem 1.4rem;border-radius:14px;
  background:rgba(255,255,255,.02);
  border:1px solid var(--line);
  transition:border-color .2s, background .2s, transform .15s;
}
.exp-cell:hover .exp-inner{border-color:var(--gold);transform:translateY(-2px)}
.exp-cell:has(input:checked) .exp-inner{
  border-color:var(--gold);
  background:linear-gradient(160deg,rgba(201,162,75,.16),rgba(201,162,75,.04));
  box-shadow:inset 0 0 0 1px var(--gold);
}
.exp-name{display:block;font-family:"Cormorant Garamond",serif;font-size:1.4rem;color:var(--paper);line-height:1.15}
.exp-tag{display:block;font-style:italic;font-family:"Cormorant Garamond",serif;color:var(--gold-soft);font-size:1.02rem;margin:.1rem 0 .6rem}
.exp-desc{display:block;font-size:.86rem;color:var(--paper-soft);line-height:1.5}
.exp-meta{display:flex;flex-wrap:wrap;gap:.4rem .9rem;margin-top:auto;padding-top:.8rem;
  font-size:.66rem;letter-spacing:.1em;text-transform:uppercase}
.exp-town{color:var(--gold)}
.exp-town::before{content:"◦ "}
.exp-closed{color:var(--paper-soft);opacity:.75}
.exp-maps{align-self:flex-start;margin-top:.7rem;font-size:.74rem;letter-spacing:.04em;
  color:var(--paper-soft);text-decoration:none;border-bottom:1px solid var(--line);
  transition:color .2s,border-color .2s}
.exp-maps:hover{color:var(--gold-soft);border-color:var(--gold)}
.exp-cell.closed{opacity:.32;filter:grayscale(.7);cursor:not-allowed}
.exp-cell.closed .exp-inner{border-style:dashed}
.exp-cell.closed .exp-maps{pointer-events:none}
.exp-cell.taken{opacity:.4;filter:grayscale(.55);cursor:not-allowed}
.exp-cell.taken .exp-inner{border-style:dashed}
.exp-cell.taken .exp-maps{pointer-events:none}
.exp-busy{color:var(--gold);font-weight:500}
/* host-blocked card with a red notice (e.g. raclette): keep it readable, no grayscale */
.exp-cell.taken.noteblock{opacity:.82;filter:none}
.exp-note-red{
  display:block;margin-top:auto;padding-top:.9rem;
  font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;
  color:#ef5b52;
}
.date-cell.closed{
  cursor:not-allowed;opacity:.3;filter:grayscale(.6);
  background:repeating-linear-gradient(45deg,rgba(255,255,255,.02),rgba(255,255,255,.02) 6px,transparent 6px,transparent 12px);
}

/* Ljubljana reveal */
[hidden]{display:none !important}  /* .exp-grid sets display:grid, which otherwise overrides the hidden attr */
.lj-toggle{
  display:block;width:100%;margin-top:14px;
  font-family:"Inter",sans-serif;font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold-soft);
  background:rgba(255,255,255,.02);
  border:1px dashed var(--line);border-radius:14px;
  padding:1.15rem 1rem;cursor:pointer;
  transition:border-color .2s,background .2s,color .2s;
}
.lj-toggle:hover{border-color:var(--gold);color:var(--gold);background:rgba(201,162,75,.06)}
.lj-grid{margin-top:14px}

/* The map is a real grid cell (never overlaps cards). On desktop it leapfrogs:
   when it scrolls out of view, JS swaps it a row lower and the cards shift up. */
.map-cell{display:flex;align-items:center;justify-content:center}
.map-cell.settling .map-panel{animation:mapsettle .5s cubic-bezier(.2,.7,.2,1) both}
@keyframes mapsettle{
  0%{opacity:.3;transform:translateY(10px) scale(.97)}
  60%{opacity:1}
  100%{opacity:1;transform:none}
}
.exp-cell.cardswap .exp-inner{animation:cardswap .5s ease both}
@keyframes cardswap{0%{opacity:0;transform:scale(.985)}100%{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){
  .map-cell.settling .map-panel,.exp-cell.cardswap .exp-inner{animation:none}
}
.map-panel{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;
  width:100%;max-width:230px;height:200px;margin:0 auto;
  padding:1rem;border-radius:16px;
  background:linear-gradient(160deg,rgba(34,27,19,.97),rgba(17,12,9,.98));
  border:1px solid var(--line);
  box-shadow:0 20px 44px rgba(0,0,0,.5);
}
.map-svg{width:100%;height:auto;display:block;overflow:visible}
.map-outline{
  fill:rgba(201,162,75,.05);
  stroke:var(--gold);stroke-width:1;stroke-linejoin:round;stroke-linecap:round;
}
.map-dot{fill:var(--gold-soft);opacity:0;transition:opacity .25s ease,cx .35s ease,cy .35s ease}
.map-dot.on{opacity:1}
.map-dot-pulse{fill:none;stroke:var(--gold-soft);stroke-width:1;opacity:0;transition:cx .35s ease,cy .35s ease}
.map-dot-pulse.on{animation:mappulse 1.5s ease-out infinite}
@keyframes mappulse{0%{opacity:.7;r:3}100%{opacity:0;r:13}}
.map-cap{font-size:.58rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);opacity:.8}

/* Standalone mobile map toast (separate element, robust on phones). */
#map-toast{
  position:fixed;inset:0;z-index:90;display:none;
  place-items:start center;                       /* top of the screen, not the middle */
  padding-top:calc(env(safe-area-inset-top) + 4.5vh);
  pointer-events:none;opacity:0;visibility:hidden;
  transition:opacity .5s ease, visibility .5s ease;
}
.mt-card{
  width:min(72vw,250px);
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  padding:1.1rem 1.1rem 1rem;border-radius:18px;
  background:linear-gradient(160deg,rgba(34,27,19,.98),rgba(14,10,7,.99));
  border:1px solid var(--gold);
  box-shadow:0 26px 64px rgba(0,0,0,.6);
}
.mt-svg{width:100%;height:auto;display:block;overflow:visible}
.mt-dot{fill:var(--gold-soft)}
.mt-pulse{fill:none;stroke:var(--gold-soft);stroke-width:1;animation:mappulse 1.5s ease-out infinite}

@media (max-width:720px){
  .map-cell{display:none !important}   /* hide the desktop in-grid map on phones */
  #map-toast{display:grid}
  #map-toast.show{opacity:1;visibility:visible}
}
@media (prefers-reduced-motion:reduce){.map-dot-pulse.on,.mt-pulse{animation:none}}

textarea{
  width:100%;
  font-family:"Inter",sans-serif;font-size:.98rem;
  color:var(--paper);
  background:rgba(0,0,0,.22);
  border:1px solid var(--line);border-radius:12px;
  padding:1rem 1.1rem;resize:vertical;
  transition:border-color .2s, box-shadow .2s;
}
textarea::placeholder{color:rgba(205,191,169,.4);font-style:italic}
textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,75,.1)}
.hint{margin-bottom:.9rem}

.confirm-bar{text-align:center;margin-top:2.6rem}
.confirm-note{margin-top:.9rem}

/* ─── Confirmed ─── */
.seal{
  position:relative;
  width:128px;height:128px;margin:0 auto 1.6rem;
  display:flex;align-items:center;justify-content:center;
}
.seal-img{
  position:relative;z-index:1;
  width:100%;height:100%;display:block;
  transform:rotate(-7deg);            /* nudge off dead-horizontal */
  filter:drop-shadow(0 10px 16px rgba(0,0,0,.45));  /* grounding shadow, no glow */
}
.seal-svg{width:100%;height:100%;display:block}
.seal-ring{fill:none;stroke:rgba(26,19,10,.55);stroke-width:1.6}
.seal-ring2{fill:none;stroke:rgba(26,19,10,.4);stroke-width:.9}
.seal-beads{fill:none;stroke:rgba(26,19,10,.5);stroke-width:2.6;stroke-linecap:round;stroke-dasharray:.1 11}
.seal-bird{fill:none;stroke:rgba(26,19,10,.3);stroke-width:1.4;stroke-linejoin:round;stroke-linecap:round}
.seal-mono{
  fill:rgba(26,19,10,.82);
  font-family:"Cormorant Garamond",serif;font-weight:600;
  font-size:30px;letter-spacing:1px;
}
.summary{margin:2rem auto;max-width:30rem;text-align:left}
.summary > div{padding:1rem 0;border-bottom:1px solid var(--line)}
.summary dt{font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:.3rem}
.summary dd{font-family:"Cormorant Garamond",serif;font-size:1.4rem;color:var(--paper)}
.summary dd.wishes{font-style:italic;color:var(--paper-soft)}
.muted{color:var(--paper-soft);font-size:1.05rem}

/* ─── View switcher (host only) ─── */
.view-switcher{
  position:fixed;top:14px;right:14px;z-index:60;
  display:flex;align-items:center;gap:.55rem;
  background:rgba(18,13,10,.93);
  border:1px solid var(--gold);
  border-radius:999px;
  padding:.42rem .55rem .42rem .95rem;
  box-shadow:0 12px 34px rgba(0,0,0,.5);
  backdrop-filter:blur(10px);
  max-width:calc(100vw - 28px);
}
.vs-label{font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);white-space:nowrap}
.view-switcher select{
  font-family:"Inter",sans-serif;font-size:.86rem;
  color:var(--paper);background:transparent;border:none;
  padding:.2rem .3rem;cursor:pointer;max-width:48vw;
}
.view-switcher select option{background:#15110f;color:var(--paper)}
.view-switcher select:focus{outline:none}
.vs-exit{
  color:var(--paper-soft);text-decoration:none;font-size:.95rem;
  padding:.15rem .45rem;border-left:1px solid var(--line);line-height:1;
}
.vs-exit:hover{color:var(--gold-soft)}

/* ─── Host overview list ─── */
.guest-list{list-style:none;max-width:640px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.guest-list li{list-style:none}
.guest-row{
  display:flex;align-items:center;gap:1rem;
  padding:1.05rem 1.3rem;border-radius:14px;
  background:rgba(255,255,255,.02);border:1px solid var(--line);
  transition:border-color .2s,background .2s;
}
.guest-row:hover{border-color:var(--gold)}
.gr-link{flex:1;min-width:0;display:flex;align-items:center;text-decoration:none;color:inherit}
.release-form{margin:0}
.release-btn{
  font-family:"Inter",sans-serif;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--paper-soft);background:rgba(255,255,255,.03);
  border:1px solid var(--line);border-radius:999px;padding:.55em 1.05em;cursor:pointer;
  transition:color .2s,border-color .2s,background .2s;white-space:nowrap;
}
.release-btn:hover{color:#e3897e;border-color:#a85a50;background:rgba(168,90,80,.14)}
.guest-row.chosen{background:linear-gradient(160deg,rgba(201,162,75,.1),rgba(201,162,75,.02))}
.gr-main{flex:1;display:flex;flex-direction:column;gap:.15rem;min-width:0}
.gr-name{font-family:"Cormorant Garamond",serif;font-size:1.5rem;color:var(--paper);line-height:1.1}
.gr-sub{font-size:.82rem;color:var(--paper-soft);letter-spacing:.02em}
.gr-wishes{font-style:italic;color:var(--gold-soft);font-size:.82rem;margin-top:.2rem;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}
.gr-status{font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);white-space:nowrap}
.guest-row:not(.chosen) .gr-status{color:var(--paper-soft);opacity:.5}
.gr-arrow{font-size:1.6rem;color:var(--gold);line-height:1;flex-shrink:0}

/* ─── Admin (legacy table, still available) ─── */
.admin-table{width:100%;border-collapse:collapse;margin-top:1rem;font-size:.92rem}
.admin-table th{
  text-align:left;font-weight:500;font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold);padding:.7rem .8rem;border-bottom:1px solid var(--line);
}
.admin-table td{padding:.85rem .8rem;border-bottom:1px solid rgba(201,162,75,.12);vertical-align:top}
.admin-table tr.pending td{opacity:.5}
.mono{font-family:ui-monospace,monospace;font-size:.82rem;color:var(--gold-soft)}
.wishes-cell{font-style:italic;color:var(--paper-soft);max-width:22rem}

/* ─── Music toggle ─── */
.music-btn{
  position:fixed;left:16px;bottom:calc(16px + env(safe-area-inset-bottom));z-index:70;
  width:46px;height:46px;border-radius:50%;
  display:grid;place-items:center;
  background:rgba(18,13,10,.9);border:1px solid var(--gold);
  color:var(--gold-soft);font-size:1.15rem;cursor:pointer;
  box-shadow:0 8px 22px rgba(0,0,0,.45);backdrop-filter:blur(6px);
  transition:transform .2s, color .2s, border-color .2s, opacity .2s;
}
.music-btn:hover{transform:translateY(-2px);color:var(--gold)}
.music-btn .ico{position:relative;display:block;line-height:1}
.music-btn.off{color:var(--paper-soft);border-color:var(--line);opacity:.75}
.music-btn.off .ico::after{
  content:"";position:absolute;left:50%;top:50%;
  width:150%;height:2px;background:currentColor;border-radius:2px;
  transform:translate(-50%,-50%) rotate(-45deg);
}

/* ─── Flash ─── */
.flash{
  position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:50;
  background:rgba(40,20,18,.96);
  border:1px solid var(--line);
  color:var(--paper);
  padding:.8rem 1.4rem;border-radius:999px;
  font-size:.86rem;letter-spacing:.02em;
  box-shadow:var(--shadow);
  animation:fade-up .5s ease both;
}

/* ─── Motion ─── */
.fade-up{animation:fade-up .9s cubic-bezier(.2,.7,.2,1) both}
@keyframes fade-up{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.fade-up,.flash{animation:none}}

@media (max-width:520px){
  .date-grid,.cal-head{gap:6px}
  .date-cell .dnum{font-size:1.3rem}
  .date-cell .dmon{font-size:.52rem}
  .cal-head span{font-size:.54rem;letter-spacing:.08em}
  .card::after{inset:6px}
  .date-note{bottom:2px;font-size:.5rem}   /* small cells: name lower + smaller, clear of "jul." */
}
