/* ============================================================
   LIBLIB — Landing (Édition Maison)
   Light editorial system · ivory / plum / rose
   ============================================================ */
:root{
  /* paper / ink */
  --paper:#FBF2EE;
  --paper-2:#F5E6E0;
  --paper-3:#F1DCD5;
  --ink:#23121C;
  --ink-2:#3a2530;
  --ink-soft:#7a6068;
  --line:rgba(35,18,28,.12);
  --line-2:rgba(35,18,28,.07);

  /* rose */
  --rose:#F23C7F;
  --rose-deep:#C81E5E;
  --rose-bright:#FF5C9A;
  --blush:#FCE0EA;

  /* dark showcase */
  --plum:#190A14;
  --plum-2:#2a0f20;

  --font-display:"DM Serif Display",Georgia,serif;
  --font-body:"Hanken Grotesk",system-ui,sans-serif;

  --maxw:1280px;
  --ease:cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  line-height:1.5;
  font-weight:400;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--rose);color:#fff}

/* paper grain via subtle radial tints */
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(60% 50% at 85% 0%,rgba(242,60,127,.10),transparent 60%),
    radial-gradient(50% 40% at 0% 100%,rgba(242,60,127,.06),transparent 60%);
}

/* ---- type helpers ---- */
.eyebrow{
  font-family:var(--font-body);font-weight:700;
  font-size:.74rem;letter-spacing:.34em;text-transform:uppercase;
  color:var(--rose-deep);display:inline-flex;align-items:center;gap:.85em;
}
.eyebrow::before{content:"";width:30px;height:1.5px;background:var(--rose);display:inline-block}
.eyebrow.center{justify-content:center}
.eyebrow.center::before{display:none}

h1,h2,h3{font-family:var(--font-display);font-weight:400;line-height:1.02;letter-spacing:-.01em}
em,.it{font-style:italic}
.rose{color:var(--rose)}
.serif{font-family:var(--font-display)}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 48px}

/* ---- buttons ---- */
.btn{
  font-family:var(--font-body);font-weight:700;font-size:1rem;cursor:pointer;border:none;
  border-radius:100px;padding:16px 30px;display:inline-flex;align-items:center;gap:11px;
  transition:.3s var(--ease);white-space:nowrap;
}
.btn--primary{background:var(--rose);color:#fff;box-shadow:0 14px 30px -12px rgba(242,60,127,.7)}
.btn--primary:hover{background:var(--rose-deep);transform:translateY(-2px);box-shadow:0 20px 38px -12px rgba(242,60,127,.85)}
.btn--ink{background:var(--ink);color:var(--paper)}
.btn--ink:hover{transform:translateY(-2px);background:#000}
.btn--ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.btn--ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn--light{background:#fff;color:var(--ink)}
.btn--light:hover{transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(0,0,0,.3)}
.btn--sm{padding:12px 22px;font-size:.94rem}
.btn .arrow{transition:transform .3s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}

/* ============================================================ NAV */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 48px;transition:.4s var(--ease);border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(251,242,238,.82);backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid var(--line);padding:14px 48px;
}
.nav__logo{height:30px;width:auto}
.nav__links{display:flex;gap:40px;align-items:center}
.nav__links a{font-size:.98rem;font-weight:600;color:var(--ink-2);position:relative;transition:color .25s}
.nav__links a:hover{color:var(--rose-deep)}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--rose);transition:width .3s var(--ease)}
.nav__links a:hover::after{width:100%}
.nav__right{display:flex;align-items:center;gap:20px}

.langs{display:flex;gap:4px;background:rgba(35,18,28,.05);border:1px solid var(--line);border-radius:100px;padding:4px}
.lang{
  min-width:38px;height:32px;padding:0 12px;border-radius:100px;border:none;background:transparent;cursor:pointer;
  font-family:var(--font-body);font-size:.78rem;font-weight:700;letter-spacing:.05em;color:var(--ink-soft);
  transition:.25s var(--ease);
}
.lang:hover{color:var(--ink)}
.lang.active{background:var(--ink);color:var(--paper)}

/* ============================================================ PHONE STAGE (airy, no box) */
.stage{position:relative;display:grid;place-items:center;min-height:560px}
.glowblob{
  position:absolute;z-index:0;width:74%;height:66%;border-radius:46% 54% 50% 50%/52% 48% 52% 48%;
  background:radial-gradient(circle at 50% 45%,rgba(242,60,127,.30),rgba(242,60,127,0) 68%);
  filter:blur(28px);
}
.glowblob.b2{width:46%;height:48%;left:18%;top:14%;background:radial-gradient(circle,rgba(255,160,120,.22),transparent 70%)}
.bignum{
  position:absolute;z-index:1;top:-6%;font-family:var(--font-display);font-style:italic;line-height:.8;
  font-size:clamp(7rem,15vw,13rem);color:rgba(200,30,94,.12);pointer-events:none;user-select:none;
}
.bignum.l{left:-2%}.bignum.r{right:-2%}

/* device frame */
.floaty{position:relative;z-index:2}
.device{
  --w:300px;position:relative;width:var(--w);
  background:linear-gradient(155deg,#1b1b22,#08080c);
  border-radius:calc(var(--w)*.135);padding:calc(var(--w)*.028);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.05) inset,
    0 2px 3px rgba(255,255,255,.12) inset,
    0 46px 60px -28px rgba(35,8,22,.5),
    0 22px 34px -22px rgba(35,8,22,.4);
}
.device--tiltL{transform:rotate(-4deg)}
.device--tiltR{transform:rotate(4deg)}
.device::after{content:"";position:absolute;left:50%;bottom:-8%;transform:translateX(-50%);width:78%;height:9%;
  background:radial-gradient(ellipse,rgba(35,8,22,.34),transparent 70%);filter:blur(9px);z-index:-1}
.device__screen{position:relative;border-radius:calc(var(--w)*.105);overflow:hidden;background:#000;line-height:0;aspect-ratio:224/478}
.device__screen img{width:100%;height:100%;object-fit:cover;display:block}
.island{position:absolute;z-index:4;top:calc(var(--w)*.03);left:50%;transform:translateX(-50%);
  width:calc(var(--w)*.26);height:calc(var(--w)*.072);background:#000;border-radius:100px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}

/* floating glass chips (light context) */
.chip{
  position:absolute;z-index:5;display:inline-flex;align-items:center;gap:8px;white-space:nowrap;
  background:rgba(255,255,255,.92);backdrop-filter:blur(8px);
  border:1px solid var(--line);border-radius:100px;
  padding:10px 16px;font-size:.84rem;font-weight:700;color:var(--ink);
  box-shadow:0 18px 34px -14px rgba(35,8,22,.32);
}
.chip .dot{width:8px;height:8px;border-radius:50%;background:var(--rose);box-shadow:0 0 10px var(--rose);animation:pulse 2s infinite}
.chip .star{color:#ffb400}
.chip b{color:var(--rose-deep)}
.chip--dark{background:var(--ink);color:#fff;border-color:transparent}
.chip--dark b{color:var(--rose-bright)}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}

/* ============================================================ HERO */
.hero{min-height:100vh;display:flex;align-items:center;padding:160px 0 80px}
.hero__grid{display:grid;grid-template-columns:1.02fr .98fr;gap:60px;align-items:center}
.badge{
  display:inline-flex;align-items:center;gap:10px;margin-bottom:30px;
  background:#fff;border:1px solid var(--line);border-radius:100px;
  padding:9px 18px;font-size:.86rem;font-weight:600;color:var(--ink-2);
  box-shadow:0 6px 16px -10px rgba(35,18,28,.3);
}
.badge .dot{width:8px;height:8px;border-radius:50%;background:var(--rose);box-shadow:0 0 10px var(--rose);animation:pulse 2s infinite}
.hero h1{font-size:clamp(3.2rem,6.6vw,6.6rem);letter-spacing:-.02em;margin-bottom:30px}
.hero h1 em{color:var(--rose);font-style:italic}
.hero__sub{font-size:1.2rem;color:var(--ink-soft);max-width:34ch;margin-bottom:40px;line-height:1.6}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:48px}
.proof{display:flex;align-items:center;gap:18px}
.avatars{display:flex}
.avatars .av{width:46px;height:46px;border-radius:50%;margin-left:-14px;border:3px solid var(--paper);box-shadow:0 4px 10px rgba(35,18,28,.18)}
.avatars .av:first-child{margin-left:0}
.proof__txt .stars{color:#ffb400;font-size:.95rem;letter-spacing:2px}
.proof__txt b{font-weight:800}
.proof__txt small{display:block;color:var(--ink-soft);font-size:.88rem;margin-top:3px}

.hero__stage{position:relative}
.hero__stage .device{--w:340px}
.hero .chip--rating{top:7%;left:0}
.hero .chip--live{top:32%;right:-3%}
.hero .chip--count{bottom:11%;left:5%}
.hero .chip--msg{bottom:33%;right:1%}
.float{animation:float 7s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}

/* ============================================================ STATS */
.stats{padding:30px 0 0}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line)}
.stat{padding:46px 30px;text-align:center;border-right:1px solid var(--line);position:relative}
.stat:last-child{border-right:none}
.stat .num{font-family:var(--font-display);font-size:clamp(2.8rem,5vw,4.4rem);line-height:1;color:var(--ink)}
.stat .num .suf{color:var(--rose)}
.stat .lbl{margin-top:12px;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);font-weight:700}

/* ============================================================ FEATURE */
.feat{padding:120px 0}
.feat__row{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.feat__row.rev .feat__stage{order:2}
.feat h2{font-size:clamp(2.6rem,4.8vw,4.6rem);margin:24px 0 26px;letter-spacing:-.015em}
.feat h2 em{color:var(--rose);font-style:italic}
.feat p{font-size:1.16rem;color:var(--ink-soft);max-width:44ch;line-height:1.65;margin-bottom:32px}
.pills{display:flex;gap:12px;flex-wrap:wrap}
.pill{
  padding:11px 20px;border-radius:100px;font-size:.94rem;font-weight:600;
  background:#fff;border:1px solid var(--line);color:var(--ink-2);transition:.25s var(--ease);
}
.pill:hover{border-color:var(--rose);color:var(--rose-deep);transform:translateY(-2px)}
.feat__stage .device{--w:298px}
.feat__stage .chip{position:absolute;z-index:5}
.feat__stage .chip--a{top:12%;right:2%}
.feat__stage .chip--b{bottom:14%;left:0}
.feat__row.rev .chip--a{right:auto;left:2%}
.feat__row.rev .chip--b{left:auto;right:0}

/* ============================================================ MANIFESTO (dark full-bleed) */
.manifesto{
  background:radial-gradient(100% 120% at 50% 0%,#3a1228,var(--plum) 60%,#0e060b);
  color:#fff;padding:150px 0;text-align:center;position:relative;overflow:hidden;
}
.manifesto::before{content:"";position:absolute;inset:0;
  background:radial-gradient(50% 60% at 50% 50%,rgba(242,60,127,.18),transparent 70%)}
.manifesto .wrap{position:relative;z-index:2}
.manifesto .tag{
  display:inline-flex;align-items:center;gap:9px;margin-bottom:32px;padding:9px 18px;border-radius:100px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);font-size:.84rem;font-weight:600;color:#fbd9e4;
}
.manifesto .tag .dot{width:8px;height:8px;border-radius:50%;background:var(--rose-bright);box-shadow:0 0 10px var(--rose-bright)}
.manifesto h2{font-size:clamp(2.8rem,7vw,6rem);line-height:1.05}
.manifesto h2 em{color:var(--rose-bright);font-style:italic}
.manifesto p{margin:30px auto 0;max-width:48ch;color:rgba(255,255,255,.7);font-size:1.2rem}

/* ============================================================ PREMIUM */
.premium{padding:140px 0}
.premium__head{text-align:center;max-width:640px;margin:0 auto 64px}
.premium__head h2{font-size:clamp(2.6rem,5vw,4.6rem);margin:22px 0 20px}
.premium__head h2 em{color:var(--rose);font-style:italic}
.premium__head p{color:var(--ink-soft);font-size:1.16rem}
.plans{display:grid;grid-template-columns:1fr 1fr;gap:26px;max-width:900px;margin:0 auto}
.plan{position:relative;border-radius:28px;padding:44px 40px;background:#fff;border:1px solid var(--line);transition:.35s var(--ease)}
.plan:hover{transform:translateY(-6px);box-shadow:0 40px 70px -40px rgba(35,18,28,.35)}
.plan--best{background:linear-gradient(170deg,#2a0f20,var(--plum));color:#fff;border-color:transparent;box-shadow:0 50px 90px -45px rgba(200,30,94,.6)}
.plan--best .plan__name{color:#fbd9e4}
.plan--best .plan__list li{color:rgba(255,255,255,.9);border-color:rgba(255,255,255,.1)}
.plan__flag{position:absolute;top:-14px;left:50%;transform:translateX(-50%);white-space:nowrap;background:var(--rose);color:#fff;font-family:var(--font-body);font-size:.72rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;padding:8px 18px;border-radius:100px;box-shadow:0 12px 24px -8px rgba(242,60,127,.7)}
.plan__name{text-align:center;font-family:var(--font-body);font-size:.8rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;margin-bottom:20px}
.plan__price{text-align:center;font-family:var(--font-display);line-height:1}
.plan__price .cur{font-size:1.7rem;vertical-align:top;opacity:.6}
.plan__price .amt{font-size:4.8rem}
.plan__price .per{font-family:var(--font-body);font-size:1.25rem;font-weight:600;opacity:.55}
.plan__sub{text-align:center;font-weight:600;font-size:.96rem;margin:14px 0 30px;color:var(--rose)}
.plan--best .plan__sub{color:var(--rose-bright)}
.plan__list{list-style:none}
.plan__list li{display:flex;align-items:center;gap:14px;padding:15px 0;border-top:1px solid var(--line-2);font-size:1rem}
.plan__list li .ck{color:var(--rose);font-weight:800;flex:none}
.plan--best .plan__list li .ck{color:var(--rose-bright)}
.plan .btn{width:100%;justify-content:center;margin-top:30px}

/* ============================================================ CTA (rose full-bleed) */
.cta{padding:140px 0;text-align:center;background:linear-gradient(160deg,var(--rose) 0%,var(--rose-deep) 100%);color:#fff;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 80% at 80% 10%,rgba(255,255,255,.18),transparent 60%)}
.cta .wrap{position:relative;z-index:2;max-width:820px}
.cta h2{font-size:clamp(2.8rem,6vw,5.6rem);line-height:1.04;margin-bottom:24px}
.cta h2 em{font-style:italic}
.cta p{color:rgba(255,255,255,.9);font-size:1.22rem;margin-bottom:42px;max-width:42ch;margin-left:auto;margin-right:auto}
.cta__btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.store{display:inline-flex;align-items:center;gap:12px;padding:13px 24px;border-radius:16px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.28);transition:.3s var(--ease)}
.store:hover{background:rgba(255,255,255,.24);transform:translateY(-2px)}
.store svg{width:24px;height:24px;flex:none}
.store small{display:block;font-size:.66rem;opacity:.8;letter-spacing:.08em;text-transform:uppercase}
.store b{font-size:1.02rem;font-weight:700}

/* ============================================================ FOOTER */
.footer{background:var(--plum);color:rgba(255,255,255,.6);padding:80px 0 40px}
.footer__top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:54px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer__logo{height:34px;margin-bottom:20px}
.footer__about{max-width:32ch;font-size:.96rem;line-height:1.6}
.footer h4{font-family:var(--font-body);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:20px;font-weight:700}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:13px}
.footer ul a{color:rgba(255,255,255,.65);font-size:.96rem;transition:color .2s}
.footer ul a:hover{color:var(--rose-bright)}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;padding-top:28px;font-size:.9rem;flex-wrap:wrap;gap:14px}
.footer__bottom .credit{color:rgba(255,255,255,.85);font-weight:600}
.footer__bottom .credit b{font-family:var(--font-display);font-style:italic;color:var(--rose-bright);font-weight:400;letter-spacing:.04em;font-size:1.05rem}

/* ============================================================ REVEAL */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ----- cinematic motion (transform/opacity only — GPU-light) ----- */
.cine-stage{opacity:0;transform:translateY(96px) scale(.9);transition:opacity 1s var(--ease),transform 1.3s var(--ease);will-change:transform,opacity}
.cine-stage.in{opacity:1;transform:none}
.cine-head{opacity:0;transform:translateY(42px);clip-path:inset(0 0 102% 0);transition:opacity .85s var(--ease),transform 1.1s var(--ease),clip-path 1.15s var(--ease);will-change:transform,opacity,clip-path}
.cine-head.in{opacity:1;transform:none;clip-path:inset(0 0 -5% 0)}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
.clip{clip-path:inset(0 100% 0 0);transition:clip-path 1.1s var(--ease)}
.clip.in{clip-path:inset(0 0 0 0)}

/* ============================================================ RESPONSIVE */
@media(max-width:1080px){
  .hero__grid{grid-template-columns:1fr;gap:48px}
  .hero__stage{order:-1}
  .hero__stage .device{--w:286px}
  .feat__stage .device{--w:268px}
  .bignum{font-size:clamp(6rem,18vw,9rem)}
  .feat__row{grid-template-columns:1fr;gap:46px}
  .feat__row.rev .feat__stage{order:0}
  .stats__grid{grid-template-columns:1fr 1fr}
  .stat:nth-child(2){border-right:none}
  .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--line)}
  .plans{grid-template-columns:1fr;max-width:460px}
  .footer__top{grid-template-columns:1fr 1fr}
  .nav__links{display:none}
}
@media(max-width:640px){
  .wrap{padding:0 22px}
  .nav,.nav.scrolled{padding:14px 22px}
  .langs{order:3}
  .nav__right{gap:10px}
  .hero{padding-top:130px}
  .hero .chip--rating,.hero .chip--live,.hero .chip--count{position:static;margin:8px;display:inline-flex}
  .footer__top{grid-template-columns:1fr 1fr}
  .footer__bottom{flex-direction:column;align-items:flex-start}
}
@media(prefers-reduced-motion:reduce){
  .reveal,.cine-stage,.cine-head{opacity:1;transform:none;clip-path:none;transition:none}
  .clip{clip-path:none;transition:none}
  .float,.float-soft{animation:none}
  [data-par]{transform:none !important}
  html{scroll-behavior:auto}
}

/* ============================================================ POLISH PASS */
/* fine grain texture for a premium print feel */
.grain{
  position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.5;mix-blend-mode:multiply;
  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='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
}

/* device hover lift (shadow only — keeps tilt) */
.device{transition:box-shadow .5s var(--ease)}
.stage:hover .device{box-shadow:0 0 0 1px rgba(255,255,255,.06) inset,0 2px 3px rgba(255,255,255,.14) inset,0 64px 80px -30px rgba(35,8,22,.6),0 26px 40px -22px rgba(35,8,22,.45)}

/* gentle float for feature mockups */
.float-soft{animation:floatSoft 8s ease-in-out infinite}
@keyframes floatSoft{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.feat:nth-of-type(odd) .float-soft{animation-duration:9s}

/* (editorial numerals handled by .bignum) */

/* hero scroll cue */
.scrollcue{
  position:absolute;left:50%;bottom:30px;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:10px;
  font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;
}
.scrollcue .rail{width:1.5px;height:46px;background:linear-gradient(var(--rose),transparent);position:relative;overflow:hidden}
.scrollcue .rail::after{content:"";position:absolute;left:0;top:0;width:100%;height:40%;background:var(--rose);animation:cue 1.8s var(--ease) infinite}
@keyframes cue{0%{transform:translateY(-100%)}100%{transform:translateY(260%)}}
@media(max-width:1080px){.scrollcue{display:none}}

/* ===================== DOWNLOAD + QR ===================== */
.download{display:flex;gap:34px;justify-content:center;align-items:center;flex-wrap:wrap}
.cta__btns{flex-direction:column;align-items:stretch;gap:14px}
button.store{cursor:pointer;font:inherit;color:#fff;text-align:left}
.qr{display:inline-flex;flex-direction:column;align-items:center;gap:12px;background:#fff;padding:16px 16px 14px;border-radius:22px;box-shadow:0 22px 60px -18px rgba(25,10,20,.55);transition:.3s var(--ease)}
.qr:hover{transform:translateY(-4px);box-shadow:0 30px 70px -18px rgba(25,10,20,.6)}
.qr__frame{display:block;padding:10px;border-radius:14px;background:#fff;border:1px solid var(--line)}
.qr__frame img{display:block;width:138px;height:138px}
.qr__cap{font-size:.7rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--ink)}
@media(max-width:560px){.download{gap:24px}.cta__btns{width:100%;max-width:300px}}

/* ===================== MODAL ===================== */
.modal{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;padding:24px}
.modal.open{display:flex}
.modal__backdrop{position:absolute;inset:0;background:rgba(25,10,20,.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);animation:modalFade .3s var(--ease)}
.modal__card{position:relative;z-index:1;width:100%;max-width:430px;background:var(--paper);color:var(--ink);border:1px solid var(--line);border-radius:26px;padding:40px 34px 30px;text-align:center;box-shadow:0 40px 90px -20px rgba(25,10,20,.6);animation:modalPop .35s var(--ease)}
.modal__x{position:absolute;top:14px;right:18px;background:none;border:none;font-size:1.8rem;line-height:1;color:var(--ink-soft);cursor:pointer;transition:.2s}
.modal__x:hover{color:var(--ink)}
.modal__icon{width:64px;height:64px;margin:0 auto 18px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--blush);color:var(--rose-deep)}
.modal__icon svg{width:30px;height:30px}
.modal__title{font-family:var(--font-display);font-size:1.7rem;line-height:1.15;margin-bottom:12px}
.modal__body{color:var(--ink-soft);font-size:1.02rem;line-height:1.55;margin-bottom:26px}
.modal__play{width:100%;justify-content:center}
.modal__close{margin-top:10px;background:none;border:none;color:var(--ink-soft);font:inherit;font-weight:600;cursor:pointer;padding:8px;transition:.2s}
.modal__close:hover{color:var(--ink)}
@keyframes modalFade{from{opacity:0}to{opacity:1}}
@keyframes modalPop{from{opacity:0;transform:translateY(14px) scale(.96)}to{opacity:1;transform:none}}
