/* ————————————————————————————————————————————
   Justin & Alexandria — v2 "Golden Hour"
   ink intro · full-bleed film · Greek stefana
   mobile-first
———————————————————————————————————————————— */
:root{
  --noir:#1c1712;
  --noir-2:#241d16;
  --paper:#f6f1e7;
  --paper-deep:#ece4d3;
  --ink:#2c241b;
  --ink-2:rgba(44,36,27,.84);
  --gold:#b78f4e;
  --gold-bright:#d9b478;
  --gold-soft:rgba(183,143,78,.4);
  --gold-ink:#7f612e;
  --blush:#e8c5a8;
  --cream:#f6f1e7;
  --cream-2:rgba(246,241,231,.85);
  --cream-line:rgba(246,241,231,.25);
  --line:rgba(44,36,27,.16);
  --serif:'Fraunces',Georgia,serif;
  --sans:'General Sans',system-ui,sans-serif;
  --pad:clamp(1.25rem,4.5vw,3.5rem);
}
*{margin:0;padding:0;box-sizing:border-box}
html{background:var(--noir);font-size:112.5%}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
html:not(.js){scroll-behavior:smooth}
body{
  background:var(--paper);color:var(--ink);font-family:var(--sans);
  font-weight:300;font-size:1.06rem;line-height:1.7;overflow-x:clip;
  -webkit-font-smoothing:antialiased;
}
.js body.locked{overflow:hidden;height:100svh}
::selection{background:var(--gold);color:var(--paper)}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
em{font-family:var(--serif);font-style:italic;font-weight:380}
.kicker{font-size:.7rem;letter-spacing:.42em;text-transform:uppercase;font-weight:400}

/* grain */
.grain{position:fixed;inset:-100%;width:300%;height:300%;pointer-events:none;z-index:120;opacity:.055;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='240' height='240' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 9s steps(10) infinite}
@keyframes grain{0%,100%{transform:translate(0,0)}10%{transform:translate(-5%,-10%)}20%{transform:translate(-15%,5%)}30%{transform:translate(7%,-25%)}40%{transform:translate(-5%,25%)}50%{transform:translate(-15%,10%)}60%{transform:translate(15%,0)}70%{transform:translate(0,15%)}80%{transform:translate(3%,35%)}90%{transform:translate(-10%,10%)}}

/* cursor — a single gold ember (desktop pointers only) */
#cursor{position:fixed;top:0;left:0;width:10px;height:10px;border-radius:50%;
  background:radial-gradient(circle,var(--gold-bright),rgba(217,180,120,0) 70%);
  box-shadow:0 0 14px 3px rgba(217,180,120,.35);
  pointer-events:none;z-index:300;transform:translate(-50%,-50%);mix-blend-mode:screen}
@media (hover:none){#cursor{display:none}}

/* ---------- intro: the ink writes ---------- */
#intro{position:fixed;inset:0;z-index:200;background:var(--noir);
  display:flex;align-items:center;justify-content:center}
html:not(.js) #intro{display:none}
.intro-inner{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:0 6vw;width:100%}
.script svg{width:100%;height:auto;color:var(--gold-bright);overflow:visible}
.script{filter:drop-shadow(0 0 18px rgba(217,180,120,.22))}
.script-l1{width:min(46vw,300px);align-self:flex-start;margin-left:8vw}
.script-l2{width:min(78vw,560px);margin-top:-2vw}
.js .script path{opacity:0}
.intro-mark{width:74px;margin-top:2.2rem;color:var(--gold)}
.intro-mark svg{width:100%;height:auto}
.js .intro-mark .st-ring circle,.js .intro-mark .st-ribbon{stroke-dasharray:260;stroke-dashoffset:260}
.js .intro-mark use{opacity:0}
.intro-date{margin-top:1.3rem;font-size:.68rem;letter-spacing:.5em;color:var(--cream-2);text-transform:uppercase}
.js .intro-date{opacity:0}
.intro-skip{position:absolute;bottom:max(2.2rem,env(safe-area-inset-bottom));left:50%;transform:translateX(-50%);
  font-size:.66rem;letter-spacing:.4em;text-transform:uppercase;color:rgba(246,241,231,.55);
  padding:.8rem 1.4rem;transition:color .3s}
.intro-skip:hover{color:var(--gold-bright)}
@media(min-width:700px){
  .intro-inner{max-width:760px}
  .script-l1{width:min(30vw,300px);margin-left:4vw}
  .script-l2{width:min(54vw,600px)}
}

/* ---------- nav ---------- */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;
  padding:.85rem var(--pad);transition:background .45s,box-shadow .45s;color:var(--cream)}
nav::before{content:"";position:absolute;inset:0 0 -2.2rem;z-index:-1;pointer-events:none;
  background:linear-gradient(to bottom,rgba(28,23,18,.85),rgba(28,23,18,.45) 55%,rgba(28,23,18,0));
  transition:opacity .45s}
nav.on-paper::before,nav.solid::before{opacity:0}
nav.solid{background:rgba(28,23,18,.72);backdrop-filter:blur(14px);box-shadow:0 1px 0 rgba(246,241,231,.08)}
nav.on-paper{color:var(--ink)}
nav.on-paper.solid{background:rgba(246,241,231,.8);box-shadow:0 1px 0 var(--line)}
.n-mark{width:46px;display:block;color:currentColor;opacity:.95}
.n-mark svg{width:100%;height:auto}
.n-links{display:none;gap:2.4rem;font-size:.68rem;letter-spacing:.3em;text-transform:uppercase}
.n-links a{position:relative;padding:.25rem 0}
.n-links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;background:var(--gold-bright);
  transform:scaleX(0);transform-origin:right;transition:transform .4s cubic-bezier(.6,0,.2,1)}
.n-links a:hover::after{transform:scaleX(1);transform-origin:left}
.n-rsvp{font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;font-weight:500;
  border:1px solid var(--gold-bright);color:var(--cream);background:rgba(28,23,18,.45);border-radius:99px;padding:.6rem 1.4rem;
  transition:background .35s,color .35s}
nav.on-paper .n-rsvp{background:transparent}
nav.on-paper .n-rsvp{border-color:var(--gold-ink);color:var(--gold-ink)}
.n-rsvp:hover{background:var(--gold-bright);color:var(--noir)}
@media(min-width:760px){.n-links{display:flex}}

/* ---------- hero ---------- */
.hero{position:relative;height:100svh;min-height:560px;overflow:hidden;color:var(--cream)}
.hero-img{position:absolute;inset:0}
.hero-img img{width:100%;height:100%;object-fit:cover;object-position:50% 34%;
  transform-origin:50% 40%;filter:saturate(.96)}
.hero-scrim{position:absolute;inset:0;
  background:linear-gradient(to top,rgba(28,23,18,.92) 0%,rgba(28,23,18,.68) 26%,rgba(28,23,18,.18) 56%,rgba(28,23,18,.5) 100%)}
.hero-content{position:absolute;left:0;right:0;bottom:0;padding:0 var(--pad) clamp(4.6rem,9svh,6rem);z-index:2}
.hero .kicker{display:inline-block;color:var(--cream);margin-bottom:1.1rem;
  background:rgba(28,23,18,.72);padding:.5em 1.1em;border-radius:99px}
.hero h1{text-shadow:0 2px 30px rgba(28,23,18,.55);font-family:var(--serif);font-weight:430;font-variation-settings:'opsz' 144;
  font-size:clamp(2.9rem,11vw,7.6rem);line-height:1.02;letter-spacing:-.012em;text-wrap:balance}
.hero h1 em{color:var(--gold-bright);font-weight:340}
.hero h1 .hl{display:block;overflow:hidden;padding:.08em 0;margin:-.08em 0}
.hero h1 .hl>span{display:inline-block}
.js .hero h1 .hl>span{transform:translateY(118%)}
.hero-sub{margin-top:1.1rem;font-family:var(--serif);font-weight:380;font-variation-settings:'opsz' 60;
  font-size:clamp(1.2rem,3.2vw,1.62rem);line-height:1.5;color:rgba(246,241,231,.94);max-width:36rem;letter-spacing:.002em}
.hero-sub em{color:var(--cream);font-weight:360}
.hero-date{display:flex;flex-wrap:wrap;align-items:center;gap:.65rem;margin-top:1.5rem;
  font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--cream);text-shadow:0 1px 12px rgba(28,23,18,.6)}
.hero-date i.ico{display:inline-flex;align-items:center;color:var(--gold-bright)}
.hero-date i.ico svg{width:.5em;height:auto}
.hero-cta{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;margin-top:1.9rem}
.btn-gold{display:inline-block;background:var(--gold-bright);color:var(--noir);border-radius:99px;
  padding:1rem 2.3rem;font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;font-weight:500;
  transition:background .3s,transform .25s}
.btn-gold:hover{background:var(--blush)}
.btn-ghost{display:inline-block;border:1px solid var(--cream-line);color:var(--cream-2);border-radius:99px;
  padding:1rem 1.9rem;font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;transition:border-color .3s,color .3s}
.btn-ghost:hover{border-color:var(--gold-bright);color:var(--gold-bright)}
.cd-chip{font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;color:var(--cream-2);
  font-variant-numeric:tabular-nums}
.cue{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);z-index:2}
.cue span{display:block;width:1px;height:42px;background:var(--cream-line);position:relative;overflow:hidden}
.cue span::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--gold-bright);
  animation:drop 1.9s cubic-bezier(.6,0,.4,1) infinite}
@keyframes drop{to{top:110%}}
.js .rl{opacity:0}
html:not(.js) .rl{opacity:1}

/* ---------- film ---------- */
.film{position:relative;height:100svh;min-height:540px;overflow:hidden;color:var(--cream)}
.film-media{position:absolute;inset:0}
.film-media img{width:100%;height:114%;object-fit:cover;object-position:50% 30%;will-change:transform}
.film::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to top,rgba(28,23,18,.8),rgba(28,23,18,.12) 48%,rgba(28,23,18,.26))}
.film-cap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:5rem var(--pad) clamp(3rem,9svh,5.5rem);text-align:left;
  background:linear-gradient(to top,rgba(28,23,18,.66),rgba(28,23,18,0))}
.film-cap .kicker{display:inline-block;color:var(--cream);margin-bottom:.9rem;
  background:rgba(28,23,18,.72);padding:.5em 1.1em;border-radius:99px}
.film-cap .cap{font-family:var(--serif);font-weight:400;font-variation-settings:'opsz' 100;
  font-size:clamp(1.7rem,5.4vw,3.6rem);line-height:1.18;letter-spacing:-.01em;max-width:18em;
  text-shadow:0 2px 28px rgba(28,23,18,.65)}
.film-cap .cap em{color:var(--blush)}
.film-cap .cap .cl{display:block;overflow:hidden;padding:.07em 0;margin:-.07em 0}
.film-cap .cap .cl>span{display:inline-block}

/* ---------- details ---------- */
.details{background:var(--paper);padding:clamp(4.5rem,11vh,8rem) var(--pad);position:relative}
.d-mark{width:84px;margin:0 auto 2.2rem;color:var(--gold)}
.d-mark svg{width:100%;height:auto}
.d-lead{font-family:var(--serif);font-weight:380;font-size:clamp(1.35rem,3.4vw,2.1rem);line-height:1.45;
  max-width:46rem;margin:0 auto;text-align:center;letter-spacing:-.005em}
.d-lead em{color:var(--gold-ink)}
.d-grid{display:grid;grid-template-columns:1fr;gap:2.6rem;max-width:62rem;margin:clamp(3rem,7vh,5rem) auto 0}
.d-col{border-left:1px solid var(--gold-soft);padding-left:1.6rem}
.d-orn{display:block;color:var(--gold);margin-bottom:1.1rem}
.d-orn svg{height:1.7rem;width:auto;display:block}
.orn-spark svg{height:1.15rem;margin-top:.3rem}
.d-col h2{font-family:var(--serif);font-weight:430;font-size:clamp(1.7rem,3.6vw,2.4rem);line-height:1.05;
  letter-spacing:-.01em;margin-bottom:1.1rem}
.d-when{font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold-ink);font-weight:500;margin-bottom:.7rem}
.d-name{font-weight:400;font-size:1.08rem;margin-bottom:.15rem}
.d-addr{color:var(--ink-2);font-size:.98rem}
.d-note{margin-top:.9rem;color:var(--ink-2);font-size:1rem;max-width:26rem}
.d-links{display:flex;gap:1.6rem;margin-top:1.2rem}
.lnk{font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;font-weight:500;color:var(--gold-ink);
  border-bottom:1px solid var(--gold-soft);padding-bottom:.3rem;transition:color .3s,border-color .3s}
.lnk:hover{color:var(--ink);border-color:var(--ink)}
.d-gifts{max-width:46rem;margin:clamp(3rem,7vh,4.5rem) auto 0;text-align:center;
  border:1px solid var(--gold-soft);padding:1.7rem clamp(1.2rem,4vw,2.6rem);position:relative}
.d-gifts::before{content:"";position:absolute;inset:.45rem;border:1px solid var(--line);pointer-events:none}
.d-gifts p{color:var(--ink-2);font-size:1rem}
.d-gifts em{color:var(--gold-ink);font-size:1.15em}
@media(min-width:760px){.d-grid{grid-template-columns:1fr 1fr;gap:4rem}}

/* ---------- travel + places ---------- */
.travel{background:var(--paper);padding:0 var(--pad) clamp(4rem,10vh,7rem)}
.t-grid{display:grid;grid-template-columns:1fr;gap:1.8rem;max-width:62rem;margin:0 auto}
.t-i{border-top:1px solid var(--line);padding-top:1.3rem}
.t-k{font-family:var(--serif);font-style:italic;font-weight:400;font-size:1.4rem;color:var(--gold-ink);display:block;margin-bottom:.5rem}
.t-i p{color:var(--ink-2);font-size:1rem}
@media(min-width:760px){.t-grid{grid-template-columns:1fr 1fr 1fr;gap:3rem}}

/* ---------- gallery filmstrip ---------- */
.gallery{background:var(--noir);color:var(--cream);padding:clamp(4rem,10vh,7rem) 0}
.g-head{display:flex;align-items:baseline;justify-content:space-between;padding:0 var(--pad);margin-bottom:2.2rem}
.g-head h2{font-family:var(--serif);font-weight:400;font-size:clamp(2.2rem,6vw,3.8rem);letter-spacing:-.01em}
.g-head h2 em{color:var(--gold-bright)}
.g-hint{font-size:.64rem;letter-spacing:.34em;text-transform:uppercase;color:rgba(246,241,231,.5)}
.gal-stage{overflow:hidden}
.strip{display:flex;gap:clamp(.8rem,1.6vw,1.4rem);overflow-x:auto;padding:0 var(--pad) 1.4rem;
  scroll-snap-type:x proximity;scrollbar-width:none}
.strip::-webkit-scrollbar{display:none}
.strip figure{flex:0 0 auto;scroll-snap-align:center;position:relative}
@media(min-width:920px) and (hover:hover){
  .strip{overflow:visible;width:max-content;scroll-snap-type:none;will-change:transform}
}
.strip img{height:min(60svh,520px);width:auto;border-radius:6px;
  filter:saturate(.97);transition:transform .6s cubic-bezier(.2,.6,.2,1);user-select:none;-webkit-user-drag:none}
.strip figure:hover img{transform:scale(1.025)}
.strip figcaption{position:absolute;left:0;right:0;bottom:0;padding:2.4rem .9rem .8rem;font-size:.62rem;letter-spacing:.3em;
  text-transform:uppercase;color:var(--cream);border-radius:0 0 6px 6px;
  background:linear-gradient(to top,rgba(28,23,18,.82),rgba(28,23,18,0))}

/* ---------- rsvp ---------- */
.rsvp{background:var(--noir);color:var(--cream);padding:clamp(4.5rem,11vh,8rem) var(--pad);position:relative}
.rsvp::before{content:"";position:absolute;left:var(--pad);right:var(--pad);top:0;height:1px;background:rgba(246,241,231,.12)}
.r-script{max-width:min(620px,86vw);margin:0 auto 1.6rem;color:var(--gold-bright);
  filter:drop-shadow(0 0 16px rgba(217,180,120,.18))}
.r-script svg{width:100%;height:auto}
.r-deadline{text-align:center;font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--blush);margin-bottom:3rem}
#rsvp-form{display:flex;flex-direction:column;gap:2rem;max-width:34rem;margin:0 auto}
.f-row{display:flex;flex-direction:column;gap:.5rem}
.f-row label,.f-legend{font-size:.66rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-bright)}
.f-row input[type=text],.f-row input[type=email],.f-row textarea{
  background:transparent;border:0;border-bottom:1px solid var(--cream-line);color:var(--cream);
  font-family:var(--serif);font-size:1.3rem;font-weight:400;padding:.45rem 0 .65rem;border-radius:0;
  transition:border-color .35s;outline:none;resize:vertical}
.f-row input::placeholder,.f-row textarea::placeholder{color:rgba(246,241,231,.3);font-style:italic;font-size:.9em}
.f-row input:focus,.f-row textarea:focus{border-color:var(--gold-bright)}
.attend-cards{display:grid;grid-template-columns:1fr;gap:.9rem}
.acard{position:relative;cursor:pointer}
.acard input{position:absolute;opacity:0;pointer-events:none}
.acard span{display:flex;flex-direction:column;gap:.25rem;border:1px solid var(--cream-line);
  border-radius:6px;padding:1.15rem 1.3rem;transition:border-color .3s,background .3s}
.acard b{font-family:var(--serif);font-weight:430;font-size:1.18rem}
.acard i{font-style:italic;font-family:var(--serif);font-size:.95rem;color:rgba(246,241,231,.6)}
.acard input:checked+span{border-color:var(--gold-bright);background:rgba(217,180,120,.1)}
.acard input:focus-visible+span{outline:1px solid var(--gold-bright);outline-offset:3px}
.stepper{display:flex;align-items:center;gap:1.3rem}
.st-btn{width:46px;height:46px;border:1px solid var(--cream-line);border-radius:50%;font-size:1.25rem;
  color:var(--cream);transition:border-color .3s,background .3s;line-height:1}
.st-btn:hover{border-color:var(--gold-bright);background:rgba(217,180,120,.1)}
#st-out{font-family:var(--serif);font-size:1.8rem;min-width:2ch;text-align:center;font-variant-numeric:tabular-nums}
.hp{position:absolute;left:-5000px;opacity:0;height:0;width:0}
.submit{align-self:center;display:inline-flex;align-items:center;gap:.7rem}
.submit .ico{display:inline-flex}.submit .ico svg{width:.75em;height:auto}
.submit[disabled]{opacity:.55;pointer-events:none}
.f-error{color:#e8a9a0;font-size:.92rem;min-height:1.2em;font-style:italic;font-family:var(--serif);text-align:center}
.rsvp-success{text-align:center;max-width:34rem;margin:0 auto}
.s-big{font-family:var(--serif);font-style:italic;font-weight:380;font-size:clamp(2.4rem,6vw,4rem);
  color:var(--gold-bright);line-height:1.08}
.s-sub{margin:1.4rem 0 2rem;color:rgba(246,241,231,.78);font-size:1.05rem;line-height:1.85}
.rsvp .lnk{color:var(--blush);border-color:rgba(232,197,168,.4)}
.rsvp .lnk:hover{color:var(--cream);border-color:var(--cream)}
@media(min-width:560px){.attend-cards{grid-template-columns:1fr 1fr}}

/* ---------- footer ---------- */
footer{background:var(--paper);text-align:center;padding:clamp(3.5rem,8vh,5.5rem) var(--pad) 2.6rem}
.f-mark{width:72px;margin:0 auto;color:var(--gold)}
.f-mark svg{width:100%;height:auto}
.f-script{max-width:300px;margin:1.4rem auto .9rem;color:var(--ink)}
.f-script svg{width:100%;height:auto}
footer p{font-size:.68rem;letter-spacing:.34em;text-transform:uppercase;color:var(--ink-2)}

/* ---------- motion prefs ---------- */
@media (prefers-reduced-motion:reduce){
  .grain,.cue span::after{animation:none}
  *{scroll-behavior:auto!important}
}

/* ---------- the dissolve: proposal → courthouse ---------- */
.film-x{position:relative;height:270lvh;color:var(--cream);background:var(--noir)}
.fx-sticky{position:sticky;top:0;height:100lvh;min-height:540px;overflow:hidden}
.fx-layer{position:absolute;inset:0;will-change:opacity,transform}
.fx-layer img{width:100%;height:104%;object-fit:cover;will-change:transform}
.fx-a img{object-position:50% 30%}
.fx-b img{object-position:50% 12%}   /* keep his head — the B&W crop was too tight */
.fx-layer::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to top,rgba(28,23,18,.8),rgba(28,23,18,.12) 48%,rgba(28,23,18,.26))}
.fx-b{opacity:0}
.fx-layer .film-cap{z-index:2}
.fx-dust{position:absolute;inset:0;width:100%;height:100%;z-index:3;pointer-events:none;mix-blend-mode:screen}

/* ---------- i18n: language picker, RU fonts, translated RSVP heading ---------- */
.intro-lang{position:absolute;bottom:max(2.4rem,env(safe-area-inset-bottom));left:50%;transform:translateX(-50%);
  display:flex;align-items:center;gap:.5rem;z-index:3}
.js .intro-lang{opacity:0}
.lang-btn{font-family:var(--serif);font-style:italic;font-weight:400;font-size:1.18rem;
  color:rgba(246,241,231,.6);padding:.4rem .7rem;border-radius:99px;
  transition:color .3s,background .3s;line-height:1}
.lang-btn:hover{color:var(--gold-bright)}
.lang-btn.on{color:var(--noir);background:var(--gold-bright)}
.lang-sep{color:rgba(246,241,231,.3);font-size:.8rem}
@media(max-width:480px){.lang-btn{font-size:1.04rem;padding:.35rem .55rem}.intro-lang{gap:.3rem}}

/* the RSVP cursive SVG is English-only; other languages get a styled heading */
.r-script-txt{display:none;text-align:center;font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:clamp(2.6rem,7vw,5rem);line-height:1.05;color:var(--gold-bright);margin-bottom:.2rem;
  text-shadow:0 0 18px rgba(217,180,120,.4)}
html:not([lang="en"]) .r-script{display:none}
html:not([lang="en"]) .r-script-txt{display:block}

/* Russian: Cyrillic-capable display + text faces, same Golden-Hour register */
html[lang="ru"]{--serif:'Playfair Display',Georgia,serif;--sans:'Manrope',system-ui,sans-serif}
html[lang="ru"] .kicker,html[lang="ru"] .d-when,html[lang="ru"] .lnk,
html[lang="ru"] .n-links,html[lang="ru"] .g-hint,html[lang="ru"] .f-row label,
html[lang="ru"] .f-legend,html[lang="ru"] .hero-date{letter-spacing:.18em}

/* adults-only line under the RSVP deadline */
.r-adults{text-align:center;font-family:var(--serif);font-style:italic;font-size:1.02rem;
  color:var(--blush);margin:-1.8rem 0 3rem;opacity:.92}

/* ---------- readability bumps (all languages) ---------- */
/* hero date + CTA sit over the photo — heavier + stronger shadow */
.hero-date{font-weight:500;color:var(--cream);
  text-shadow:0 1px 3px rgba(28,23,18,.75),0 2px 18px rgba(28,23,18,.9)}
.cd-chip{font-weight:500;color:var(--cream);
  text-shadow:0 1px 3px rgba(28,23,18,.75),0 1px 14px rgba(28,23,18,.85)}
.btn-ghost{color:var(--cream);font-weight:500;border-color:rgba(246,241,231,.5)}
/* footer date under the script — a touch heavier */
footer p{font-weight:600;color:#544a3d}
/* small body paragraphs on paper — heavier + more solid ink */
.d-addr,.d-note,.t-i p,.d-name,.r-note{font-weight:400;color:#4a4236}
.d-name{font-weight:500;color:var(--ink)}

/* mobile hero: lift the kicker off her face — eyebrow at top, the rest at the bottom */
@media(max-width:760px){
  .hero-content{top:0;display:flex;flex-direction:column;justify-content:space-between;padding-top:5.4rem}
  .hero .kicker{margin-bottom:0;align-self:flex-start}
  .hero-lower{display:flex;flex-direction:column}
  .cue{display:none}
}
