/* ==========================================================================
   Vitanela — Wellness brand
   Palette: Silver · Grey · Blue · Pearl
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600&family=Manrope:wght@300;400;500;600;700&display=swap');

:root{
  --pearl:#f6f8fb;
  --pearl-2:#eef2f7;
  --silver:#c9d2dc;
  --silver-soft:#dde3ea;
  --grey:#5d6b7a;
  --grey-deep:#37424f;
  --ink:#222b34;
  --blue:#3f6fa3;
  --blue-deep:#274b73;
  --blue-soft:#7ea4cc;
  --mist:#9fb2c4;
  --white:#ffffff;

  --shadow-sm:0 2px 10px rgba(39,75,115,.06);
  --shadow-md:0 12px 40px rgba(39,75,115,.10);
  --shadow-lg:0 26px 70px rgba(39,75,115,.16);

  --radius:18px;
  --radius-sm:12px;
  --maxw:1180px;

  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Manrope',system-ui,sans-serif;

  --ease:cubic-bezier(.22,.61,.36,1);
}

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

.wrap{width:90%;max-width:var(--maxw);margin-inline:auto}
.section{padding:clamp(3.5rem,8vw,7rem) 0}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.12;color:var(--grey-deep);letter-spacing:.2px}
h1{font-size:clamp(2.6rem,6vw,4.6rem)}
h2{font-size:clamp(2rem,4.4vw,3.2rem)}
h3{font-size:clamp(1.3rem,2.4vw,1.7rem)}
.eyebrow{
  font-family:var(--sans);font-weight:600;text-transform:uppercase;
  letter-spacing:.28em;font-size:.72rem;color:var(--blue);
  display:inline-block;margin-bottom:1rem;
}
.lead{font-size:clamp(1.05rem,1.6vw,1.22rem);color:var(--grey);max-width:60ch}
p{color:var(--grey)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--sans);font-weight:600;font-size:.95rem;
  padding:.95rem 2rem;border-radius:999px;cursor:pointer;border:none;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .35s var(--ease);
}
.btn-primary{
  background:linear-gradient(135deg,var(--blue),var(--blue-deep));
  color:var(--white);box-shadow:var(--shadow-sm);
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.btn-ghost{
  background:rgba(255,255,255,.6);color:var(--blue-deep);
  border:1px solid var(--silver);backdrop-filter:blur(6px);
}
.btn-ghost:hover{background:var(--white);transform:translateY(-3px)}
.btn .arr{transition:transform .35s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(246,248,251,.78);
  backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid rgba(201,210,220,.5);
  transition:box-shadow .3s var(--ease);
}
.site-header.scrolled{box-shadow:var(--shadow-sm)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--serif);font-size:1.55rem;color:var(--blue-deep);font-weight:600;letter-spacing:.5px}
.brand .dot{
  width:13px;height:13px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,#fff,var(--blue-soft) 55%,var(--blue) 100%);
  box-shadow:0 0 0 4px rgba(126,164,204,.25);
}
.nav-links{display:flex;align-items:center;gap:1.9rem;list-style:none}
.nav-links a{
  font-size:.94rem;font-weight:500;color:var(--grey-deep);position:relative;padding:.3rem 0;
  transition:color .3s var(--ease);
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;
  background:var(--blue);transition:width .3s var(--ease);
}
.nav-links a:hover,.nav-links a.active{color:var(--blue-deep)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{margin-left:.4rem}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--grey-deep);border-radius:2px;transition:.3s var(--ease)}
.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)}

/* ---------- Hero ---------- */
.hero{position:relative;padding:clamp(3rem,7vw,6rem) 0 clamp(4rem,8vw,7rem);overflow:hidden}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-2;
  background:
    radial-gradient(60% 60% at 78% 18%,rgba(126,164,204,.30),transparent 60%),
    radial-gradient(50% 50% at 12% 86%,rgba(201,210,220,.45),transparent 60%),
    linear-gradient(180deg,var(--pearl),var(--pearl-2));
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.hero-copy{max-width:33rem}
.hero h1{margin:.4rem 0 1.3rem}
.hero h1 em{font-style:italic;color:var(--blue)}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-top:2rem}
.hero-figure{position:relative}
.hero-figure img{
  border-radius:calc(var(--radius) + 8px);box-shadow:var(--shadow-lg);
  aspect-ratio:4/5;object-fit:cover;width:100%;
}
.hero-figure .float{
  position:absolute;left:-22px;bottom:30px;
  background:rgba(255,255,255,.85);backdrop-filter:blur(10px);
  border:1px solid var(--silver-soft);border-radius:var(--radius);
  padding:1rem 1.3rem;box-shadow:var(--shadow-md);max-width:230px;
}
.hero-figure .float strong{font-family:var(--serif);font-size:1.5rem;color:var(--blue-deep);display:block}
.hero-figure .float span{font-size:.82rem;color:var(--grey)}

/* ---------- Trust strip ---------- */
.strip{border-top:1px solid var(--silver-soft);border-bottom:1px solid var(--silver-soft);background:var(--white)}
.strip-inner{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1.5rem;padding:1.6rem 0}
.strip-item{display:flex;align-items:center;gap:.7rem;font-size:.92rem;color:var(--grey-deep);font-weight:500}
.strip-item svg{flex:none;color:var(--blue)}

/* ---------- Section heading ---------- */
.head{max-width:62ch;margin-bottom:clamp(2rem,4vw,3.2rem)}
.head.center{margin-inline:auto;text-align:center}

/* ---------- Cards / features ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.card{
  background:var(--white);border:1px solid var(--silver-soft);border-radius:var(--radius);
  padding:2rem 1.8rem;box-shadow:var(--shadow-sm);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease);
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:var(--blue-soft)}
.card .ic{
  width:50px;height:50px;border-radius:14px;display:grid;place-items:center;margin-bottom:1.2rem;
  background:linear-gradient(135deg,var(--pearl-2),var(--silver-soft));color:var(--blue-deep);
}
.card h3{margin-bottom:.6rem;font-size:1.35rem}
.card p{font-size:.96rem}

/* ---------- Split sections ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.split.rev .split-media{order:2}
.split-media img{border-radius:var(--radius);box-shadow:var(--shadow-md);aspect-ratio:5/4;object-fit:cover;width:100%}
.split-copy h2{margin-bottom:1.1rem}
.tick{list-style:none;margin-top:1.6rem;display:grid;gap:.85rem}
.tick li{display:flex;gap:.75rem;align-items:flex-start;color:var(--grey-deep);font-size:.98rem}
.tick li::before{
  content:"";flex:none;width:22px;height:22px;border-radius:50%;margin-top:2px;
  background:radial-gradient(circle at 35% 30%,#fff,var(--blue-soft) 60%,var(--blue));
}

/* ---------- Product card ---------- */
.product-band{background:linear-gradient(180deg,var(--pearl),var(--pearl-2))}
.product-card{
  display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center;
  background:var(--white);border:1px solid var(--silver-soft);border-radius:calc(var(--radius) + 6px);
  padding:clamp(1.6rem,4vw,3rem);box-shadow:var(--shadow-md);position:relative;overflow:hidden;
}
.product-card::before{
  content:"";position:absolute;right:-80px;top:-80px;width:260px;height:260px;border-radius:50%;
  background:radial-gradient(circle,rgba(126,164,204,.22),transparent 70%);
}
.product-visual{
  position:relative;display:grid;place-items:center;
  background:radial-gradient(circle at 50% 40%,var(--pearl-2),var(--silver-soft));
  border-radius:var(--radius);padding:2rem;aspect-ratio:1/1;
}
.product-visual img{filter:drop-shadow(0 24px 40px rgba(39,75,115,.22));max-height:300px;width:auto}
.product-info h2{margin-bottom:.4rem}
.product-info .tagline{color:var(--blue);font-weight:600;font-size:.85rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:1rem}
.product-info p{margin-bottom:1.2rem}
.pill-row{display:flex;flex-wrap:wrap;gap:.6rem;margin:1.2rem 0 1.6rem}
.pill{font-size:.82rem;font-weight:600;color:var(--blue-deep);background:var(--pearl-2);border:1px solid var(--silver-soft);padding:.4rem .9rem;border-radius:999px}
.note{font-size:.82rem;color:var(--mist);margin-top:1rem}

/* ---------- CTA band ---------- */
.cta-band{
  background:linear-gradient(135deg,var(--blue-deep),var(--grey-deep));
  color:var(--white);border-radius:calc(var(--radius) + 10px);
  padding:clamp(2.5rem,6vw,4.5rem);text-align:center;position:relative;overflow:hidden;
}
.cta-band::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(50% 80% at 80% 0%,rgba(159,178,196,.3),transparent 60%);
}
.cta-band h2{color:#fff;position:relative}
.cta-band p{color:rgba(255,255,255,.82);max-width:54ch;margin:1rem auto 2rem;position:relative}
.cta-band .btn-ghost{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.4);position:relative}
.cta-band .btn-ghost:hover{background:rgba(255,255,255,.25)}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{padding:clamp(3rem,6vw,5rem) 0 clamp(2rem,4vw,3rem);background:
  radial-gradient(50% 60% at 85% 10%,rgba(126,164,204,.22),transparent 60%),
  linear-gradient(180deg,var(--pearl),var(--pearl-2));}
.page-hero .eyebrow{margin-bottom:.8rem}
.page-hero p{max-width:60ch;margin-top:1rem}

/* ---------- Legal / prose ---------- */
.prose{max-width:78ch}
.prose h2{font-size:1.7rem;margin:2.4rem 0 .9rem}
.prose h3{font-size:1.25rem;margin:1.8rem 0 .6rem;color:var(--grey-deep)}
.prose p,.prose li{color:var(--grey);font-size:1rem;margin-bottom:.9rem}
.prose ul{padding-left:1.3rem;margin-bottom:1rem}
.prose li{margin-bottom:.4rem}
.prose a{color:var(--blue);text-decoration:underline;text-underline-offset:3px}
.callout{
  background:var(--white);border-left:4px solid var(--blue);border-radius:var(--radius-sm);
  padding:1.3rem 1.5rem;box-shadow:var(--shadow-sm);margin:1.6rem 0;
}
.callout p{margin:0;color:var(--grey-deep);font-size:.96rem}
.toc{background:var(--white);border:1px solid var(--silver-soft);border-radius:var(--radius);padding:1.4rem 1.6rem;box-shadow:var(--shadow-sm);margin-bottom:2.5rem}
.toc strong{display:block;font-family:var(--serif);font-size:1.2rem;color:var(--grey-deep);margin-bottom:.6rem}
.toc ul{list-style:none;display:grid;gap:.4rem}
.toc a{color:var(--blue);font-size:.94rem}
.toc a:hover{text-decoration:underline}
.updated{font-size:.85rem;color:var(--mist);margin-bottom:1.5rem}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.info-list{list-style:none;display:grid;gap:1.4rem;margin-top:1.5rem}
.info-list li{display:flex;gap:1rem;align-items:flex-start}
.info-list .ic{
  width:46px;height:46px;flex:none;border-radius:13px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--pearl-2),var(--silver-soft));color:var(--blue-deep);
}
.info-list .lbl{font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;color:var(--mist);font-weight:600}
.info-list a,.info-list span{color:var(--grey-deep);font-weight:500;display:block}
.map-embed{margin-top:2rem;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--silver-soft)}
.map-embed iframe{display:block;width:100%;height:260px;border:0;filter:grayscale(.2) contrast(.95)}

/* ---------- Form ---------- */
.form-card{background:var(--white);border:1px solid var(--silver-soft);border-radius:var(--radius);padding:clamp(1.6rem,4vw,2.6rem);box-shadow:var(--shadow-md)}
.field{margin-bottom:1.3rem}
.field label{display:block;font-size:.88rem;font-weight:600;color:var(--grey-deep);margin-bottom:.45rem}
.field input,.field textarea,.field select{
  width:100%;font-family:var(--sans);font-size:.97rem;color:var(--ink);
  background:var(--pearl);border:1px solid var(--silver);border-radius:var(--radius-sm);
  padding:.85rem 1rem;transition:border-color .3s var(--ease),box-shadow .3s var(--ease),background .3s var(--ease);
}
.field textarea{resize:vertical;min-height:130px}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--blue);background:var(--white);box-shadow:0 0 0 4px rgba(126,164,204,.2);
}
.field input.invalid,.field textarea.invalid{border-color:#c0556b;box-shadow:0 0 0 4px rgba(192,85,107,.15)}
.err{display:none;color:#c0556b;font-size:.82rem;margin-top:.4rem}
.err.show{display:block}
.check{display:flex;gap:.7rem;align-items:flex-start;font-size:.88rem;color:var(--grey)}
.check input{width:auto;margin-top:.25rem}
.check a{color:var(--blue);text-decoration:underline}
.form-status{margin-top:1rem;font-size:.92rem;font-weight:600;color:var(--blue-deep);display:none}
.form-status.show{display:block}

/* ---------- Success ---------- */
.success-wrap{min-height:62vh;display:grid;place-items:center;text-align:center;
  background:radial-gradient(60% 60% at 50% 0%,rgba(126,164,204,.18),transparent 60%);}
.success-card{max-width:560px;background:var(--white);border:1px solid var(--silver-soft);
  border-radius:calc(var(--radius)+6px);padding:clamp(2rem,6vw,3.5rem);box-shadow:var(--shadow-lg)}
.success-card .badge{
  width:84px;height:84px;border-radius:50%;margin:0 auto 1.6rem;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--blue-soft),var(--blue));color:#fff;box-shadow:var(--shadow-md);
  animation:pop .6s var(--ease) both;
}
.success-card h1{font-size:clamp(2rem,5vw,2.8rem);margin-bottom:.8rem}
.success-card p{margin-bottom:1.6rem}
@keyframes pop{0%{transform:scale(.4);opacity:0}60%{transform:scale(1.08)}100%{transform:scale(1);opacity:1}}

/* ---------- FAQ ---------- */
.faq{max-width:760px;margin-inline:auto}
.acc{background:var(--white);border:1px solid var(--silver-soft);border-radius:var(--radius-sm);margin-bottom:.9rem;overflow:hidden;transition:box-shadow .3s var(--ease)}
.acc:hover{box-shadow:var(--shadow-sm)}
.acc-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:1.2rem 1.4rem;
  font-family:var(--sans);font-weight:600;font-size:1rem;color:var(--grey-deep);
  display:flex;justify-content:space-between;align-items:center;gap:1rem}
.acc-q .sign{flex:none;width:24px;height:24px;position:relative;transition:transform .3s var(--ease)}
.acc-q .sign::before,.acc-q .sign::after{content:"";position:absolute;background:var(--blue);border-radius:2px}
.acc-q .sign::before{top:11px;left:4px;width:16px;height:2px}
.acc-q .sign::after{top:4px;left:11px;width:2px;height:16px;transition:opacity .3s var(--ease)}
.acc.open .sign::after{opacity:0}
.acc-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.acc-a p{padding:0 1.4rem 1.3rem;font-size:.95rem;margin:0}

/* ---------- Footer ---------- */
.site-footer{background:var(--grey-deep);color:rgba(255,255,255,.78);padding:clamp(3rem,6vw,4.5rem) 0 2rem;margin-top:auto}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2.2rem}
.footer-brand .brand{color:#fff;margin-bottom:1rem}
.footer-brand p{color:rgba(255,255,255,.6);font-size:.92rem;max-width:32ch}
.footer-col h4{font-family:var(--sans);font-size:.82rem;text-transform:uppercase;letter-spacing:.16em;color:rgba(255,255,255,.55);margin-bottom:1.1rem;font-weight:700}
.footer-col ul{list-style:none;display:grid;gap:.6rem}
.footer-col a,.footer-col span{color:rgba(255,255,255,.78);font-size:.92rem;transition:color .3s var(--ease)}
.footer-col a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:2.6rem;padding-top:1.6rem;
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;font-size:.84rem;color:rgba(255,255,255,.5)}
.footer-bottom a{color:rgba(255,255,255,.6)}
.footer-bottom a:hover{color:#fff}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}
.reveal.d2{transition-delay:.2s}
.reveal.d3{transition-delay:.3s}

/* ---------- Cookie banner ---------- */
.cookie{
  position:fixed;left:50%;bottom:20px;transform:translateX(-50%) translateY(140%);
  width:min(680px,92%);background:var(--white);border:1px solid var(--silver-soft);
  border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:1.3rem 1.5rem;z-index:90;
  display:flex;flex-wrap:wrap;align-items:center;gap:1rem;justify-content:space-between;
  transition:transform .5s var(--ease);
}
.cookie.show{transform:translateX(-50%) translateY(0)}
.cookie p{font-size:.9rem;color:var(--grey-deep);flex:1 1 320px;margin:0}
.cookie p a{color:var(--blue);text-decoration:underline}
.cookie-actions{display:flex;gap:.7rem;flex-wrap:wrap}
.cookie .btn{padding:.65rem 1.3rem;font-size:.85rem}

/* ---------- Skip link ---------- */
.skip{position:absolute;left:-999px;top:0;background:var(--blue-deep);color:#fff;padding:.7rem 1.2rem;border-radius:0 0 8px 0;z-index:100}
.skip:focus{left:0}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:2.5rem}
  .hero-figure{max-width:440px;margin-inline:auto}
  .grid-3{grid-template-columns:1fr 1fr}
  .split,.product-card,.contact-grid{grid-template-columns:1fr;gap:2rem}
  .split.rev .split-media{order:0}
  .product-visual{max-width:380px;margin-inline:auto}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .nav-links{
    position:fixed;inset:74px 0 auto 0;background:var(--pearl);
    flex-direction:column;align-items:flex-start;gap:0;padding:1rem 6%;
    border-bottom:1px solid var(--silver-soft);box-shadow:var(--shadow-md);
    transform:translateY(-120%);transition:transform .4s var(--ease);
  }
  .nav-links.open{transform:translateY(0)}
  .nav-links li{width:100%;border-bottom:1px solid var(--silver-soft)}
  .nav-links li:last-child{border:none}
  .nav-links a{display:block;padding:1rem 0;width:100%}
  .nav-cta{margin:.6rem 0}
  .burger{display:flex}
  .grid-3{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .strip-inner{justify-content:flex-start;gap:1rem 1.8rem}
}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  html{scroll-behavior:auto}
}
