/* ============================================================
   A FONTE DA SAUDADE — a nossa história
   100% offline. Nada aqui sai do navegador.
   ============================================================ */

/* ---------- Fontes locais ---------- */
@font-face{
  font-family:'Fraunces';
  src:url('assets/fonts/Fraunces.ttf') format('truetype');
  font-weight:100 900; font-style:normal; font-display:swap;
}
@font-face{
  font-family:'EBGaramond';
  src:url('assets/fonts/EBGaramond.ttf') format('truetype');
  font-weight:400 800; font-style:normal; font-display:swap;
}
@font-face{
  font-family:'Cormorant';
  src:url('assets/fonts/Cormorant.ttf') format('truetype');
  font-weight:300 700; font-style:normal; font-display:swap;
}
@font-face{
  font-family:'CormorantItalic';
  src:url('assets/fonts/Cormorant-Italic.ttf') format('truetype');
  font-weight:300 700; font-style:italic; font-display:swap;
}
@font-face{
  font-family:'GreatVibes';
  src:url('assets/fonts/GreatVibes-Regular.ttf') format('truetype');
  font-weight:400; font-style:normal; font-display:swap;
}

/* ---------- Variáveis ---------- */
:root{
  --ink:#0a0813;
  --ink2:#120e20;
  --plum:#241634;
  --wine:#3e1730;
  --gold:#e3c283;
  --gold-soft:#d9b878;
  --rose:#e7a9a0;
  --rose-deep:#c97f78;
  --cream:#f5ecdd;
  --muted:rgba(245,236,221,.62);
  --faint:rgba(245,236,221,.34);
  --display:'Fraunces',Georgia,serif;
  --serif:'EBGaramond','Iowan Old Style',Georgia,serif;
  --corm:'Cormorant',Georgia,serif;
  --corm-i:'CormorantItalic',Georgia,serif;
  --script:'GreatVibes','Snell Roundhand',cursive;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow:hidden;background:var(--ink)}
body{
  font-family:var(--serif);
  color:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  user-select:none;
  position:relative;
}

/* ---------- Fundo: atmosfera ---------- */
#bg{position:fixed;inset:0;z-index:0;
  background:
    radial-gradient(120% 90% at 50% -10%, #2a1838 0%, rgba(20,14,32,.4) 42%, transparent 70%),
    radial-gradient(100% 80% at 50% 120%, #43162f 0%, transparent 55%),
    linear-gradient(180deg, #0c0917 0%, #0a0813 55%, #0b0814 100%);
}
#dust{position:fixed;inset:0;z-index:1;pointer-events:none}
#grain{position:fixed;inset:0;z-index:2;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
#vignette{position:fixed;inset:0;z-index:3;pointer-events:none;
  box-shadow:inset 0 0 220px 60px rgba(0,0,0,.65);
  background:radial-gradient(120% 120% at 50% 50%, transparent 55%, rgba(0,0,0,.45) 100%);
}

/* ---------- Palco ---------- */
#stage{position:fixed;inset:0;z-index:5;display:flex;align-items:center;justify-content:center}
.scene{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:7vh clamp(20px,6vw,80px);
  opacity:0;visibility:hidden;
  transition:opacity 1.1s var(--ease), transform 1.1s var(--ease);
  transform:scale(1.02);
  pointer-events:none;
  text-align:center;
}
.scene.active{opacity:1;visibility:visible;transform:scale(1);pointer-events:auto}
.scene.leaving{opacity:0;transform:scale(.985);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.scene{overflow-y:auto;-webkit-overflow-scrolling:touch}
.scene.fase{justify-content:flex-start;padding-top:clamp(56px,9vh,84px);padding-bottom:8vh;gap:.2em}
.scene.fase>*{flex:none}

/* reveal helpers */
.rv{opacity:0;transform:translateY(22px);
  transition:opacity 1.15s var(--ease), transform 1.15s var(--ease);}
.scene.active .rv.show{opacity:1;transform:translateY(0)}

/* ---------- Tipografia ---------- */
.kicker{font-family:var(--corm);font-weight:500;letter-spacing:.42em;text-transform:uppercase;
  font-size:clamp(11px,1.5vw,14px);color:var(--gold);opacity:.9;margin-bottom:1.4em}
.eyebrow{font-family:var(--corm-i);font-style:italic;color:var(--rose);
  font-size:clamp(16px,2.4vw,22px);letter-spacing:.02em;margin-bottom:.5em}
.display{font-family:var(--display);font-weight:340;line-height:1.02;letter-spacing:-.01em;
  font-size:clamp(40px,8.5vw,104px);font-optical-sizing:auto;
  font-variation-settings:'SOFT' 40,'WONK' 1,'opsz' 110;}
.h-chapter{font-family:var(--display);font-weight:330;font-size:clamp(34px,7vw,82px);line-height:1.04;
  font-variation-settings:'SOFT' 30,'opsz' 80;}
.roman{font-family:var(--corm);font-weight:400;letter-spacing:.3em;color:var(--gold);
  font-size:clamp(13px,1.8vw,17px);text-transform:uppercase;margin-bottom:1.1em}
.place{font-family:var(--corm-i);font-style:italic;color:var(--muted);
  font-size:clamp(16px,2.6vw,24px);margin-top:1.1em}
.lead{font-family:var(--serif);font-weight:400;color:var(--cream);
  font-size:clamp(19px,3vw,29px);line-height:1.55;max-width:18em;margin:0 auto}
.lead em{font-family:var(--corm-i);font-style:italic;color:var(--gold)}
.soft{color:var(--muted)}
.poem{font-family:var(--corm);font-weight:330;font-size:clamp(22px,3.6vw,34px);
  line-height:1.5;max-width:16em;color:var(--cream)}
.poem em{font-family:var(--corm-i);font-style:italic;color:var(--gold)}

/* ---------- Capa ---------- */
#cover .veil{max-width:30em}
.cover-script{font-family:var(--script);color:var(--gold);
  font-size:clamp(60px,15vw,170px);line-height:.9;
  text-shadow:0 0 40px rgba(227,194,131,.25)}
.cover-sub{font-family:var(--corm-i);font-style:italic;color:var(--muted);
  font-size:clamp(17px,2.6vw,24px);margin-top:1.4em;letter-spacing:.02em}
.notes{font-size:1.4em;letter-spacing:.3em;color:var(--gold);opacity:.7;margin-bottom:1.2em}

/* ---------- Botão começar ---------- */
.begin{margin-top:3.4em;cursor:pointer;display:inline-flex;flex-direction:column;align-items:center;gap:1.1em;
  pointer-events:auto}
.begin .ring{width:74px;height:74px;border-radius:50%;border:1px solid var(--gold);
  display:flex;align-items:center;justify-content:center;position:relative;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.begin .ring::after{content:'';position:absolute;inset:-9px;border-radius:50%;
  border:1px solid rgba(227,194,131,.25);animation:pulse 3s ease-out infinite}
.begin .ring .tri{width:0;height:0;border-left:15px solid var(--gold);
  border-top:10px solid transparent;border-bottom:10px solid transparent;margin-left:4px}
.begin:hover .ring{transform:scale(1.08);box-shadow:0 0 36px rgba(227,194,131,.35)}
.begin .label{font-family:var(--corm);letter-spacing:.38em;text-transform:uppercase;
  font-size:13px;color:var(--gold)}
@keyframes pulse{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.55);opacity:0}}

/* ---------- Fotos ---------- */
.frame{position:relative;border-radius:3px;overflow:hidden;
  box-shadow:0 30px 80px -28px rgba(0,0,0,.9), 0 0 0 1px rgba(227,194,131,.18),
             0 0 0 9px rgba(245,236,221,.04);
  background:#0c0a16;}
.frame img{display:block;width:100%;height:100%;object-fit:cover;
  filter:saturate(1.02) contrast(1.02)}
.frame::after{content:'';position:absolute;inset:0;pointer-events:none;
  box-shadow:inset 0 0 60px rgba(0,0,0,.45)}
.photo-hero{width:min(74vw,calc(72vh * .76));max-height:72vh;aspect-ratio:3/4}
.photo-wide{width:min(86vw,calc(64vh * 1.4));max-height:64vh;aspect-ratio:4/3}

.caption{font-family:var(--corm-i);font-style:italic;color:var(--rose);
  font-size:clamp(16px,2.3vw,22px);margin-top:1.4em;letter-spacing:.01em}
.narr{font-family:var(--serif);color:var(--cream);font-size:clamp(17px,2.5vw,24px);
  line-height:1.55;max-width:19em;margin:1.1em auto 0}
.narr em{font-family:var(--corm-i);font-style:italic;color:var(--gold)}

/* polaroid cluster */
.cluster{position:relative;display:flex;justify-content:center;align-items:center;
  height:min(64vh,560px);width:100%}
.cluster .frame{position:absolute;width:clamp(150px,30vw,290px);aspect-ratio:3/4}
.cluster .frame:nth-child(1){transform:rotate(-7deg) translate(-32%,4%);z-index:1}
.cluster .frame:nth-child(2){transform:rotate(4deg) translate(34%,-3%);z-index:2}
.cluster .frame:nth-child(3){transform:rotate(-2deg) translate(2%,8%);z-index:3}

/* ---------- Chat ---------- */
.chat{width:min(92vw,560px);display:flex;flex-direction:column;gap:11px}
.chat-head{font-family:var(--corm);letter-spacing:.3em;text-transform:uppercase;
  color:var(--faint);font-size:12px;margin-bottom:1.4em;text-align:center}
.bub{max-width:80%;padding:11px 16px;border-radius:18px;line-height:1.4;
  font-size:clamp(15px,2.2vw,18px);font-family:var(--serif);position:relative;
  opacity:0;transform:translateY(14px) scale(.97);
  transition:opacity .5s var(--ease),transform .5s var(--ease);
  box-shadow:0 8px 24px -12px rgba(0,0,0,.7)}
.bub.in{opacity:1;transform:none}
.bub.her{align-self:flex-start;background:linear-gradient(180deg,#241a33,#1d1428);
  border:1px solid rgba(231,169,160,.22);border-bottom-left-radius:5px;color:#f3e7e3}
.bub.him{align-self:flex-end;background:linear-gradient(180deg,#3a2a18,#2e2012);
  border:1px solid rgba(227,194,131,.28);border-bottom-right-radius:5px;color:#f7eeda}
.bub .who{display:block;font-family:var(--corm);font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;opacity:.6;margin-bottom:3px}
.bub.her .who{color:var(--rose)}
.bub.him .who{color:var(--gold)}
.typing{display:inline-flex;gap:5px;align-items:center;padding:14px 18px}
.typing span{width:7px;height:7px;border-radius:50%;background:var(--faint);
  animation:blink 1.3s infinite}
.typing span:nth-child(2){animation-delay:.2s}
.typing span:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,60%,100%{opacity:.25}30%{opacity:.9}}

/* ---------- Números ---------- */
.stats{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(24px,6vw,72px);
  max-width:1000px;margin:1.6em auto 0}
.stat{min-width:140px}
.stat .num{font-family:var(--display);font-weight:330;color:var(--gold);
  font-size:clamp(40px,7vw,76px);line-height:1;font-variation-settings:'opsz' 90}
.stat .lab{font-family:var(--corm);letter-spacing:.18em;text-transform:uppercase;
  font-size:clamp(11px,1.6vw,14px);color:var(--muted);margin-top:.7em}

/* ---------- Tempestade ---------- */
.storm-quote{font-family:var(--corm-i);font-style:italic;color:var(--cream);
  font-size:clamp(20px,3.2vw,32px);line-height:1.5;max-width:15em;margin:0 auto}
.storm-quote .who{display:block;font-family:var(--corm);font-style:normal;
  letter-spacing:.24em;text-transform:uppercase;font-size:12px;color:var(--rose);margin-top:1.4em}

/* ---------- Carta ---------- */
/* a cena centraliza via margens automáticas (não justify-content:center):
   quando a carta é mais alta que a tela, o topo continua alcançável no scroll */
.scene[data-type="letter"]{justify-content:flex-start}
.scene[data-type="letter"] .letter{margin-top:auto}
.scene[data-type="letter"] .advance{margin-bottom:auto;flex:none}
.letter{max-width:34em;text-align:left}
.letter p{font-family:var(--serif);font-size:clamp(18px,2.5vw,23px);line-height:1.72;
  color:var(--cream);margin-bottom:1.05em}
.letter p:first-child{font-family:var(--corm);font-size:clamp(24px,3.4vw,34px);color:var(--gold);
  margin-bottom:.8em}
.letter em{font-family:var(--corm-i);font-style:italic;color:var(--gold)}
.letter .sign{font-family:var(--script);color:var(--gold);font-size:clamp(40px,7vw,68px);
  line-height:1;margin-top:.5em;text-shadow:0 0 30px rgba(227,194,131,.25)}
.letter .sign-pre{font-family:var(--corm-i);font-style:italic;color:var(--muted);
  font-size:clamp(16px,2.2vw,20px);margin-bottom:.1em}

/* ---------- Final ---------- */
.replay{margin-top:2.6em;font-family:var(--corm);letter-spacing:.3em;text-transform:uppercase;
  font-size:12px;color:var(--gold);cursor:pointer;border:1px solid rgba(227,194,131,.4);
  padding:13px 26px;border-radius:40px;transition:all .4s var(--ease);background:transparent;pointer-events:auto}
.replay:hover{background:rgba(227,194,131,.1);transform:translateY(-2px)}

/* ---------- HUD ---------- */
#hud{position:fixed;z-index:30;inset:0;pointer-events:none}
.progress{position:absolute;top:26px;left:50%;transform:translateX(-50%);
  display:flex;gap:9px;align-items:center;opacity:0;transition:opacity 1s}
.progress.show{opacity:1}
.progress .dot{width:6px;height:6px;border-radius:50%;background:rgba(245,236,221,.22);
  transition:all .5s var(--ease)}
.progress .dot.on{background:var(--gold);box-shadow:0 0 10px rgba(227,194,131,.7)}
.progress .dot.cur{transform:scale(1.7)}

.hint{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  font-family:var(--corm);letter-spacing:.32em;text-transform:uppercase;font-size:11px;
  color:var(--faint);opacity:0;transition:opacity 1.2s}
.hint.show{opacity:.5;animation:breathe 3.4s ease-in-out infinite}
@keyframes breathe{0%,100%{opacity:.3}50%{opacity:.65}}

.ctrl{position:absolute;pointer-events:auto;cursor:pointer;opacity:0;transition:opacity 1s}
.ctrl.show{opacity:.75}
.ctrl:hover{opacity:1}
#sound{top:24px;right:24px;width:40px;height:40px;border-radius:50%;
  border:1px solid rgba(227,194,131,.35);display:flex;align-items:center;justify-content:center;
  background:rgba(10,8,19,.4);backdrop-filter:blur(6px)}
#sound svg{width:18px;height:18px;fill:var(--gold)}
#back{top:24px;left:24px;font-family:var(--corm);letter-spacing:.2em;text-transform:uppercase;
  font-size:11px;color:var(--muted);padding:10px 14px}

.nav-arrow{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;
  display:none;align-items:center;justify-content:center;pointer-events:auto;cursor:pointer;
  opacity:0;transition:opacity .6s}
@media(hover:hover) and (min-width:760px){
  .nav-arrow{display:flex}
  .nav-arrow.show{opacity:.4}
  .nav-arrow:hover{opacity:.85}
}
#next-a{right:18px}#prev-a{left:18px}
.nav-arrow svg{width:26px;height:26px;stroke:var(--gold);fill:none;stroke-width:1.4}

/* rain canvas overlay (storm) */
#rain{position:fixed;inset:0;z-index:4;pointer-events:none;opacity:0;transition:opacity 1.4s}

/* loading */
#loader{position:fixed;inset:0;z-index:60;background:var(--ink);display:flex;
  align-items:center;justify-content:center;flex-direction:column;gap:1.4em;transition:opacity 1s}
#loader.gone{opacity:0;pointer-events:none}
#loader .l-script{font-family:var(--script);color:var(--gold);font-size:clamp(36px,8vw,64px);opacity:.9}
#loader .l-bar{width:160px;height:1px;background:rgba(245,236,221,.15);position:relative;overflow:hidden}
#loader .l-bar i{position:absolute;inset:0;width:40%;background:var(--gold);
  animation:load 1.3s var(--ease) infinite}
@keyframes load{0%{left:-40%}100%{left:100%}}

@media (max-width:600px){
  .cluster .frame{width:clamp(118px,38vw,180px)}
  .photo-hero{width:78vw;max-height:62vh}
  .letter{text-align:left}
}
@media (prefers-reduced-motion:reduce){
  .scene,.rv,.bub{transition-duration:.4s !important}
  .begin .ring::after{animation:none}
}

/* ============================================================
   JOGO — fases e desafios
   ============================================================ */
.tiny{display:block;margin-top:1em;font-size:.62em;letter-spacing:.18em;opacity:.7}

.fase-badge{font-family:var(--corm);letter-spacing:.34em;text-transform:uppercase;
  font-size:clamp(10px,1.5vw,13px);color:var(--gold);opacity:.85;margin-bottom:.5em}
.fase-title{font-family:var(--display);font-weight:330;font-size:clamp(30px,6vw,62px);line-height:1.05;
  font-variation-settings:'SOFT' 30,'opsz' 70}
.fase-place{font-family:var(--corm-i);font-style:italic;color:var(--muted);
  font-size:clamp(15px,2.3vw,21px);margin:.5em 0 1.2em}
.scene.fase .cluster{height:min(40vh,360px);margin:.2em 0 .4em}
.scene.fase .cluster .frame{width:clamp(112px,24vw,210px)}
.fase-story{max-width:21em;margin:.4em auto 0}
.fase-story .narr{font-size:clamp(16px,2.3vw,21px);margin:.5em auto 0;max-width:21em}
.fase-story .storm-quote{font-size:clamp(17px,2.6vw,24px);margin:1em auto}

/* desafio container */
.challenge{width:min(94vw,560px);margin:1.6em auto .4em;
  border-top:1px solid rgba(227,194,131,.16);padding-top:1.6em}
.c-cta,.c-q{font-family:var(--corm);color:var(--gold);letter-spacing:.04em;
  font-size:clamp(16px,2.4vw,22px);margin-bottom:1em;line-height:1.4}
.c-q{color:var(--cream);font-family:var(--serif);font-size:clamp(17px,2.5vw,23px)}
.c-hint{font-family:var(--corm-i);font-style:italic;color:var(--rose);margin-top:1em;font-size:15px;opacity:.9}
.c-skip{margin-top:1.2em;font-family:var(--corm);letter-spacing:.2em;text-transform:uppercase;
  font-size:12px;color:var(--muted);cursor:pointer;text-decoration:underline;text-underline-offset:5px}
.c-skip:hover{color:var(--gold)}

/* choice / sequence */
.c-opts{display:flex;flex-direction:column;gap:11px}
.c-opt{font-family:var(--serif);font-size:clamp(15px,2.2vw,19px);color:var(--cream);
  background:rgba(36,22,52,.5);border:1px solid rgba(227,194,131,.22);border-radius:14px;
  padding:14px 18px;cursor:pointer;transition:all .3s var(--ease);text-align:left}
.c-opt:hover{background:rgba(58,42,24,.45);border-color:rgba(227,194,131,.5);transform:translateY(-1px)}
.c-opt.right{background:linear-gradient(180deg,#3a2a18,#2e2012);border-color:var(--gold);color:var(--gold)}
.c-opt.wrong{border-color:var(--rose-deep);color:var(--rose)}
.c-opt.dim{opacity:.35}
.seq .c-opt{text-align:center}
.seq-num{color:var(--gold);font-family:var(--corm);font-weight:600}
.shake{animation:shake .45s}
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-7px)}40%{transform:translateX(7px)}60%{transform:translateX(-5px)}80%{transform:translateX(4px)}}

/* type */
.c-typerow{display:flex;gap:10px;align-items:stretch}
.c-input{flex:1;font-family:var(--serif);font-size:clamp(16px,2.4vw,20px);color:var(--cream);
  background:rgba(36,22,52,.45);border:1px solid rgba(227,194,131,.3);border-radius:12px;
  padding:13px 16px;outline:none;transition:border-color .3s}
.c-input:focus{border-color:var(--gold)}
.c-input.right{border-color:var(--gold);color:var(--gold)}
.c-check{font-size:20px;color:var(--ink);background:var(--gold);border:none;border-radius:12px;
  width:52px;cursor:pointer;transition:transform .2s}
.c-check:hover{transform:scale(1.06)}

/* tap buttons */
.c-tap{margin-top:1.2em;font-family:var(--corm);letter-spacing:.18em;text-transform:uppercase;
  font-size:13px;color:var(--gold);background:rgba(227,194,131,.08);border:1px solid rgba(227,194,131,.4);
  border-radius:40px;padding:14px 28px;cursor:pointer;transition:all .3s var(--ease)}
.c-tap:hover{background:rgba(227,194,131,.16);transform:translateY(-2px)}
.c-tap:active{transform:scale(.96)}

/* vídeo */
.vid-wrap{position:relative;width:min(64vw,calc(46vh*.56));max-width:300px;margin:0 auto;
  aspect-ratio:9/16;border-radius:14px;overflow:hidden;background:#0c0a16;
  box-shadow:0 24px 60px -24px rgba(0,0,0,.9),0 0 0 1px rgba(227,194,131,.2)}
.vid{width:100%;height:100%;object-fit:cover;display:block}
.vid-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(10,8,19,.35);border:none;cursor:pointer}
.vid-play .ptri{width:0;height:0;border-left:26px solid var(--gold);border-top:17px solid transparent;
  border-bottom:17px solid transparent;margin-left:6px;filter:drop-shadow(0 0 14px rgba(227,194,131,.5))}

/* pétalas */
.petal-area{position:relative;width:min(86vw,420px);height:min(46vh,360px);margin:.4em auto 0}
.petal{position:absolute;background:none;border:none;font-size:30px;color:var(--rose);cursor:pointer;
  filter:drop-shadow(0 0 8px rgba(231,169,160,.5));animation:floatp 3.6s ease-in-out infinite;transition:opacity .5s,transform .5s;z-index:3}
.petal.gone{opacity:0;transform:translateY(40px) rotate(60deg) scale(.4);pointer-events:none}
@keyframes floatp{0%,100%{transform:translateY(0) rotate(-6deg)}50%{transform:translateY(-12px) rotate(8deg)}}
.petal-reveal{position:absolute;inset:0;width:100%;height:100%;opacity:1;transition:opacity 1s;z-index:1}
.petal-reveal.hidden{opacity:0}
.petal-reveal img{border-radius:8px}

/* números (count) */
.scene.fase .stats{gap:clamp(16px,4vw,40px);margin:.6em auto 0}
.stat.off{opacity:0;transform:translateY(14px)}
.stat{transition:opacity .6s var(--ease),transform .6s var(--ease)}
.stat.pop{opacity:1;transform:none}
.scene.fase .stat .num{font-size:clamp(30px,6vw,58px)}

/* segurar (hold) */
.hold-ring{position:relative;width:140px;height:140px;margin:.4em auto 0;cursor:pointer;touch-action:none}
.hold-ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.hold-ring circle{fill:none;stroke-width:5}
.hold-ring .bg{stroke:rgba(245,236,221,.14)}
.hold-ring .fg{stroke:var(--gold);transition:stroke-dashoffset .05s linear;filter:drop-shadow(0 0 8px rgba(227,194,131,.6))}
.hold-lbl{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--corm);letter-spacing:.2em;text-transform:uppercase;font-size:13px;color:var(--gold)}
.hold-ring.holding{transform:scale(1.04)}
.hold-ring.full .hold-lbl{content:'';}

/* estrada (journey) */
.road{position:relative;width:min(90vw,460px);height:80px;margin:1em auto 0}
.road-line{position:absolute;top:50%;left:0;right:0;height:2px;transform:translateY(-50%);
  background:repeating-linear-gradient(90deg,rgba(227,194,131,.5) 0 14px,transparent 14px 28px)}
.road .bus{position:absolute;top:50%;left:6%;transform:transl(-50%,-50%);font-size:30px;transition:left .4s var(--ease);filter:drop-shadow(0 4px 6px rgba(0,0,0,.5))}
.road .bus{transform:translateY(-50%)}
.road .home{position:absolute;top:50%;right:4%;transform:translateY(-50%);font-size:26px;filter:drop-shadow(0 0 10px rgba(231,108,108,.6))}
.road .bus.arrived{animation:bump .5s}
@keyframes bump{0%,100%{transform:translateY(-50%)}50%{transform:translateY(-50%) scale(1.25)}}

/* reward + advance */
.reward{font-family:var(--corm-i);font-style:italic;color:var(--rose);
  font-size:clamp(16px,2.4vw,22px);margin:1.4em auto .2em;max-width:20em;
  opacity:0;transform:translateY(10px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reward.show{opacity:1;transform:none}
.reward em{color:var(--gold);font-style:italic}
.advance{margin:1.3em auto 0;font-family:var(--corm);letter-spacing:.26em;text-transform:uppercase;
  font-size:12px;color:var(--gold);background:transparent;border:1px solid rgba(227,194,131,.45);
  border-radius:40px;padding:13px 30px;cursor:pointer;opacity:0;transform:translateY(8px);
  transition:opacity .7s var(--ease),transform .7s var(--ease),background .3s;pointer-events:none}
.advance.show{opacity:1;transform:none;pointer-events:auto}
.advance:hover{background:rgba(227,194,131,.12)}

/* ============================================================
   MAIS CARA DE JOGO
   ============================================================ */
/* placar de corações */
#score{top:22px;left:24px;font-family:var(--corm);letter-spacing:.12em;
  font-size:15px;color:var(--rose);padding:8px 14px;border-radius:30px;
  border:1px solid rgba(231,169,160,.3);background:rgba(10,8,19,.4);backdrop-filter:blur(6px)}
#score span{color:var(--faint);font-size:12px}
/* move voltar pra baixo-esquerda pra não brigar com o placar */
#back{top:auto;bottom:26px;left:22px}

/* banner FASE CONCLUÍDA */
.fase-done{position:fixed;left:50%;top:34%;transform:translate(-50%,-20px) scale(.9);
  z-index:50;font-family:var(--corm);letter-spacing:.28em;text-transform:uppercase;
  font-size:clamp(15px,2.6vw,22px);color:var(--gold);text-align:center;pointer-events:none;
  opacity:0;transition:opacity .5s var(--ease),transform .5s var(--ease);
  text-shadow:0 0 30px rgba(227,194,131,.5)}
.fase-done.in{opacity:1;transform:translate(-50%,0) scale(1)}
.fase-done span{display:block;margin-top:.5em;font-family:var(--display);text-transform:none;
  letter-spacing:0;font-size:clamp(22px,4vw,34px);color:var(--rose)}

/* corações subindo */
.spark{position:fixed;z-index:49;color:var(--rose);pointer-events:none;
  animation:rise 1.7s ease-out forwards;text-shadow:0 0 10px rgba(231,169,160,.6)}
@keyframes rise{0%{opacity:0;transform:translate(0,0) scale(.5)}
  15%{opacity:1}100%{opacity:0;transform:translate(var(--dx,0),-220px) scale(1.1)}}

/* tela de vitória */
.victory-sc .vic-crown{font-size:clamp(40px,9vw,76px);color:var(--rose);
  filter:drop-shadow(0 0 22px rgba(231,169,160,.6));margin-bottom:.3em;animation:beat 1.8s ease-in-out infinite}
@keyframes beat{0%,100%{transform:scale(1)}15%{transform:scale(1.18)}30%{transform:scale(1)}45%{transform:scale(1.12)}}
.vic-badge{font-family:var(--corm);letter-spacing:.4em;text-transform:uppercase;
  font-size:clamp(11px,1.7vw,14px);color:var(--gold);margin-bottom:1em}
.vic-hearts{display:flex;gap:6px;justify-content:center;margin:1.4em 0 .4em;flex-wrap:wrap;max-width:360px}
.vic-hearts .vh{color:var(--rose);font-size:18px;opacity:.9;
  filter:drop-shadow(0 0 6px rgba(231,169,160,.5))}

/* mecânica unir */
.unite{position:relative;width:min(92vw,480px);height:90px;margin:1em auto 0;
  display:flex;align-items:center;justify-content:center}
.unite .uh{position:absolute;top:50%;transform:translateY(-50%);font-size:30px;color:var(--rose);
  transition:left .35s var(--ease),right .35s var(--ease);filter:drop-shadow(0 0 8px rgba(231,169,160,.6));z-index:2}
.unite .ha{left:8%}.unite .hb{right:8%}
.unite .ult{position:absolute;top:0;font-family:var(--corm-i);font-style:italic;color:var(--muted);font-size:14px}
.unite .tagA{left:6%}.unite .tagB{right:6%}
.unite.united .uh{font-size:40px}
.unite::before{content:'';position:absolute;left:8%;right:8%;top:50%;height:1px;
  background:repeating-linear-gradient(90deg,rgba(231,169,160,.35) 0 8px,transparent 8px 16px)}

/* cover tiny */
.tiny{opacity:.62}

/* cluster com foto em destaque (ex.: a neve em Granada) */
.cluster.feature{height:min(46vh,420px)}
.cluster.feature .frame{position:absolute}
.cluster.feature .frame:nth-child(1){width:clamp(96px,19vw,168px);
  transform:rotate(-8deg) translate(-66%,-2%);z-index:1;opacity:.92}
.cluster.feature .frame:nth-child(2){width:clamp(170px,34vw,310px);
  transform:rotate(2deg) translate(10%,2%);z-index:3}
.scene.fase .cluster.feature .frame:nth-child(2){width:clamp(170px,34vw,310px)}
/* 3ª foto no modo destaque: pequena, à direita, atrás da principal */
.cluster.feature .frame:nth-child(3){width:clamp(96px,19vw,168px);
  transform:rotate(7deg) translate(72%,10%);z-index:2;opacity:.92}
/* a foto destacada (310px de largura, 3/4) é mais alta que o cluster padrão da fase */
.scene.fase .cluster.feature{height:min(46vh,430px)}
