/* ============================================================
   Maindi — Landing Page
   Brand system: Ñom Studio guidelines
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  /* Primary palette */
  --cream:#F5EDDB;
  --cobalt:#1E3270;
  --rose:#CC8090;
  --petal:#F0C8CC;
  /* Secondary palette */
  --sand:#EDE4CE;
  --taupe:#8A8078;
  --deep-taupe:#6A6050;
  --deep-cobalt:#152558;
  /* Derived */
  --cobalt-12:rgba(30,50,112,0.12);
  --cobalt-20:rgba(30,50,112,0.20);
  --cream-60:rgba(245,237,219,0.62);
  --cream-75:rgba(245,237,219,0.78);

  /* Type */
  --font-display:'Instrument Serif', Georgia, 'Times New Roman', serif;
  --font-body:'Inter', system-ui, -apple-system, sans-serif;

  /* Tweakable */
  --accent:#CC8090;          /* dusty rose */
  --accent-on:#FBF7EE;       /* text on accent */
  --hscale:1;
  --radius:22px;
  --radius-sm:14px;
  --radius-pill:999px;

  /* Layout */
  --maxw:1200px;
  --gutter:clamp(20px,5vw,72px);
  --section-y:clamp(64px,9vw,128px);
}

/* ---------- Reset ---------- */
*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;
  background:var(--cream);
  color:var(--cobalt);
  font-family:var(--font-body);
  font-weight:400;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;height:auto;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;}
::selection{background:var(--rose);color:#fff;}

/* ---------- Type ---------- */
.display{
  font-family:var(--font-display);
  font-weight:400;
  font-size:calc(clamp(52px,7.4vw,92px) * var(--hscale));
  line-height:0.98;
  letter-spacing:-0.012em;
  margin:0;
}
.display .it,.heading .it,.subheading .it{font-style:italic;color:var(--accent);}
.heading{
  font-family:var(--font-display);
  font-weight:400;
  font-size:calc(clamp(32px,4.4vw,50px) * var(--hscale));
  line-height:1.04;
  letter-spacing:-0.008em;
  margin:0;
  text-wrap:balance;
}
.subheading{
  font-family:var(--font-display);
  font-weight:400;
  font-size:clamp(21px,2.4vw,28px);
  line-height:1.2;
  margin:0;
}
.lede{
  font-size:clamp(16.5px,1.35vw,18.5px);
  font-weight:300;
  line-height:1.62;
  color:var(--deep-taupe);
  max-width:46ch;
  text-wrap:pretty;
  margin:0;
}
.dark .lede{color:rgba(245,237,219,0.82);}
.body{font-size:15.5px;font-weight:300;line-height:1.64;color:var(--deep-taupe);text-wrap:pretty;}
.eyebrow{
  font-size:11px;font-weight:700;line-height:1.2;
  letter-spacing:0.18em;text-transform:uppercase;
  color:var(--accent);
  display:inline-flex;align-items:center;gap:11px;margin:0;
}
.eyebrow::before{content:"";width:26px;height:1.5px;background:currentColor;display:inline-block;}
.eyebrow.center{justify-content:center;}
.caption{font-size:12px;font-weight:400;color:var(--taupe);letter-spacing:.01em;}
.dark .caption{color:rgba(245,237,219,0.6);}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter);}
section{position:relative;}
.section-pad{padding-block:var(--section-y);}

/* Section contexts */
.light{background:var(--cream);color:var(--cobalt);}
.sand{background:var(--sand);color:var(--cobalt);}
.dark{background:var(--cobalt);color:var(--cream);}
.dark .heading,.dark .display,.dark .subheading{color:var(--cream);}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-body);font-weight:600;font-size:15px;letter-spacing:.005em;
  padding:13px 22px;border-radius:var(--radius-pill);
  border:1.5px solid transparent;transition:transform .16s ease, box-shadow .16s ease, background .16s ease;
  white-space:nowrap;line-height:1;
}
.btn--primary{background:var(--accent);color:var(--accent-on);box-shadow:0 1px 0 rgba(0,0,0,0.04);}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 10px 24px -10px var(--accent);}
.btn--ghost{background:transparent;color:var(--cobalt);border-color:var(--cobalt-20);}
.btn--ghost:hover{border-color:var(--cobalt);}
.dark .btn--ghost{color:var(--cream);border-color:rgba(245,237,219,0.32);}
.dark .btn--ghost:hover{border-color:var(--cream);}
.btn--lg{padding:16px 28px;font-size:16px;}

/* ---------- Nav ---------- */
.nav{
  position:sticky;top:0;z-index:40;
  background:var(--cream-75);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--cobalt-12);
}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:72px;}
.nav__logo{display:flex;align-items:center;}
.nav__logo img{height:26px;width:auto;}
.nav__links{display:flex;align-items:center;gap:34px;}
.nav__links a{font-size:14.5px;font-weight:500;color:var(--taupe);transition:color .15s;}
.nav__links a:hover{color:var(--cobalt);}
.nav__cta{display:flex;align-items:center;gap:18px;}
.nav__menu{display:none;background:none;border:none;color:var(--cobalt);padding:6px;}

/* ---------- Forms ---------- */
.signup{display:flex;gap:9px;max-width:440px;width:100%;}
.signup input{
  flex:1;min-width:0;font-family:var(--font-body);font-size:15px;font-weight:400;
  padding:13px 18px;border-radius:var(--radius-pill);
  border:1.5px solid var(--cobalt-20);background:rgba(255,255,255,0.7);color:var(--cobalt);
  transition:border-color .15s, box-shadow .15s;
}
.signup input::placeholder{color:var(--taupe);}
.signup input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 18%,transparent);}
.dark .signup input{background:rgba(255,255,255,0.06);border-color:rgba(245,237,219,0.28);color:var(--cream);}
.dark .signup input::placeholder{color:rgba(245,237,219,0.55);}
.signup--stack{flex-direction:column;align-items:stretch;}
.signup--stack .btn{width:100%;}
.form-note{margin-top:11px;}
.form-ok{display:none;align-items:center;gap:9px;font-size:15px;color:var(--accent);font-weight:500;}
.form-ok.show{display:flex;}
.form-ok svg{width:20px;height:20px;}

/* ---------- Illustration frames ---------- */
.frame{
  border-radius:var(--radius);overflow:hidden;
  box-shadow:0 30px 60px -28px rgba(21,37,88,0.45), 0 2px 0 rgba(255,255,255,0.04);
  background:#6c7bd6;line-height:0;
}
.frame img{width:100%;}
.frame--soft{box-shadow:0 24px 48px -30px rgba(21,37,88,0.4);}

/* ---------- Hero ---------- */
.hero{padding-top:clamp(40px,5vw,72px);padding-bottom:var(--section-y);overflow:hidden;}
.hero__grid{
  display:grid;grid-template-columns:minmax(0,0.92fr) minmax(0,1.08fr);
  gap:clamp(28px,4vw,64px);align-items:center;
}
.hero--image-right .hero__grid{grid-template-columns:minmax(0,1.08fr) minmax(0,0.92fr);}
.hero--image-right .hero__media{order:2;}
.hero--image-right .hero__copy{order:1;}
.hero__copy{display:flex;flex-direction:column;align-items:flex-start;gap:22px;}
.hero__copy .display{margin-top:2px;}
.hero__media{position:relative;}
.hero__copy .signup{margin-top:4px;}

/* ---------- Trust strip ---------- */
.trust{background:var(--deep-cobalt);color:var(--cream);}
.trust .wrap{display:flex;align-items:center;gap:14px 30px;flex-wrap:wrap;padding-block:18px;}
.trust__label{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--petal);}
.trust__items{display:flex;align-items:center;gap:12px 26px;flex-wrap:wrap;}
.trust__item{display:flex;align-items:center;gap:9px;font-size:13.5px;font-weight:400;color:rgba(245,237,219,0.86);}
.trust__item::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--rose);flex:0 0 auto;}

/* ---------- Generic split section ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,80px);align-items:center;}
.split--copy-first .split__media{order:2;}
.split__copy{display:flex;flex-direction:column;align-items:flex-start;gap:20px;max-width:520px;}
.split__copy.gap-sm{gap:14px;}

/* ---------- Statement strip ---------- */
.statement{background:var(--petal);}
.statement .wrap{padding-block:clamp(40px,5.5vw,72px);}
.statement__q{
  font-family:var(--font-display);font-weight:400;
  font-size:clamp(26px,3.5vw,42px);line-height:1.16;letter-spacing:-0.005em;
  color:var(--cobalt);max-width:20ch;margin:0;text-wrap:balance;
}
.statement__q .it{font-style:italic;}

/* ---------- The Moment / flow ---------- */
.moment__head{max-width:680px;display:flex;flex-direction:column;gap:18px;margin-bottom:clamp(36px,4vw,56px);}
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-top:clamp(34px,4vw,52px);counter-reset:step;}
.step{padding-top:18px;border-top:1.5px solid rgba(245,237,219,0.24);}
.step__n{font-family:var(--font-display);font-size:26px;line-height:1;color:var(--petal);}
.step__t{font-weight:600;font-size:15px;margin:11px 0 6px;color:var(--cream);}
.step__d{font-size:13px;font-weight:300;line-height:1.5;color:rgba(245,237,219,0.7);}

/* ---------- Features (editorial 1 big + 3) ---------- */
.features__head{max-width:760px;margin-bottom:clamp(34px,4vw,52px);display:flex;flex-direction:column;gap:16px;}
.feat-grid{display:grid;grid-template-columns:1.12fr 1fr;grid-auto-rows:1fr;gap:14px;}
.feat{
  border-radius:var(--radius);padding:clamp(24px,2.6vw,38px);
  border:1.5px solid var(--cobalt-12);background:var(--cream);
  display:flex;flex-direction:column;
}
.feat__n{font-family:var(--font-display);font-size:20px;color:var(--accent);line-height:1;}
.feat__t{font-family:var(--font-display);font-size:clamp(22px,2vw,28px);line-height:1.08;margin:14px 0 10px;color:var(--cobalt);}
.feat__d{font-size:14.5px;font-weight:300;line-height:1.55;color:var(--deep-taupe);max-width:34ch;}
.feat--hero{
  grid-row:span 3;background:var(--cobalt);border-color:var(--cobalt);
  justify-content:flex-end;padding:clamp(30px,3vw,46px);
}
.feat--hero .feat__n{color:var(--petal);font-size:24px;}
.feat--hero .feat__t{color:var(--cream);font-size:clamp(30px,3vw,40px);margin-top:18px;}
.feat--hero .feat__d{color:rgba(245,237,219,0.8);font-size:16px;max-width:32ch;}
.feat--hero .feat__top{margin-bottom:auto;}
.feat__chip{
  align-self:flex-start;font-size:11px;font-weight:600;letter-spacing:.06em;
  color:var(--petal);border:1px solid rgba(240,200,204,0.4);border-radius:var(--radius-pill);
  padding:6px 13px;
}
.feat:not(.feat--hero){background:var(--sand);border-color:transparent;}

/* ---------- Dashboard showcase ---------- */
.showcase__head{max-width:620px;display:flex;flex-direction:column;gap:16px;margin-bottom:clamp(30px,3.5vw,48px);}
.showcase__chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px;}
.chip{
  font-size:13px;font-weight:500;color:var(--cobalt);background:var(--cream);
  border:1.5px solid var(--cobalt-12);border-radius:var(--radius-pill);padding:8px 16px;
}
.dark .chip{background:rgba(245,237,219,0.08);border-color:rgba(245,237,219,0.18);color:var(--cream);}

/* ---------- Swiss section ---------- */
.swiss__list{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-direction:column;gap:16px;}
.swiss__list li{display:flex;gap:13px;align-items:flex-start;font-size:16px;font-weight:300;color:rgba(245,237,219,0.9);}
.swiss__list li strong{font-weight:600;color:var(--cream);}
.swiss__list svg{flex:0 0 auto;width:22px;height:22px;margin-top:1px;color:var(--rose);}

/* ---------- Testimonial ---------- */
.quote{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px);align-items:center;}
.quote__mark{font-family:var(--font-display);font-size:clamp(90px,12vw,150px);line-height:0.6;color:var(--petal);height:0.5em;display:block;}
.quote__t{
  font-family:var(--font-display);font-weight:400;
  font-size:clamp(24px,2.9vw,36px);line-height:1.22;letter-spacing:-0.004em;
  color:var(--cobalt);margin:18px 0 22px;text-wrap:balance;
}
.quote__t .it{font-style:italic;color:var(--accent);}
.quote__who{display:flex;flex-direction:column;gap:2px;}
.quote__who b{font-weight:600;font-size:15px;color:var(--cobalt);}
.quote__who span{font-size:13.5px;color:var(--taupe);}

/* ---------- Closing CTA ---------- */
.closing{background:var(--cobalt);color:var(--cream);text-align:center;overflow:hidden;}
.closing .wrap{display:flex;flex-direction:column;align-items:center;gap:24px;max-width:760px;}
.closing .signup{margin:0 auto;}
.closing .form-note{text-align:center;}

/* ---------- Footer ---------- */
.footer{background:var(--deep-cobalt);color:rgba(245,237,219,0.7);padding-block:clamp(48px,6vw,72px) 32px;}
.footer__top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;padding-bottom:36px;border-bottom:1px solid rgba(245,237,219,0.12);}
.footer__brand{display:flex;flex-direction:column;gap:16px;max-width:280px;}
.footer__brand img{height:24px;width:auto;}
.footer__brand p{font-size:13.5px;font-weight:300;line-height:1.55;color:rgba(245,237,219,0.6);margin:0;}
.footer__cols{display:flex;gap:clamp(36px,6vw,84px);flex-wrap:wrap;}
.footer__col h4{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--petal);margin:0 0 16px;}
.footer__col a{display:block;font-size:14px;font-weight:300;color:rgba(245,237,219,0.72);margin-bottom:11px;transition:color .15s;}
.footer__col a:hover{color:var(--cream);}
.footer__bottom{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;padding-top:26px;font-size:12.5px;color:rgba(245,237,219,0.5);}
.footer__bottom .secure{display:flex;align-items:center;gap:8px;}
.footer__bottom .secure svg{width:15px;height:15px;}

/* ---------- Reveal animation (gated on JS) ---------- */
.reveal{opacity:1;transform:none;}
html.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.22,.61,.36,1), transform .7s cubic-bezier(.22,.61,.36,1);}
html.js .reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){
  html.js .reveal{opacity:1;transform:none;transition:none;}
  html{scroll-behavior:auto;}
}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .hero__grid,.split,.quote{grid-template-columns:1fr;gap:32px;}
  .hero__media,.hero--image-right .hero__media{order:-1;}
  .split--copy-first .split__media{order:-1;}
  .hero__copy,.split__copy{max-width:none;}
  .feat-grid{grid-template-columns:1fr;}
  .feat--hero{grid-row:auto;}
  .steps{grid-template-columns:1fr 1fr;gap:22px 18px;}
  .quote__mark{height:0.4em;}
  .nav__links{display:none;}
}
@media (max-width:560px){
  .nav__cta .btn{display:none;}
  .nav__menu{display:inline-flex;}
  .signup{flex-direction:column;align-items:stretch;}
  .signup .btn{width:100%;}
  .steps{grid-template-columns:1fr;}
  .trust__label{width:100%;}
  .footer__top{flex-direction:column;gap:32px;}
}
