/* ==========================================================================
   AI Media — Mia-first homepage
   Palette: warm off-white paper · charcoal ink (matches hand-drawn logo)
            · iridescent pastel decoration (from Mia's fur halo)
   Type: Rubik (friendly rounded display) + Assistant (Hebrew body)
   ========================================================================== */

@font-face{font-family:'Assistant';src:url('fonts/Assistant-400.woff2') format('woff2');font-weight:400;font-display:swap;}
@font-face{font-family:'Assistant';src:url('fonts/Assistant-500.woff2') format('woff2');font-weight:500;font-display:swap;}
@font-face{font-family:'Assistant';src:url('fonts/Assistant-600.woff2') format('woff2');font-weight:600;font-display:swap;}
@font-face{font-family:'Assistant';src:url('fonts/Assistant-700.woff2') format('woff2');font-weight:700;font-display:swap;}

:root{
  /* paper / surfaces */
  --paper:#FAF8F4;
  --paper-2:#F3EDE4;
  --white:#FFFFFF;

  /* ink */
  --ink:#1B1815;
  --ink-2:#4E4842;
  --ink-3:#938B80;
  --line:#ECE5DA;
  --line-2:#E1D8CB;

  /* iridescent (Mia's edge) */
  --iri-lav:#CDB4F6;
  --iri-sky:#A8D8FF;
  --iri-mint:#C7EFDB;
  --iri-pink:#FFC9E3;
  --grad-iri:linear-gradient(110deg,#CDB4F6 0%,#A8D8FF 36%,#C7EFDB 64%,#FFC9E3 100%);
  --grad-iri-soft:linear-gradient(110deg,#E7DBFB 0%,#DCEEFF 36%,#E4F7EE 64%,#FFE5F1 100%);

  /* tints */
  --tint-lav:#F4EFFB;
  --tint-sky:#EBF5FF;
  --tint-mint:#EDF8F2;
  --tint-pink:#FFF0F7;
  --tint-cream:#FBF5EC;

  /* cta */
  --cta:#1B1815;
  --cta-hover:#000000;

  /* night (voice modal) */
  --night:#171320;
  --night-2:#221B31;

  --font-display:'Rubik','Assistant',sans-serif;
  --font-body:'Assistant',sans-serif;

  --container:1180px;
  --radius:18px;
  --radius-lg:28px;
  --radius-pill:999px;

  --shadow-sm:0 1px 3px rgba(27,24,21,.06);
  --shadow:0 4px 24px -8px rgba(27,24,21,.12);
  --shadow-lg:0 24px 60px -22px rgba(27,24,21,.22);
  --shadow-iri:0 30px 70px -30px rgba(120,90,200,.35);

  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--ink);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
::selection{background:rgba(205,180,246,.4);color:var(--ink);}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;letter-spacing:-.02em;line-height:1.1;margin:0;color:var(--ink);}
p{margin:0;}

.container{max-width:var(--container);margin-inline:auto;padding-inline:24px;}
.section{padding-block:clamp(64px,9vw,120px);position:relative;}

/* ---------- shared bits ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-display);
  font-size:13px;font-weight:500;
  text-transform:uppercase;letter-spacing:.16em;
  color:var(--ink-2);
}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--grad-iri);box-shadow:0 0 0 4px rgba(168,216,255,.25);}
.grad-text{background:var(--grad-iri);-webkit-background-clip:text;background-clip:text;color:transparent;}
.lead{font-size:clamp(18px,2vw,21px);color:var(--ink-2);line-height:1.62;}

/* buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--font-display);font-weight:500;font-size:16px;
  padding:15px 26px;border-radius:var(--radius-pill);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .2s,color .2s;
  white-space:nowrap;
}
.btn svg{width:19px;height:19px;flex:none;}
.btn-primary{background:var(--cta);color:#fff;box-shadow:var(--shadow);}
.btn-primary:hover{background:var(--cta-hover);transform:translateY(-2px);box-shadow:var(--shadow-lg);}
.btn-primary .ic{transition:transform .35s var(--ease);}
.btn-primary:hover .ic{transform:translateX(-4px);}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line-2);}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px);}
.btn-iri{position:relative;color:var(--ink);background:var(--white);border:1.5px solid transparent;
  background-image:linear-gradient(var(--white),var(--white)),var(--grad-iri);
  background-origin:border-box;background-clip:padding-box,border-box;box-shadow:var(--shadow-sm);}
.btn-iri:hover{transform:translateY(-2px);box-shadow:var(--shadow);}
.btn-lg{padding:18px 34px;font-size:18px;}

/* mic glyph wrapper */
.mic-glyph{width:20px;height:20px;}

/* ============================ HEADER ============================ */
.site-header{
  position:fixed;inset-block-start:0;inset-inline:0;z-index:60;
  transition:background .3s,box-shadow .3s,border-color .3s;
  border-block-end:1px solid transparent;
}
.site-header.scrolled{background:rgba(250,248,244,.82);backdrop-filter:blur(18px) saturate(1.3);border-block-end-color:var(--line);}
.header-inner{display:flex;align-items:center;gap:28px;height:84px;}
.brand{display:flex;align-items:center;gap:10px;}
.brand img{height:64px;width:auto;}
.brand .tag{display:none;}
.nav{display:flex;align-items:center;gap:28px;margin-inline-start:auto;}
.nav a{font-family:var(--font-display);font-weight:400;font-size:15.5px;color:var(--ink-2);transition:color .2s;position:relative;}
.nav a:hover{color:var(--ink);}
/* nav dropdown — built on <details> so it fails visible and needs no toggle JS (see FAQ accordion) */
.nav .nav-dd{position:relative;}
.nav .nav-dd>summary{font-family:var(--font-display);font-weight:400;font-size:15.5px;color:var(--ink-2);display:inline-flex;align-items:center;gap:6px;cursor:pointer;list-style:none;transition:color .2s;}
.nav .nav-dd>summary::-webkit-details-marker{display:none;}
.nav .nav-dd>summary:hover,.nav .nav-dd[open]>summary{color:var(--ink);}
.nav .nav-dd>summary::after{content:"";width:7px;height:7px;border-inline-end:1.6px solid currentColor;border-block-end:1.6px solid currentColor;transform:translateY(-2px) rotate(45deg);transition:transform .2s var(--ease);}
.nav .nav-dd[open]>summary::after{transform:translateY(1px) rotate(-135deg);}
.nav .nav-dd-panel{position:absolute;inset-inline-end:0;inset-block-start:calc(100% + 14px);min-width:230px;display:flex;flex-direction:column;background:var(--white);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:8px;z-index:80;}
.nav .nav-dd-panel a{font-size:15px;color:var(--ink-2);padding:10px 12px;border-radius:12px;transition:background .15s,color .15s;}
.nav .nav-dd-panel a:hover{background:var(--paper-2);color:var(--ink);}
.nav .nav-dd-panel a[aria-current="page"]{color:var(--ink);font-weight:500;}
.header-cta{display:flex;align-items:center;gap:14px;}
.header-cta .btn{padding:11px 20px;font-size:15px;}
.menu-toggle{display:none;width:42px;height:42px;border-radius:12px;align-items:center;justify-content:center;color:var(--ink);}
@media(max-width:900px){
  .nav{display:none;}
  .header-cta{margin-inline-start:auto;}
  .header-cta .btn-ghost{display:none;}
  .menu-toggle{display:flex;}
}

/* ============================ HERO ============================ */
.hero{position:relative;padding-block:clamp(110px,15vw,170px) clamp(40px,6vw,72px);overflow:hidden;}
.hero-glow{position:absolute;inset-block-start:-12%;inset-inline-end:-6%;width:min(820px,80vw);height:min(820px,80vw);
  background:radial-gradient(circle at 50% 45%,rgba(205,180,246,.5),rgba(168,216,255,.32) 40%,rgba(255,201,227,.16) 62%,transparent 72%);
  filter:blur(18px);z-index:0;pointer-events:none;}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;}
.hero-copy{max-width:600px;}
.hero h1{font-size:clamp(38px,5.6vw,70px);font-weight:600;line-height:1.04;margin-block:18px 0;}
.hero h1 .em{position:relative;white-space:nowrap;}
.hero-sub{margin-block-start:24px;font-size:clamp(17px,1.9vw,20px);color:var(--ink-2);line-height:1.6;max-width:540px;}
/* align-items:flex-start so the sibling CTA keeps its natural height when the
   inline "Talk to Mia" console expands into the tall .vc-panel (stretch would
   force the left button to the panel's height). */
.hero-cta{display:flex;flex-wrap:wrap;align-items:flex-start;gap:14px;margin-block-start:34px;}
.hero-trust{display:flex;flex-wrap:wrap;gap:10px 22px;margin-block-start:30px;}
.hero-trust span{display:inline-flex;align-items:center;gap:8px;font-size:14.5px;color:var(--ink-3);font-weight:500;}
.hero-trust span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--grad-iri);}

/* hero visual */
.hero-visual{position:relative;display:flex;align-items:center;justify-content:center;min-height:480px;}
.mia-stage{position:relative;width:min(440px,90%);aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;}
.mia-halo{position:absolute;inset:-6% -6% 4% -6%;border-radius:50%;
  background:radial-gradient(circle at 50% 46%,#fff 0%,#fff 30%,rgba(231,219,251,.9) 46%,rgba(220,238,255,.7) 60%,rgba(255,229,241,.4) 74%,transparent 82%);
  z-index:0;}
.mia-ring{position:absolute;inset:2%;border-radius:50%;border:1.5px dashed rgba(180,160,230,.4);z-index:0;animation:spin 46s linear infinite;}
.mia-ring.r2{inset:-7%;border-style:solid;border-color:rgba(168,216,255,.28);animation-duration:64s;animation-direction:reverse;}
.mia-img{position:relative;z-index:2;width:94%;filter:drop-shadow(0 26px 30px rgba(120,100,170,.22));animation:float 6.5s ease-in-out infinite;}
@keyframes float{0%,100%{transform:translateY(0) rotate(-.6deg);}50%{transform:translateY(-16px) rotate(.6deg);}}
@keyframes spin{to{transform:rotate(360deg);}}

/* floating live-call chip on hero */
.call-chip{position:absolute;z-index:4;background:var(--white);border:1px solid var(--line);border-radius:16px;
  box-shadow:var(--shadow-lg);padding:13px 16px;display:flex;align-items:center;gap:12px;backdrop-filter:blur(4px);}
.call-chip .pulse{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#1B1815,#3a3430);position:relative;flex:none;}
.call-chip .pulse::after{content:"";position:absolute;inset:0;border-radius:12px;box-shadow:0 0 0 0 rgba(168,216,255,.6);animation:ring 2.4s ease-out infinite;}
@keyframes ring{0%{box-shadow:0 0 0 0 rgba(168,216,255,.5);}70%{box-shadow:0 0 0 12px rgba(168,216,255,0);}100%{box-shadow:0 0 0 0 rgba(168,216,255,0);}}
.call-chip .ct b{display:block;font-family:var(--font-display);font-size:14px;}
.call-chip .ct small{color:var(--ink-3);font-size:12.5px;}
.call-chip.c1{inset-block-start:14%;inset-inline-start:-6%;animation:float 7.5s ease-in-out infinite;}
.call-chip.c2{inset-block-end:10%;inset-inline-end:-4%;animation:float 8.5s ease-in-out .6s infinite;}

@media(max-width:880px){
  .hero-grid{grid-template-columns:1fr;gap:8px;}
  .hero-visual{order:-1;min-height:340px;}
  .mia-stage{width:min(330px,80%);}
  .call-chip.c1{inset-inline-start:0;}
  .call-chip.c2{inset-inline-end:0;}
}

/* ============================ logo marquee / trust ============================ */
.trustbar{border-block:1px solid var(--line);background:var(--white);}
.trustbar .container{display:flex;align-items:center;gap:18px;flex-wrap:wrap;padding-block:22px;justify-content:center;}
.trustbar p{font-size:14px;color:var(--ink-3);font-weight:500;}
.trustbar .chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;}
.chip{font-family:var(--font-display);font-size:14px;font-weight:500;color:var(--ink-2);background:var(--paper);border:1px solid var(--line);padding:8px 15px;border-radius:var(--radius-pill);}

/* ============================ "what Mia does" + "how it works" — wave background ============================ */
#what,#how{position:relative;overflow:hidden;
  background:
    linear-gradient(180deg,rgba(250,248,244,.88) 0%,rgba(250,248,244,.52) 46%,rgba(250,248,244,.66) 100%),
    url('assets/bg-hero-wave.jpg') center / cover no-repeat;}
#what>.container,#how>.container{position:relative;z-index:1;}

/* ============================ section heading ============================ */
.sec-head{max-width:720px;margin-block-end:54px;}
.sec-head.center{margin-inline:auto;text-align:center;}
.sec-head h2{font-size:clamp(28px,4vw,46px);font-weight:600;margin-block:14px 0;}
.sec-head p{margin-block-start:18px;font-size:clamp(17px,1.8vw,19px);color:var(--ink-2);line-height:1.6;}

/* ============================ role spine ("what Mia does") ============================ */
.roles{display:grid;gap:20px;}
.role{
  display:grid;grid-template-columns:auto 1fr auto;gap:22px;align-items:center;
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:26px 30px;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;
}
.role:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--line-2);}
.role .num{font-family:var(--font-display);font-weight:600;font-size:15px;color:var(--ink);
  width:46px;height:46px;border-radius:14px;display:grid;place-items:center;background:var(--tint-lav);}
.role:nth-child(2) .num{background:var(--tint-sky);}
.role:nth-child(3) .num{background:var(--tint-mint);}
.role:nth-child(4) .num{background:var(--tint-pink);}
.role:nth-child(5) .num{background:var(--tint-cream);}
.role .body h3{font-size:21px;font-weight:600;margin-block-end:6px;}
.role .body p{color:var(--ink-2);font-size:16px;line-height:1.55;max-width:62ch;}
.role .tagk{font-family:var(--font-display);font-size:13px;font-weight:500;color:var(--ink-3);
  border:1px solid var(--line-2);border-radius:var(--radius-pill);padding:7px 14px;white-space:nowrap;}
@media(max-width:760px){
  .role{grid-template-columns:auto 1fr;padding:22px;}
  .role .tagk{display:none;}
}

/* ============================ call showcase ============================ */
.showcase{background:var(--night);color:#fff;border-radius:34px;overflow:hidden;position:relative;}
.showcase::before{content:"";position:absolute;inset-block-start:-30%;inset-inline-start:-10%;width:60%;height:120%;
  background:radial-gradient(circle,rgba(205,180,246,.35),transparent 62%);filter:blur(20px);}
.showcase::after{content:"";position:absolute;inset-block-end:-40%;inset-inline-end:-12%;width:60%;height:120%;
  background:radial-gradient(circle,rgba(168,216,255,.28),transparent 62%);filter:blur(20px);}
.showcase-grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;padding:clamp(34px,5vw,64px);}
.showcase h2{color:#fff;font-size:clamp(26px,3.4vw,40px);}
.showcase .sc-copy p{color:rgba(255,255,255,.72);margin-block-start:18px;font-size:18px;line-height:1.6;}
.showcase .eyebrow{color:rgba(255,255,255,.7);}
.sc-steps{display:flex;flex-direction:column;gap:14px;margin-block-start:28px;}
.sc-step{display:flex;align-items:center;gap:13px;font-size:16px;color:rgba(255,255,255,.9);}
.sc-step .k{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;flex:none;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);color:#fff;}
.sc-step .k svg{width:16px;height:16px;}

/* transcript mock card */
.tx-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:22px;backdrop-filter:blur(6px);}
.tx-top{display:flex;align-items:center;gap:11px;padding-block-end:16px;border-block-end:1px solid rgba(255,255,255,.1);margin-block-end:16px;}
.tx-top .av{width:46px;height:46px;border-radius:12px;position:relative;flex:none;overflow:hidden;}
.tx-top .av img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.tx-top b{font-family:var(--font-display);font-size:15px;color:#fff;display:block;}
.tx-top small{color:rgba(255,255,255,.55);font-size:12.5px;}
.tx-top .live{margin-inline-start:auto;display:inline-flex;align-items:center;gap:6px;font-size:12px;color:#9be7c0;}
.tx-top .live i{width:8px;height:8px;border-radius:50%;background:#42d98a;box-shadow:0 0 0 0 rgba(66,217,138,.6);animation:ring 2s infinite;}
.bubble{max-width:84%;padding:11px 15px;border-radius:16px;font-size:15px;line-height:1.5;margin-block-end:11px;}
.bubble.mia{background:linear-gradient(135deg,rgba(205,180,246,.22),rgba(168,216,255,.18));border:1px solid rgba(205,180,246,.3);color:#fff;border-start-end-radius:5px;}
.bubble.cust{background:rgba(255,255,255,.07);color:rgba(255,255,255,.86);margin-inline-start:auto;border-start-start-radius:5px;}
.summary{margin-block-start:16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:14px 16px;}
.summary b{font-family:var(--font-display);font-size:13px;color:#fff;display:flex;align-items:center;gap:7px;}
.summary ul{margin:11px 0 0;padding-inline-start:0;list-style:none;display:grid;gap:7px;}
.summary li{font-size:13.5px;color:rgba(255,255,255,.78);display:flex;gap:8px;}
.summary li span{color:rgba(255,255,255,.5);min-width:64px;}
@media(max-width:820px){.showcase-grid{grid-template-columns:1fr;gap:30px;}}

/* ============================ modules ============================ */
.mod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.mod{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;position:relative;overflow:hidden;}
.mod:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line-2);}
.mod .ic{width:52px;height:52px;border-radius:15px;display:grid;place-items:center;margin-block-end:18px;color:var(--ink);}
.mod h3{font-size:20px;font-weight:600;margin-block-end:9px;}
.mod p{color:var(--ink-2);font-size:15.5px;line-height:1.55;}
.mod .price{margin-block-start:16px;padding-block-start:15px;border-block-start:1px solid var(--line);
  font-size:14px;color:var(--ink-3);font-weight:500;display:flex;align-items:center;gap:8px;}
.mod .price svg{width:15px;height:15px;}
.mod.feat{background:linear-gradient(160deg,var(--tint-lav),var(--white) 70%);border-color:rgba(205,180,246,.5);}
.mod .ic.t-lav{background:var(--tint-lav);}.mod .ic.t-sky{background:var(--tint-sky);}
.mod .ic.t-mint{background:var(--tint-mint);}.mod .ic.t-pink{background:var(--tint-pink);}
.mod .ic.t-cream{background:var(--tint-cream);}.mod .ic.t-lav2{background:var(--tint-lav);}
.mod .badge{position:absolute;inset-block-start:18px;inset-inline-end:18px;font-family:var(--font-display);
  font-size:11.5px;font-weight:500;color:var(--ink);background:var(--white);border:1px solid rgba(205,180,246,.6);
  padding:5px 11px;border-radius:var(--radius-pill);}
@media(max-width:880px){.mod-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.mod-grid{grid-template-columns:1fr;}}

/* ============================ how it works ============================ */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;counter-reset:step;}
.step{position:relative;padding-block-start:14px;}
.step .n{font-family:var(--font-display);font-weight:600;font-size:15px;width:40px;height:40px;border-radius:50%;
  display:grid;place-items:center;background:var(--white);border:1.5px solid var(--line-2);color:var(--ink);margin-block-end:16px;}
.step h3{font-size:18px;font-weight:600;margin-block-end:7px;}
.step p{font-size:15px;color:var(--ink-2);line-height:1.5;}
.step::before{content:"";position:absolute;inset-block-start:33px;inset-inline-end:-10px;width:20px;height:1.5px;
  background:repeating-linear-gradient(90deg,var(--line-2) 0 5px,transparent 5px 10px);}
.step:last-child::before{display:none;}
@media(max-width:820px){.steps{grid-template-columns:1fr 1fr;}.step::before{display:none;}}
@media(max-width:480px){.steps{grid-template-columns:1fr;}}

/* ============================ niches ============================ */
.niche-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;}
.niche{position:relative;border-radius:var(--radius-lg);overflow:hidden;padding:34px;border:1px solid var(--line);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);min-height:280px;display:flex;flex-direction:column;}
.niche:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.niche.clinic{background:linear-gradient(155deg,var(--tint-pink),var(--white) 75%);}
.niche.travel{background:linear-gradient(155deg,var(--tint-sky),var(--white) 75%);}
.niche .nt{font-family:var(--font-display);font-size:13px;font-weight:500;color:var(--ink-3);text-transform:uppercase;letter-spacing:.12em;}
.niche h3{font-size:25px;font-weight:600;margin-block:10px 12px;}
.niche p{color:var(--ink-2);font-size:16px;line-height:1.55;max-width:46ch;}
.niche .loop{display:flex;flex-wrap:wrap;gap:8px;margin-block-start:auto;padding-block-start:22px;}
.niche .loop span{font-size:13px;font-weight:500;background:rgba(255,255,255,.7);border:1px solid var(--line);
  padding:6px 12px;border-radius:var(--radius-pill);color:var(--ink-2);}
.niche .arrow{position:absolute;inset-block-start:30px;inset-inline-end:30px;width:42px;height:42px;border-radius:50%;
  border:1.5px solid var(--line-2);display:grid;place-items:center;transition:.3s var(--ease);background:rgba(255,255,255,.6);}
.niche:hover .arrow{background:var(--ink);color:#fff;border-color:var(--ink);}
.niche.soon{background:var(--paper);border-style:dashed;align-items:center;justify-content:center;text-align:center;color:var(--ink-3);min-height:0;}
.niche.soon h3{color:var(--ink-2);font-size:20px;}
.niche.soon .grad-text{background:none;-webkit-background-clip:unset;background-clip:unset;color:var(--ink);text-decoration:underline;text-underline-offset:3px;}
@media(max-width:760px){.niche-grid{grid-template-columns:1fr;}}

/* ============================ works-with ============================ */
.workswith{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(28px,4vw,48px);display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center;}
.workswith h2{font-size:clamp(24px,3vw,34px);font-weight:600;}
.workswith p{color:var(--ink-2);margin-block-start:16px;font-size:17px;line-height:1.6;}
.ww-tools{display:flex;flex-wrap:wrap;gap:12px;}
.ww-tools .chip{background:var(--paper);}
@media(max-width:760px){.workswith{grid-template-columns:1fr;gap:24px;}}

/* ---------- why AI Media (4-pillar) ---------- */
.ben-grid.why-grid{grid-template-columns:repeat(4,1fr);}
.why-tools{justify-content:center;margin-block-start:36px;}
@media(max-width:980px){.ben-grid.why-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.ben-grid.why-grid{grid-template-columns:1fr;}}

/* ============================ try-mia band ============================ */
.tryband{position:relative;border-radius:34px;overflow:hidden;background:url('assets/bg-iri-smoke.jpg') center/cover no-repeat;padding:clamp(40px,6vw,72px);text-align:center;}
.tryband::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.74),rgba(255,255,255,.4) 58%,rgba(255,255,255,.2) 85%);}
.tryband .inner{position:relative;z-index:2;max-width:680px;margin-inline:auto;}
.tryband .mia-mini{width:138px;margin-inline:auto;margin-block-end:6px;filter:drop-shadow(0 18px 22px rgba(120,100,170,.18));animation:float 6s ease-in-out infinite;}
.tryband h2{font-size:clamp(28px,4vw,44px);font-weight:600;}
.tryband p{color:var(--ink-2);font-size:18px;margin-block-start:16px;line-height:1.6;}
.tryband .btn{margin-block-start:30px;}

/* ============================ FAQ ============================ */
.faq{max-width:820px;margin-inline:auto;}
.qa{border-block-end:1px solid var(--line);}
.qa button{width:100%;display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:24px 4px;text-align:start;font-family:var(--font-display);font-size:18px;font-weight:500;color:var(--ink);}
.qa .pm{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--line-2);display:grid;place-items:center;flex:none;transition:.3s var(--ease);}
.qa[open] .pm{background:var(--ink);color:#fff;border-color:var(--ink);transform:rotate(45deg);}
.qa .ans{overflow:hidden;max-height:0;transition:max-height .4s var(--ease);}
.qa .ans p{padding:0 4px 24px;color:var(--ink-2);font-size:16.5px;line-height:1.65;max-width:68ch;}

/* ============================ closing cta ============================ */
.closing{text-align:center;}
.closing .box{background:var(--ink);color:#fff;border-radius:34px;padding:clamp(44px,6vw,76px);position:relative;overflow:hidden;}
.closing .box::before{content:"";position:absolute;inset-block-start:-40%;inset-inline:0;height:140%;
  background:radial-gradient(circle at 50% 0,rgba(205,180,246,.3),transparent 55%);}
.closing h2{color:#fff;font-size:clamp(28px,4vw,46px);font-weight:600;position:relative;}
.closing p{color:rgba(255,255,255,.72);font-size:18px;margin-block-start:18px;position:relative;max-width:560px;margin-inline:auto;}
.closing .cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-block-start:32px;position:relative;}
.closing .btn-ghost{color:#fff;border-color:rgba(255,255,255,.3);}
.closing .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08);}

/* ============================ footer ============================ */
.site-footer{border-block-start:1px solid var(--line);padding-block:48px 36px;}
.footer-top{display:flex;flex-wrap:wrap;justify-content:space-between;gap:30px;}
.footer-top .brand img{height:36px;}
.footer-top p{color:var(--ink-3);font-size:15px;max-width:300px;margin-block-start:14px;line-height:1.55;}
.footer-cols{display:flex;gap:56px;flex-wrap:wrap;}
.fcol h4{font-family:var(--font-display);font-size:13px;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-3);margin-block-end:14px;}
.fcol a{display:block;color:var(--ink-2);font-size:15px;margin-block-end:10px;transition:color .2s;}
.fcol a:hover{color:var(--ink);}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-block-start:40px;padding-block-start:24px;border-block-start:1px solid var(--line);color:var(--ink-3);font-size:14px;}

/* ============================ contact form (#contact) ============================ */
.contact-section{background:var(--paper-2);}
.contact-inner{max-width:520px;margin-inline:auto;text-align:center;}
.contact-heading{font-size:clamp(22px,3.5vw,32px);margin-block-end:32px;}
.contact-form{text-align:start;}
.cf-fields{display:flex;gap:12px;margin-block-end:14px;}
.cf-fields input,.contact-form input[type="text"],.contact-form input[type="tel"]{
  flex:1 1 0;width:100%;padding:14px 16px;border:1.5px solid var(--line-2);border-radius:12px;
  background:var(--white);font-family:var(--font-body);font-size:16px;color:var(--ink);
  outline:none;transition:border-color .2s;}
.cf-fields input:focus,.contact-form input[type="text"]:focus,.contact-form input[type="tel"]:focus{border-color:var(--iri-lav);}
.cf-consent{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--ink-2);margin-block-end:18px;cursor:pointer;line-height:1.5;}
.cf-consent input[type="checkbox"]{margin-block-start:3px;flex:0 0 auto;}
.cf-err{font-size:14px;color:#c0392b;margin-block-end:12px;}
.cf-info{font-size:14px;color:var(--ink-3);margin-block-end:12px;}
.cf-submit-btn{width:100%;justify-content:center;}
.cf-otp-hint{font-size:15px;color:var(--ink-2);margin-block-end:20px;}
.cf-otp-row{display:flex;gap:12px;align-items:stretch;margin-block-end:14px;}
.cf-otp-row input{
  flex:1;max-width:180px;padding:14px 16px;border:1.5px solid var(--line-2);border-radius:12px;
  background:var(--white);font-family:var(--font-display);font-size:22px;letter-spacing:.18em;
  color:var(--ink);outline:none;transition:border-color .2s;}
.cf-otp-row input:focus{border-color:var(--iri-lav);}
.cf-otp-meta{display:flex;align-items:center;gap:12px;font-size:14px;color:var(--ink-3);margin-block-end:14px;flex-wrap:wrap;}
.cf-link{background:none;border:none;font-family:var(--font-body);font-size:14px;color:var(--ink-2);
  cursor:pointer;text-decoration:underline;text-underline-offset:3px;padding:0;transition:color .2s;}
.cf-link:hover{color:var(--ink);}
.cf-link:disabled{opacity:.45;cursor:default;text-decoration:none;}
.cf-cancel{display:block;margin-block-start:6px;color:var(--ink-3);}
.cf-done-msg{font-family:var(--font-display);font-size:18px;font-weight:500;color:var(--ink);text-align:center;padding-block:12px;}
@keyframes formFieldPulse{0%{box-shadow:0 0 0 0 rgba(205,180,246,.65);}70%{box-shadow:0 0 0 10px rgba(205,180,246,0);}100%{box-shadow:0 0 0 0 rgba(205,180,246,0);}}
.form-pulse{animation:formFieldPulse .9s ease 3;}
@media(max-width:560px){
  .cf-fields{flex-direction:column;}
  .cf-otp-row{flex-direction:column;}
  .cf-otp-row input{max-width:none;}
}

/* ============================ reveal ============================ */
/* Hidden state applies ONLY once JS confirms it can reveal it (html.reveal-ready).
   If JS / IntersectionObserver fails for any visitor, .reveal stays fully visible. */
html.reveal-ready .reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
html.reveal-ready .reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s;}.reveal.d2{transition-delay:.16s;}.reveal.d3{transition-delay:.24s;}.reveal.d4{transition-delay:.32s;}

/* ============================ mobile menu ============================ */
.mobile-menu{position:fixed;inset:0;z-index:90;background:var(--paper);transform:translateX(100%);
  transition:transform .4s var(--ease);display:flex;flex-direction:column;padding:24px;}
.mobile-menu.open{transform:none;}
.mobile-menu .mm-top{display:flex;align-items:center;justify-content:space-between;}
.mobile-menu nav{display:flex;flex-direction:column;gap:6px;margin-block-start:40px;}
.mobile-menu nav a{font-family:var(--font-display);font-size:24px;font-weight:500;padding-block:12px;border-block-end:1px solid var(--line);}
.mobile-menu .btn{margin-block-start:24px;}
/* mobile: same <details> collapses inline (no nested-menu, no absolute panel) */
.mobile-menu .nav-dd>summary{font-family:var(--font-display);font-size:24px;font-weight:500;color:var(--ink);padding-block:12px;border-block-end:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;cursor:pointer;list-style:none;}
.mobile-menu .nav-dd>summary::-webkit-details-marker{display:none;}
.mobile-menu .nav-dd>summary::after{content:"";width:10px;height:10px;border-inline-end:2px solid currentColor;border-block-end:2px solid currentColor;transform:translateY(-3px) rotate(45deg);transition:transform .2s var(--ease);}
.mobile-menu .nav-dd[open]>summary::after{transform:translateY(2px) rotate(-135deg);}
.mobile-menu .nav-dd-panel{position:static;background:none;border:0;border-radius:0;box-shadow:none;padding:0;min-width:0;display:flex;flex-direction:column;}
.mobile-menu .nav-dd-panel a{font-family:var(--font-display);font-size:19px;font-weight:400;color:var(--ink-2);padding-block:10px;padding-inline-start:18px;border-block-end:1px solid var(--line);}
.mobile-menu .nav-dd-panel a[aria-current="page"]{color:var(--ink);font-weight:500;}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;}
  .reveal{opacity:1;transform:none;}
}
