/* ============================================================
   PIX MARKETING STUDIO — premium minimal landing
   Palette: powder/blush pink · warm white · soft beige · graphite
   ============================================================ */
:root{
  --powder:#F8E8E8;
  --blush:#F0D4D4;
  --blush-deep:#E4B7B7;
  --rose:#C98A8A;
  --warm-white:#FBF6F2;
  --milk:#FFFDFB;
  --beige:#F2E8DC;
  --beige-deep:#EADDCD;
  --graphite:#1E1B1A;
  --ink:#2C2724;
  --grey:#8C847D;
  --grey-soft:#B7B0A9;
  --line:rgba(30,27,26,.10);
  --line-soft:rgba(30,27,26,.06);
  --glass:rgba(255,253,251,.55);
  --glass-strong:rgba(255,253,251,.78);
  --shadow-sm:0 2px 14px rgba(120,90,90,.06);
  --shadow:0 18px 50px -22px rgba(120,80,80,.28);
  --shadow-lg:0 40px 90px -38px rgba(120,70,70,.40);
  --r:22px;
  --r-lg:30px;
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"Manrope",-apple-system,sans-serif;
  color:var(--graphite);
  background:var(--warm-white);
  line-height:1.6;
  font-weight:400;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  position:relative;
}
/* soft grain overlay */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
/* ambient pink/beige blooms across the page */
.bg-bloom{position:fixed;border-radius:50%;filter:blur(90px);opacity:.55;z-index:-1;pointer-events:none}
.bloom-1{top:-160px;left:-120px;width:520px;height:520px;background:radial-gradient(circle,var(--powder),transparent 70%)}
.bloom-2{top:38%;right:-180px;width:560px;height:560px;background:radial-gradient(circle,var(--beige),transparent 70%);opacity:.5}
.bloom-3{bottom:-200px;left:20%;width:600px;height:600px;background:radial-gradient(circle,var(--blush),transparent 72%);opacity:.4}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--blush-deep);color:var(--graphite)}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
section{scroll-margin-top:88px}

h1,h2,h3{font-family:"Fraunces",Georgia,serif;font-weight:400;line-height:1.06;letter-spacing:-.01em;color:var(--graphite)}
.eyebrow{
  font-family:"Manrope";font-weight:600;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--rose);display:inline-flex;align-items:center;gap:.6em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--rose);opacity:.6}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:"Manrope";font-weight:600;font-size:.95rem;letter-spacing:.01em;
  padding:15px 30px;border-radius:100px;border:1px solid transparent;cursor:pointer;
  transition:transform .35s var(--ease),background .35s var(--ease),box-shadow .35s var(--ease),color .3s;
  white-space:nowrap;
}
.btn-primary{background:var(--graphite);color:var(--milk);box-shadow:var(--shadow-sm)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 22px 40px -18px rgba(30,27,26,.55)}
.btn-ghost{background:transparent;color:var(--graphite);border-color:var(--line)}
.btn-ghost:hover{background:var(--milk);border-color:var(--graphite);transform:translateY(-3px)}
.btn-rose{background:var(--blush);color:var(--graphite)}
.btn-rose:hover{background:var(--blush-deep);transform:translateY(-2px)}
.btn-arrow svg{transition:transform .35s var(--ease)}
.btn:hover .btn-arrow svg{transform:translateX(4px)}
.btn-block{width:100%}

/* ---------- nav ---------- */
header.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;transition:all .4s var(--ease);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:18px 28px;max-width:1320px;margin:0 auto;transition:padding .4s var(--ease);
}
.nav.scrolled .nav-inner{padding:11px 28px}
.nav.scrolled{
  background:var(--glass-strong);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line-soft);
}
.brand{display:flex;align-items:baseline;gap:.4em;font-family:"Manrope";font-weight:700;letter-spacing:.18em;font-size:1.18rem}
.brand small{font-weight:500;font-size:.62rem;letter-spacing:.34em;color:var(--grey);transform:translateY(-1px)}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none}
.nav-links a{font-size:.9rem;font-weight:500;color:var(--ink);position:relative;padding:4px 0;opacity:.85;transition:opacity .25s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;background:var(--graphite);transition:width .35s var(--ease)}
.nav-links a:hover{opacity:1}
.nav-links a:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:16px}

.lang{display:inline-flex;align-items:center;background:var(--milk);border:1px solid var(--line);border-radius:100px;padding:3px;gap:2px}
.lang button{
  font-family:"Manrope";font-weight:600;font-size:.72rem;letter-spacing:.05em;
  border:none;background:transparent;color:var(--grey);padding:5px 11px;border-radius:100px;cursor:pointer;transition:all .25s
}
.lang button.active{background:var(--graphite);color:var(--milk)}

.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--graphite);border-radius:2px;transition:.3s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile menu */
.mobile-menu{
  position:fixed;inset:0;z-index:999;background:var(--warm-white);
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:26px;
  opacity:0;visibility:hidden;transition:opacity .4s var(--ease);padding:40px;
}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu a{font-family:"Fraunces";font-size:2rem;color:var(--graphite)}
.mobile-menu .lang{margin-top:10px}

/* ---------- hero ---------- */
.hero{position:relative;padding:170px 0 110px;text-align:center;overflow:hidden}
.hero-orb{
  position:absolute;top:8%;left:50%;transform:translateX(-50%);width:680px;height:680px;max-width:120vw;
  background:conic-gradient(from 120deg,var(--powder),var(--beige),var(--blush),var(--powder));
  border-radius:50%;filter:blur(70px);opacity:.55;z-index:0;animation:spin 34s linear infinite;
}
@keyframes spin{to{transform:translateX(-50%) rotate(360deg)}}
.hero-grid-dots{
  position:absolute;inset:0;z-index:0;opacity:.5;
  background-image:radial-gradient(var(--line) 1px,transparent 1px);background-size:30px 30px;
  -webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,#000,transparent 75%);
          mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,#000,transparent 75%);
}
.hero .wrap{position:relative;z-index:2}
.hero-badge{
  display:inline-flex;align-items:center;gap:.6em;background:var(--glass);backdrop-filter:blur(8px);
  border:1px solid var(--line-soft);border-radius:100px;padding:8px 18px;font-size:.78rem;font-weight:600;
  letter-spacing:.04em;color:var(--ink);margin-bottom:30px;box-shadow:var(--shadow-sm)
}
.hero-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--rose);box-shadow:0 0 0 4px rgba(201,138,138,.22)}
.hero h1{font-size:clamp(2.7rem,6.4vw,5.4rem);max-width:15ch;margin:0 auto 26px;font-weight:380}
.hero h1 em{font-style:italic;color:var(--rose)}
.hero p.sub{font-size:clamp(1.05rem,1.7vw,1.3rem);color:var(--ink);max-width:46ch;margin:0 auto 40px;font-weight:400}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero-marquee{margin-top:64px;font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;color:var(--grey-soft);font-weight:600}

/* ---------- generic section heading ---------- */
.sec-head{max-width:640px;margin-bottom:54px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:clamp(2rem,4vw,3.2rem);margin-top:16px;font-weight:380}
.sec-head p{color:var(--ink);font-size:1.06rem;margin-top:16px}
.section{padding:clamp(70px,9vw,120px) 0}

/* ---------- about ---------- */
.about{position:relative}
.about-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.about h2{font-size:clamp(2rem,4.2vw,3.4rem);font-weight:380;line-height:1.08}
.about-panel{
  background:var(--glass);backdrop-filter:blur(14px);border:1px solid var(--line-soft);border-radius:var(--r-lg);
  padding:42px;box-shadow:var(--shadow);position:relative;overflow:hidden
}
.about-panel::before{content:"";position:absolute;top:-60px;right:-60px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,var(--blush),transparent 70%);opacity:.6}
.about-panel p{font-size:1.08rem;color:var(--ink);position:relative;z-index:1}
.about-stats{display:flex;gap:34px;margin-top:30px;position:relative;z-index:1;flex-wrap:wrap}
.about-stats .stat span{display:block;font-family:"Fraunces";font-size:2.1rem;color:var(--graphite)}
.about-stats .stat small{font-size:.78rem;letter-spacing:.08em;color:var(--grey);text-transform:uppercase;font-weight:600}

/* ---------- services ---------- */
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.svc-card{
  background:var(--glass);backdrop-filter:blur(12px);border:1px solid var(--line-soft);border-radius:var(--r);
  padding:30px 26px;transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .45s;
  position:relative;overflow:hidden;min-height:230px;display:flex;flex-direction:column
}
.svc-card:hover{transform:translateY(-7px);box-shadow:var(--shadow);border-color:var(--blush-deep)}
.svc-icon{width:46px;height:46px;border-radius:14px;background:var(--powder);display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:var(--graphite)}
.svc-icon svg{width:22px;height:22px}
.svc-card h3{font-size:1.22rem;margin-bottom:10px;font-weight:440}
.svc-card p{font-size:.94rem;color:var(--ink);flex:1}
.svc-num{position:absolute;top:22px;right:24px;font-family:"Fraunces";font-size:.95rem;color:var(--grey-soft)}

/* ---------- packages ---------- */
.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch}
.pkg{
  background:var(--milk);border:1px solid var(--line-soft);border-radius:var(--r-lg);padding:38px 32px;
  display:flex;flex-direction:column;position:relative;transition:transform .45s var(--ease),box-shadow .45s var(--ease);
  box-shadow:var(--shadow-sm)
}
.pkg:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.pkg-name{font-family:"Manrope";font-weight:700;letter-spacing:.16em;font-size:.84rem;text-transform:uppercase;color:var(--rose)}
.pkg-price{font-family:"Fraunces";font-size:3rem;font-weight:400;margin:14px 0 4px;line-height:1}
.pkg-price span{font-size:1rem;color:var(--grey);font-family:"Manrope";font-weight:500;letter-spacing:.02em}
.pkg-desc{font-size:.92rem;color:var(--ink);min-height:62px;margin-bottom:22px}
.pkg-feat{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:28px;flex:1}
.pkg-feat li{display:flex;gap:11px;font-size:.92rem;color:var(--ink);align-items:flex-start}
.pkg-feat li svg{flex:0 0 17px;margin-top:4px;color:var(--rose)}
.pkg.featured{background:var(--graphite);color:var(--milk);transform:scale(1.03)}
.pkg.featured:hover{transform:scale(1.03) translateY(-6px)}
.pkg.featured .pkg-name{color:var(--blush-deep)}
.pkg.featured .pkg-desc,.pkg.featured .pkg-feat li{color:#E7E1DC}
.pkg.featured .pkg-price span{color:var(--grey-soft)}
.pkg.featured .pkg-feat li svg{color:var(--blush-deep)}
.pkg.featured .btn-primary{background:var(--milk);color:var(--graphite)}
.pkg.featured .btn-primary:hover{background:var(--blush)}
.pkg-tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--blush);color:var(--graphite);font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:6px 16px;border-radius:100px;white-space:nowrap}

/* ---------- why (bento) ---------- */
.bento{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:minmax(150px,auto);gap:16px}
.bento .cell{
  background:var(--glass);backdrop-filter:blur(12px);border:1px solid var(--line-soft);border-radius:var(--r);
  padding:28px;display:flex;flex-direction:column;justify-content:flex-end;position:relative;overflow:hidden;
  transition:transform .45s var(--ease),box-shadow .45s var(--ease)
}
.bento .cell:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.bento .cell h3{font-size:1.3rem;font-weight:440;margin-bottom:8px}
.bento .cell p{font-size:.9rem;color:var(--ink)}
.bento .cell .idx{font-family:"Fraunces";font-size:.9rem;color:var(--grey-soft);margin-bottom:auto}
.cell-feature{grid-column:span 2;grid-row:span 2;background:linear-gradient(150deg,var(--powder),var(--milk) 60%,var(--beige));border:1px solid var(--line-soft)}
.cell-feature h3{font-family:"Fraunces";font-size:clamp(1.7rem,3vw,2.6rem);font-weight:380;line-height:1.1}
.cell-orb{position:absolute;top:-40px;right:-30px;width:160px;height:160px;border-radius:50%;background:conic-gradient(from 90deg,var(--blush),var(--beige),var(--powder));filter:blur(26px);opacity:.7}

/* ---------- process ---------- */
.process-track{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative}
.process-track::before{content:"";position:absolute;top:24px;left:7%;right:7%;height:1px;background:var(--line);z-index:0}
.step{position:relative;z-index:1;text-align:left}
.step .node{
  width:50px;height:50px;border-radius:50%;background:var(--milk);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;font-family:"Fraunces";font-size:1.2rem;margin-bottom:22px;
  box-shadow:var(--shadow-sm);color:var(--graphite)
}
.step h3{font-size:1.2rem;font-weight:440;margin-bottom:8px}
.step p{font-size:.92rem;color:var(--ink)}

/* ---------- contact ---------- */
.contact{position:relative}
.contact-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:56px;align-items:start}
.contact h2{font-size:clamp(2rem,4vw,3.2rem);font-weight:380;margin-bottom:18px}
.contact-lead{color:var(--ink);font-size:1.08rem;margin-bottom:30px}
.contact-info{display:flex;flex-direction:column;gap:18px;margin-top:6px}
.contact-info a,.contact-info span{display:flex;align-items:center;gap:12px;font-size:.98rem;color:var(--ink)}
.contact-info svg{width:18px;height:18px;color:var(--rose)}
.form-card{
  background:var(--glass-strong);backdrop-filter:blur(16px);border:1px solid var(--line-soft);border-radius:var(--r-lg);
  padding:38px;box-shadow:var(--shadow)
}
.pkg-chip{display:none;align-items:center;gap:10px;background:var(--powder);border-radius:100px;padding:8px 16px;font-size:.82rem;font-weight:600;margin-bottom:22px;color:var(--graphite)}
.pkg-chip.show{display:inline-flex}
.pkg-chip button{background:none;border:none;cursor:pointer;color:var(--rose);font-size:1.1rem;line-height:1}
.field{margin-bottom:18px}
.field label{display:block;font-size:.8rem;font-weight:600;letter-spacing:.04em;color:var(--ink);margin-bottom:7px}
.field input,.field textarea{
  width:100%;font-family:"Manrope";font-size:.96rem;color:var(--graphite);background:var(--milk);
  border:1px solid var(--line);border-radius:14px;padding:13px 16px;transition:border-color .25s,box-shadow .25s;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--rose);box-shadow:0 0 0 4px rgba(201,138,138,.14)}
.field textarea{resize:vertical;min-height:110px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.consent{display:flex;gap:12px;align-items:flex-start;margin:6px 0 22px;font-size:.84rem;color:var(--ink)}
.consent input{margin-top:3px;width:17px;height:17px;accent-color:var(--rose);flex:0 0 17px}
.consent a{color:var(--rose);text-decoration:underline}
.hp{position:absolute;left:-9999px;opacity:0;height:0;width:0}
.form-success{display:none;text-align:center;padding:30px 10px}
.form-success.show{display:block;animation:pop .5s var(--ease)}
@keyframes pop{from{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}
.form-success .check{width:62px;height:62px;border-radius:50%;background:var(--powder);display:flex;align-items:center;justify-content:center;margin:0 auto 18px;color:var(--rose)}
.form-success h3{font-size:1.5rem;font-weight:420;margin-bottom:8px}
.form-success p{color:var(--ink)}

/* ---------- footer ---------- */
footer{background:var(--graphite);color:#E7E1DC;padding:70px 0 34px;margin-top:40px;position:relative;overflow:hidden}
footer .bloom-f{position:absolute;top:-120px;right:-80px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(201,138,138,.4),transparent 70%);filter:blur(40px)}
.foot-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;position:relative;z-index:1;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:40px;margin-bottom:30px}
.foot-brand .brand{color:var(--milk)}
.foot-brand .brand small{color:var(--grey-soft)}
.foot-brand p{color:var(--grey-soft);max-width:34ch;margin-top:16px;font-size:.95rem}
.foot-cols{display:flex;gap:60px;flex-wrap:wrap}
.foot-cols h4{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--grey-soft);margin-bottom:16px;font-weight:600;font-family:"Manrope"}
.foot-cols ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot-cols a,.foot-cols button{color:#D9D2CC;font-size:.92rem;background:none;border:none;cursor:pointer;font-family:"Manrope";padding:0;text-align:left;transition:color .25s}
.foot-cols a:hover,.foot-cols button:hover{color:var(--milk)}
.foot-bottom{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;position:relative;z-index:1;color:var(--grey-soft);font-size:.84rem}

/* ---------- cookie banner ---------- */
.cookie{
  position:fixed;left:24px;right:24px;bottom:24px;max-width:560px;margin:0 auto;z-index:2000;
  background:var(--glass-strong);backdrop-filter:blur(20px);border:1px solid var(--line-soft);border-radius:var(--r);
  padding:22px 24px;box-shadow:var(--shadow-lg);transform:translateY(180%);transition:transform .55s var(--ease);
}
.cookie.show{transform:translateY(0)}
.cookie p{font-size:.86rem;color:var(--ink);margin-bottom:16px}
.cookie-btns{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.cookie-btns .btn{padding:11px 24px;font-size:.88rem}
.cookie-btns a{font-size:.86rem;color:var(--rose);text-decoration:underline;font-weight:600}

/* ---------- privacy modal ---------- */
.modal{position:fixed;inset:0;z-index:3000;display:none;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto}
.modal.show{display:flex}
.modal-overlay{position:fixed;inset:0;background:rgba(30,27,26,.5);backdrop-filter:blur(4px)}
.modal-card{
  position:relative;background:var(--warm-white);border-radius:var(--r-lg);max-width:760px;width:100%;
  padding:48px;box-shadow:var(--shadow-lg);margin:auto;z-index:1
}
.modal-card h2{font-size:2rem;font-weight:400;margin-bottom:8px}
.modal-card .upd{color:var(--grey);font-size:.84rem;margin-bottom:28px}
.modal-card h3{font-family:"Manrope";font-weight:700;font-size:1rem;margin:24px 0 8px;color:var(--graphite)}
.modal-card p,.modal-card li{font-size:.94rem;color:var(--ink);margin-bottom:10px}
.modal-card ul{padding-left:20px}
.modal-card .note{background:var(--powder);border-radius:14px;padding:14px 18px;font-size:.86rem;color:var(--ink);margin-top:8px}
.modal-close{position:absolute;top:20px;right:20px;width:40px;height:40px;border-radius:50%;border:1px solid var(--line);background:var(--milk);cursor:pointer;font-size:1.3rem;line-height:1;color:var(--graphite);transition:.25s}
.modal-close:hover{background:var(--graphite);color:var(--milk)}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in-view{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.hero-orb{animation:none}}

/* ---------- responsive ---------- */
@media (max-width:980px){
  .nav-links{display:none}
  .burger{display:flex}
  .nav .lang{display:none}
  .about-grid{grid-template-columns:1fr;gap:36px}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .pkg-grid{grid-template-columns:1fr;max-width:460px;margin:0 auto}
  .pkg.featured{transform:none}.pkg.featured:hover{transform:translateY(-6px)}
  .bento{grid-template-columns:repeat(2,1fr)}
  .cell-feature{grid-column:span 2;grid-row:span 1}
  .process-track{grid-template-columns:repeat(2,1fr);gap:34px}
  .process-track::before{display:none}
  .contact-grid{grid-template-columns:1fr;gap:36px}
}
@media (max-width:560px){
  .wrap{padding:0 20px}
  .hero{padding:140px 0 80px}
  .services-grid,.bento{grid-template-columns:1fr}
  .cell-feature{grid-column:span 1}
  .field-row{grid-template-columns:1fr}
  .modal-card{padding:32px 24px}
  .form-card{padding:28px 22px}
  .hero-cta .btn{flex:1}
}
/* ============================================================
   Standalone legal page (privacy.html)
   ============================================================ */
.legal{padding:150px 0 90px;position:relative}
.legal .wrap{max-width:820px}
.legal .back{display:inline-flex;align-items:center;gap:.5em;font-size:.9rem;font-weight:600;color:var(--rose);margin-bottom:26px}
.legal .back svg{width:16px;height:16px}
.legal h1{font-size:clamp(2.2rem,5vw,3.4rem);font-weight:380;margin-bottom:8px}
.legal .upd{color:var(--grey);font-size:.86rem;margin-bottom:34px}
.legal-card{background:var(--glass);backdrop-filter:blur(14px);border:1px solid var(--line-soft);border-radius:var(--r-lg);padding:clamp(28px,5vw,52px);box-shadow:var(--shadow)}
.legal-card h3{font-family:"Manrope";font-weight:700;font-size:1.05rem;margin:26px 0 8px;color:var(--graphite)}
.legal-card h3:first-child{margin-top:0}
.legal-card p,.legal-card li{font-size:.96rem;color:var(--ink);margin-bottom:10px}
.legal-card ul{padding-left:20px}
.legal-card .note{background:var(--powder);border-radius:14px;padding:14px 18px;font-size:.86rem;color:var(--ink);margin-top:8px;display:block}
