/* ============================================================
   DigiSignage — "Studio Daylight"  (LIGHT THEME)
   Brand teal/cyan + navy · green eco accent · airy & premium
   ============================================================ */

:root{
  /* surfaces */
  --bg:        #ffffff;
  --bg-2:      #f3f7f9;   /* light cool grey */
  --bg-3:      #e9f2f5;   /* teal-tinted */
  --surface:   #ffffff;
  --line:      #e3eaef;
  --line-soft: #eef3f6;

  /* ink */
  --navy:      #0e2138;   /* headings */
  --text:      #33414f;   /* body */
  --muted:     #6a7886;
  --muted-2:   #95a2ad;

  /* brand */
  --teal:      #0fa5c2;   /* bright cyan-teal (logo) */
  --teal-deep: #03758c;   /* deep brand teal */
  --teal-dk:   #02607a;
  --green:     #2fa84f;   /* eco / save-tree */
  --green-soft:#e7f6ec;

  /* accents used only inside mock screens (real signage is colourful) */
  --amber:     #f5a623;
  --coral:     #ff5c7a;
  --violet:    #8c7bff;
  --cyan:      #19c4d8;

  /* type */
  --display: 'Outfit', system-ui, sans-serif;
  --body:    'Satoshi', system-ui, -apple-system, sans-serif;
  --mono:    'Space Mono', ui-monospace, monospace;

  --wrap: 1200px;
  --r:    18px;
  --r-sm: 12px;
  --ease: cubic-bezier(.22,.61,.36,1);

  --shadow-sm: 0 4px 14px -6px rgba(14,33,56,.12);
  --shadow:    0 18px 44px -22px rgba(14,33,56,.28);
  --shadow-lg: 0 40px 90px -40px rgba(3,117,140,.45);
}

/* ---------- reset ---------- */
*{ box-sizing:border-box; margin:0; padding:0; }
[hidden]{ display:none !important; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--body);
  font-size:17px;
  line-height:1.6;
  letter-spacing:.01em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(900px 520px at 82% -8%, rgba(15,165,194,.10), transparent 60%),
    radial-gradient(760px 440px at -5% 8%, rgba(47,168,79,.06), transparent 55%);
  background-attachment: fixed;
}
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
h1,h2,h3,h4{ font-family:var(--display); font-weight:600; line-height:1.04; letter-spacing:-.02em; color:var(--navy); }
em{ font-style:normal; color:var(--teal-deep); }

.grain{ display:none; } /* not needed on light theme */

.wrap{ width:100%; max-width:var(--wrap); margin:0 auto; padding:0 28px; }
.wrap--narrow{ max-width:820px; }

/* ---------- shared bits ---------- */
.kicker{
  font-family:var(--mono); font-size:12px; font-weight:700; letter-spacing:.22em;
  color:var(--teal-deep); text-transform:uppercase; margin-bottom:18px;
}
.kicker--amber{ color:var(--green); }
.hl{ color:var(--teal-deep); }
.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--mono); font-size:12px; letter-spacing:.14em; color:var(--muted);
  background:#fff; border:1px solid var(--line); border-radius:100px; padding:8px 16px; margin-bottom:18px;
  box-shadow:var(--shadow-sm);
  animation:eyebrowGlow 2.4s ease-in-out infinite;
}
@keyframes eyebrowGlow{
  0%,100%{ box-shadow:0 0 0 0 rgba(15,165,194,0), var(--shadow-sm); border-color:var(--line); }
  50%    { box-shadow:0 0 20px 2px rgba(15,165,194,.5), var(--shadow-sm); border-color:var(--teal); }
}
.eyebrow__live{ width:7px; height:7px; border-radius:50%; background:var(--teal); box-shadow:0 0 0 0 rgba(15,165,194,.6); animation:pulse 2s infinite; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--body); font-weight:700; font-size:15px; letter-spacing:.01em;
  padding:13px 22px; border-radius:100px; cursor:pointer; border:1px solid transparent;
  transition:transform .25s var(--ease), background .25s, color .25s, box-shadow .25s, border-color .25s;
  white-space:nowrap;
}
.btn--lg{ padding:16px 30px; font-size:16px; }
.btn--block{ display:flex; width:100%; }
.btn--solid{ background:linear-gradient(145deg,var(--teal),var(--teal-deep)); color:#fff; box-shadow:0 12px 28px -10px rgba(3,117,140,.6); }
.btn--solid:hover{ transform:translateY(-2px); box-shadow:0 18px 40px -10px rgba(3,117,140,.7); }
.btn--line{ border-color:var(--line); color:var(--navy); background:#fff; box-shadow:var(--shadow-sm); }
.btn--line:hover{ border-color:var(--teal); color:var(--teal-deep); transform:translateY(-2px); }
.btn--ghost{ color:var(--navy); padding:10px 16px; }
.btn--ghost:hover{ color:var(--teal-deep); }
.play{ width:0; height:0; border-left:9px solid currentColor; border-top:6px solid transparent; border-bottom:6px solid transparent; }

/* ============================================================
   NAV
   ============================================================ */
.nav{ position:fixed; top:0; left:0; right:0; z-index:50; transition:background .3s, border-color .3s, box-shadow .3s, backdrop-filter .3s;
  border-bottom:1px solid var(--line); box-shadow:0 6px 20px -12px rgba(14,33,56,.22); }
.nav.is-stuck{ background:rgba(255,255,255,.85); backdrop-filter:blur(14px); border-bottom:1px solid var(--line); box-shadow:0 6px 24px -18px rgba(14,33,56,.5); }
.nav__inner{ display:flex; align-items:center; justify-content:space-between; height:76px; }

.brand{ display:inline-flex; align-items:center; }
.brand__logo{ height:38px; width:auto; }

.nav__links{ display:flex; gap:34px; }
.nav__links a{ font-size:15px; color:var(--text); font-weight:500; transition:color .2s; position:relative; }
.nav__links a:hover{ color:var(--teal-deep); }
.nav__links a::after{ content:''; position:absolute; left:0; bottom:-6px; height:2px; width:0; background:var(--teal); transition:width .25s var(--ease); }
.nav__links a:hover::after{ width:100%; }

.nav__cta{ display:flex; align-items:center; gap:8px; }

.nav__burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px; }
.nav__burger span{ width:24px; height:2px; background:var(--navy); transition:.3s; border-radius:2px; }
.nav__burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav__burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav__burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

.nav__mobile{ display:none; flex-direction:column; gap:4px; padding:0 28px 24px; background:rgba(255,255,255,.97); backdrop-filter:blur(14px); border-bottom:1px solid var(--line); }
.nav__mobile a{ padding:13px 4px; color:var(--text); border-bottom:1px solid var(--line-soft); }
.nav__mobile a.btn{ border-bottom:0; margin-top:8px; }
.nav__mobile.is-open{ display:flex; }

/* ============================================================
   HERO
   ============================================================ */
/* first screen: hero fills ~one viewport minus the strip, content centred,
   strip flows right after it (no forced pin → no clipping, no big gap) */
/* firstview = full screen; hero fills the space, strip pinned to the very bottom */
.firstview{ display:flex; flex-direction:column; min-height:100vh; min-height:100svh; }
.hero{ position:relative; flex:1 1 auto; display:flex; flex-direction:column; justify-content:center;
  padding:92px 0 30px; overflow:hidden; }
.marquee{ flex:0 0 auto; }
.hero__glow{ position:absolute; top:-140px; right:-100px; width:760px; height:760px; pointer-events:none;
  background:radial-gradient(circle, rgba(15,165,194,.16), transparent 62%); filter:blur(12px); }

.hero__grid{ position:relative; z-index:2; display:grid; grid-template-columns:1.05fr 1fr; gap:54px; align-items:center; }

.hero__title{ font-size:clamp(44px,6.2vw,80px); margin-bottom:16px; }
.hero__sub{ font-size:clamp(17px,2vw,20px); color:var(--muted); max-width:540px; margin-bottom:20px; }
.hero__actions{ display:flex; gap:14px; flex-wrap:wrap; margin-bottom:16px; }
.hero__eco{ display:inline-flex; align-items:center; gap:9px; font-size:14px; color:var(--green); font-weight:600;
  background:var(--green-soft); border:1px solid rgba(47,168,79,.2); border-radius:100px; padding:8px 16px; margin-bottom:14px; }
.hero__micro{ font-size:14px; color:var(--muted-2); max-width:470px; }
.hero__micro strong{ color:var(--text); font-weight:700; }

/* ----- device stage ----- */
.hero__stage{ position:relative; height:520px; }
.stage__floor{ position:absolute; left:4%; right:4%; bottom:34px; height:130px;
  background:radial-gradient(ellipse at center, rgba(3,117,140,.18), transparent 70%); filter:blur(12px); }

/* TV — wall-mounted flat panel (flush to the wall, soft cast shadow) */
.tv{ position:absolute; top:48px; left:-2%; width:90%; z-index:2; }
.tv__bezel{ position:relative; background:linear-gradient(155deg,#222c33,#090f13); padding:11px; border-radius:13px;
  border:1px solid rgba(255,255,255,.07);
  box-shadow:0 46px 72px -34px rgba(14,33,56,.55), 0 12px 28px -14px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.08); }
.tv__screen{ position:relative; aspect-ratio:16/9; border-radius:6px; overflow:hidden; background:#ffffff; }

.onair{ position:absolute; top:12px; right:12px; z-index:6; font-family:var(--mono); font-size:10px; font-weight:700;
  letter-spacing:.12em; color:#fff; background:rgba(255,60,90,.95); padding:4px 9px; border-radius:5px; animation:blink 1.6s steps(1) infinite; }
.onair--sm{ font-size:8px; padding:3px 6px; top:8px; right:8px; }

.slides{ position:absolute; inset:0; }
.slide{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:8px; opacity:0; text-align:center; animation:slideshow 16s infinite; }
.slide:nth-child(1){ animation-delay:0s; }
.slide:nth-child(2){ animation-delay:4s; }
.slide:nth-child(3){ animation-delay:8s; }
.slide:nth-child(4){ animation-delay:12s; }
/* product slides: image + name + price + feature bullets */
.slide--product{ flex-direction:row; align-items:center; justify-content:center; gap:20px;
  padding:0 26px; text-align:left; background:linear-gradient(135deg,#ffffff,#eef7fa); }
.pr-media{ flex:none; width:30%; max-width:128px; aspect-ratio:1; border-radius:16px;
  display:grid; place-items:center; font-size:clamp(40px,6vw,64px); box-shadow:0 8px 18px -10px rgba(14,33,56,.3); }
.pr-media--a{ background:linear-gradient(135deg,#e7f6fb,#bfe9f3); }
.pr-media--b{ background:linear-gradient(135deg,#fff1d6,#ffd98a); }
.pr-media--c{ background:linear-gradient(135deg,#ffe0e6,#ffc1cd); }
.pr-media--d{ background:linear-gradient(135deg,#e8e1ff,#cabcff); }
.pr-info{ display:flex; flex-direction:column; gap:2px; min-width:0; }
.pr-tag{ font-family:var(--mono); font-size:clamp(8px,1.1vw,11px); letter-spacing:.14em; color:var(--teal-deep); font-weight:700; }
.pr-name{ font-family:var(--display); font-weight:700; font-size:clamp(16px,2.4vw,26px); color:var(--navy); line-height:1.05; }
.pr-price{ font-family:var(--display); font-weight:700; font-size:clamp(18px,2.8vw,30px); color:#c77400; margin-bottom:5px; }
.pr-feats{ list-style:none; display:flex; flex-direction:column; gap:3px; }
.pr-feats li{ position:relative; padding-left:16px; font-size:clamp(9px,1.3vw,13px); color:#33414f; line-height:1.25; }
.pr-feats li::before{ content:'✓'; position:absolute; left:0; color:var(--teal); font-weight:700; }

.tv__ticker{ position:absolute; left:0; right:0; bottom:0; z-index:6;
  background:linear-gradient(90deg,#e02437,#a40f1c); color:#fff;
  font-family:var(--mono); font-size:11px; font-weight:700; padding:6px 0; overflow:hidden; }
.tv__ticker-track{ display:flex; width:max-content; animation:tickerseam 22s linear infinite; will-change:transform; }
.tv__ticker-track span{ white-space:nowrap; padding-right:48px; }

/* portrait — free-standing digital standee / totem */
.portrait{ position:absolute; right:-14px; bottom:0; width:30%; z-index:4;
  display:flex; flex-direction:column; align-items:center; }
.portrait__screen{ position:relative; width:100%; aspect-ratio:9/16; border-radius:9px; overflow:hidden;
  background:linear-gradient(165deg,#ffffff,#e9f5f8); border:6px solid #11181c;
  box-shadow:var(--shadow); display:flex; align-items:center; }
/* slim neck + flat floor base */
.portrait__stand{ position:relative; width:9px; height:46px; background:linear-gradient(180deg,#2b353e,#141d22); }
.portrait__stand::after{ content:''; position:absolute; left:50%; bottom:-5px; transform:translateX(-50%);
  width:98px; height:13px; border-radius:50%/60%;
  background:linear-gradient(180deg,#26323b,#0b1115); box-shadow:0 14px 22px -8px rgba(0,0,0,.5); }
/* digital menu board on the standee */
.menu{ display:flex; flex-direction:column; width:100%; padding:13px 12px 11px; }
.menu__head{ text-align:center; padding-bottom:7px; border-bottom:2px solid var(--teal); margin-bottom:6px; }
.menu__brand{ display:block; font-family:var(--display); font-weight:700; font-size:16px; color:var(--navy); line-height:1; }
.menu__sub{ display:block; font-family:var(--mono); font-size:7.5px; letter-spacing:.16em; color:var(--teal-deep); text-transform:uppercase; margin-top:4px; }
.menu__list{ list-style:none; display:flex; flex-direction:column; }
.menu__list li{ display:flex; justify-content:space-between; align-items:baseline; gap:7px;
  font-size:10px; line-height:1.2; padding:3.4px 0; border-bottom:1px dashed rgba(14,33,56,.13); color:#3a4754; }
.menu__list li span{ overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.menu__list li b{ color:var(--teal-deep); font-weight:700; flex:none; }
.menu__foot{ text-align:center; font-family:var(--mono); font-size:8.5px; letter-spacing:.06em; color:#fff;
  background:linear-gradient(90deg,var(--teal),var(--teal-deep)); padding:6px; border-radius:6px; margin-top:7px; }

/* standee cycles between Menu A and Menu B every ~3s */
.mslides{ position:absolute; inset:0; }
.mslide{ position:absolute; inset:0; opacity:0; display:flex; flex-direction:column; justify-content:flex-start;
  animation:mswap 6s ease-in-out infinite; }
.mslide:nth-child(1){ animation-delay:0s; }
.mslide:nth-child(2){ animation-delay:3s; }
.mslide .menu{ width:100%; }
@keyframes mswap{
  0%,3%   { opacity:0; }
  7%,46%  { opacity:1; }
  50%,100%{ opacity:0; }
}

/* Menu B — 4 product cards (image + name + price) */
.pgrid{ display:grid; grid-template-columns:1fr 1fr; gap:8px; margin:8px 0; }
.pcard{ background:#fff; border:1px solid var(--line); border-radius:8px; overflow:hidden;
  box-shadow:0 2px 8px -4px rgba(14,33,56,.25); }
.pcard__img{ height:48px; display:grid; place-items:center; font-size:27px; }
.pcard__img--a{ background:linear-gradient(135deg,#fff1d6,#ffd98a); }
.pcard__img--b{ background:linear-gradient(135deg,#ffe0e6,#ffc1cd); }
.pcard__img--c{ background:linear-gradient(135deg,#dcf4f8,#a9e6f0); }
.pcard__img--d{ background:linear-gradient(135deg,#e8e1ff,#cabcff); }
.pcard__body{ padding:5px 7px 7px; }
.pcard__name{ display:block; font-size:9.5px; font-weight:700; color:var(--navy); line-height:1.1; }
.pcard__price{ font-size:10.5px; font-weight:700; color:var(--teal-deep); }

/* floating chips */
.chip{ position:absolute; z-index:6; display:inline-flex; align-items:center; gap:8px;
  background:#fff; border:1px solid var(--line); border-radius:100px; padding:9px 15px;
  font-size:13px; font-weight:600; color:var(--navy); box-shadow:var(--shadow); }
.chip--sync{ top:22%; right:-8%; animation:floaty 6s ease-in-out infinite .3s; }
.chip--offline{ top:38%; left:-13%; color:var(--green); animation:floaty 6s ease-in-out infinite 1.1s; }
.chip__pulse{ width:8px; height:8px; border-radius:50%; background:var(--teal); animation:pulse 2s infinite; }
.chip__bolt{ font-size:12px; }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{ position:relative; border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  padding:20px 0; overflow:hidden; background:var(--bg-3);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent); }
.marquee__track{ display:flex; align-items:center; white-space:nowrap; width:max-content;
  font-family:var(--mono); font-size:14px; font-weight:700; letter-spacing:.16em;
  animation:marquee 45s linear infinite; }
.marquee__track span{ color:#3f5160; padding:0 16px; }
.marquee__track .sep{ color:var(--teal); font-weight:400; font-size:16px; padding:0; }

/* ============================================================
   SECTION SHELL
   ============================================================ */
.section{ padding:108px 0; position:relative; scroll-margin-top:84px; }
.section--tint{ background:var(--bg-2); }
.section__head{ max-width:680px; margin:0 auto 64px; text-align:center; }
.section__title{ font-size:clamp(32px,4.6vw,54px); margin-bottom:18px; }
.section__lead{ color:var(--muted); font-size:18px; }

/* ============================================================
   PILLARS
   ============================================================ */
/* asymmetric bento: two wide + two narrow, zig-zagged, with index watermark */
.pillars__grid{ display:grid; grid-template-columns:repeat(6,1fr); gap:18px; counter-reset:pill; }
.card{ counter-increment:pill; position:relative; isolation:isolate; background:var(--surface);
  border:1px solid var(--line); border-radius:var(--r); padding:32px 30px 34px; overflow:hidden;
  box-shadow:var(--shadow-sm); transition:transform .35s var(--ease), border-color .35s, box-shadow .35s; }
.card:nth-child(1), .card:nth-child(4){ grid-column:span 4; background:linear-gradient(135deg,var(--bg-3),var(--surface)); }
.card:nth-child(2), .card:nth-child(3){ grid-column:span 2; }
.card::before{ content:''; position:absolute; inset:0 0 auto 0; height:3px; z-index:2;
  background:linear-gradient(90deg,var(--teal),var(--teal-deep)); opacity:0; transition:opacity .35s; }
.card::after{ content:counter(pill,decimal-leading-zero); position:absolute; top:14px; right:22px; z-index:0;
  font-family:var(--display); font-weight:700; font-size:56px; line-height:1; color:rgba(15,165,194,.11); }
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.card:hover::before{ opacity:1; }
.card__ix, .card h3, .card p{ position:relative; z-index:1; }
.card h3{ font-size:22px; margin:22px 0 10px; }
.card p{ font-size:15px; color:var(--muted); max-width:48ch; }
.card p strong{ color:var(--navy); font-weight:700; }

.card__ix{ width:56px; height:56px; border-radius:16px; display:grid; place-items:center;
  color:var(--teal-deep); background:var(--bg-3); border:1px solid rgba(15,165,194,.22);
  transition:background .35s var(--ease), color .35s, transform .35s var(--ease), box-shadow .35s; }
.card__ix svg{ width:27px; height:27px; }
.card:hover .card__ix{ color:#fff; background:linear-gradient(145deg,var(--teal),var(--teal-deep));
  transform:translateY(-2px) rotate(-3deg); box-shadow:0 12px 24px -10px rgba(3,117,140,.55); }

/* ============================================================
   HOW
   ============================================================ */
/* process flow: numbered nodes on a dashed connector line */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; position:relative; }
.steps::before{ content:''; position:absolute; top:39px; left:16.66%; width:0; height:2px; z-index:0;
  background:repeating-linear-gradient(90deg, var(--teal) 0 7px, transparent 7px 15px); opacity:.5;
  transition:width 1.4s linear; }
.steps.is-drawn::before{ width:66.7%; }
.step{ position:relative; z-index:1; text-align:center; padding:0 16px; }
.step__node{ position:relative; width:80px; height:80px; border-radius:50%; margin:0 auto 24px;
  display:grid; place-items:center; color:#fff; background:linear-gradient(145deg,var(--teal),var(--teal-deep));
  box-shadow:0 16px 30px -12px rgba(3,117,140,.6); border:5px solid var(--bg);
  transition:transform .35s var(--ease); }
.step:hover .step__node{ transform:translateY(-4px) scale(1.05); }
.step__node svg{ width:32px; height:32px; }
.step__no{ position:absolute; top:-3px; right:-3px; min-width:26px; height:26px; padding:0 5px; border-radius:13px;
  background:var(--green); color:#fff; font-family:var(--mono); font-size:11px; font-weight:700;
  display:grid; place-items:center; border:3px solid var(--bg); }
.step h3{ font-size:22px; margin:0 0 10px; }
.step p{ color:var(--muted); font-size:15px; max-width:34ch; margin:0 auto; }

/* ============================================================
   FEATURES
   ============================================================ */
.feature{ display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; padding:54px 0; }
.feature--rev .feature__text{ order:2; }
.feature__text h3{ font-size:clamp(26px,3.2vw,38px); margin:0 0 18px; }
.feature__text p{ color:var(--muted); margin-bottom:24px; }
.feature__text strong{ color:var(--navy); }
.ticks{ list-style:none; display:flex; flex-direction:column; gap:13px; }
.ticks li{ position:relative; padding-left:30px; color:var(--text); font-size:15.5px; }
.ticks li::before{ content:''; position:absolute; left:0; top:3px; width:18px; height:18px; border-radius:50%;
  background:var(--bg-3); border:1px solid var(--teal); }
.ticks li::after{ content:''; position:absolute; left:6px; top:6px; width:5px; height:9px; border:2px solid var(--teal-deep); border-top:0; border-left:0; transform:rotate(45deg); }

.feature__art{ position:relative; }

/* editor mock */
.editor{ background:#0f161b; border:1px solid rgba(255,255,255,.06); border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow); }
.editor__bar{ display:flex; align-items:center; gap:7px; padding:13px 16px; background:#161f25; border-bottom:1px solid rgba(255,255,255,.06); }
.editor__bar i{ width:11px; height:11px; border-radius:50%; background:#2a3434; }
.editor__bar i:nth-child(1){ background:#ff5f57; } .editor__bar i:nth-child(2){ background:#febc2e; } .editor__bar i:nth-child(3){ background:var(--teal); }
.editor__bar span{ margin-left:10px; font-family:var(--mono); font-size:11px; color:#7d8a93; }
.editor__body{ display:flex; min-height:300px; }
.editor__rail{ display:flex; flex-direction:column; gap:8px; padding:14px 10px; background:#0c1216; border-right:1px solid rgba(255,255,255,.06); }
.tool{ width:36px; height:36px; border-radius:9px; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.07); display:grid; place-items:center; color:#7d8a93; font-size:16px; transition:.25s; }
.tool::after{ content:attr(data-t); }
.tool:nth-child(2){ background:rgba(15,165,194,.16); border-color:var(--teal); color:var(--teal); }
.editor__canvas{ flex:1; position:relative; margin:20px; border-radius:10px;
  background:linear-gradient(135deg,#2a1408,#140a04); overflow:hidden;
  background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px); background-size:22px 22px,22px 22px; }
.ed-block{ position:absolute; }
.ed-block--img{ inset:14px 14px 40% 55%; border-radius:8px; background:linear-gradient(135deg,var(--amber),#c77400); opacity:.95; }
.ed-block--head{ left:24px; top:34px; font-family:var(--display); font-weight:700; font-size:30px; color:#fff; }
.ed-block--sub{ left:24px; top:78px; font-size:16px; color:var(--amber); }
.ed-block--btn{ left:24px; bottom:34px; background:var(--teal); color:#fff; font-weight:700; font-size:13px; padding:9px 16px; border-radius:7px; }
.ed-handle{ position:absolute; left:18px; top:26px; right:40%; bottom:42%; border:1.5px dashed var(--teal); border-radius:6px; pointer-events:none; }
.ed-handle::after{ content:''; position:absolute; right:-5px; bottom:-5px; width:10px; height:10px; background:var(--teal); border-radius:2px; }

/* dashboard mock */
.dash{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:10px; box-shadow:var(--shadow); }
.dash__row{ display:grid; grid-template-columns:1.3fr 1fr 1.1fr; gap:10px; padding:15px 18px; align-items:center; font-size:14px; border-radius:10px; }
.dash__row + .dash__row{ margin-top:4px; }
.dash__row:not(.dash__row--head){ background:var(--bg-2); color:var(--navy); }
.dash__row--head{ font-family:var(--mono); font-size:10.5px; letter-spacing:.14em; color:var(--muted-2); padding-bottom:6px; }
.dot{ font-size:13px; font-weight:700; }
.dot.ok{ color:var(--green); } .dot.sync{ color:var(--amber); } .dot.off{ color:var(--teal-deep); }
.dash__push{ margin-top:10px; text-align:center; font-family:var(--mono); font-size:12px; color:#fff; background:linear-gradient(90deg,var(--teal),var(--teal-deep)); padding:11px; border-radius:10px; font-weight:700; }

/* extras mock */
.extras{ display:flex; flex-direction:column; gap:14px; }
.xcard{ border-radius:var(--r); padding:22px 24px; border:1px solid var(--line); background:var(--surface); box-shadow:var(--shadow-sm); }
.xcard span{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; }
.xcard p{ font-family:var(--display); font-size:19px; color:var(--navy); margin-top:8px; line-height:1.25; }
.xcard--thought{ border-left:4px solid var(--amber); } .xcard--thought span{ color:#c77400; }
.xcard--bday{ border-left:4px solid var(--coral); } .xcard--bday span{ color:#d9365a; }
.xcard--quiz{ border-left:4px solid var(--teal); } .xcard--quiz span{ color:var(--teal-deep); }

/* ============================================================
   COMPARISON TABLE
   ============================================================ */
.table{ border:1px solid var(--line); border-radius:var(--r); overflow:hidden; max-width:920px; margin:0 auto; background:var(--surface); box-shadow:var(--shadow-sm); }
.table__head, .table__row{ display:grid; grid-template-columns:1.6fr 1fr 1fr; align-items:center; }
.table__head{ background:var(--bg-3); }
.table__head span{ padding:22px 24px; font-family:var(--display); font-size:16px; color:var(--navy); }
.table__head small{ display:block; font-family:var(--mono); font-size:10px; letter-spacing:.1em; color:var(--muted-2); font-weight:400; margin-top:4px; }
.col-us{ color:var(--teal-deep); }
.col-them{ color:var(--muted); }
.table__row{ border-top:1px solid var(--line); }
.table__row span{ padding:18px 24px; font-size:15px; }
.table__row span:first-child{ color:var(--navy); }
.table__row .yes, .table__row .no{ font-weight:700; font-family:var(--mono); font-size:13px; letter-spacing:.05em; }
.table__row .yes{ color:var(--green); }
.table__row .yes::before{ content:'✓ '; }
.table__row .no{ color:var(--muted-2); }
.table__row .no::before{ content:'✕ '; color:var(--coral); }
.table__row:nth-child(even){ background:var(--bg-2); }

/* ============================================================
   INDUSTRIES
   ============================================================ */
/* two opposing scrolling rows of industry chips */
.indmarq{ display:flex; flex-direction:column; gap:18px; overflow-x:clip; overflow-y:visible; padding:8px 0;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); }
.indrow{ overflow:visible; }
.indtrack{ display:flex; gap:16px; width:max-content; will-change:transform; animation:indleft 48s linear infinite; }
.indrow--rev .indtrack{ animation:indright 48s linear infinite; }
.indrow:hover .indtrack{ animation-play-state:paused; }
@keyframes indleft{ from{ transform:translateX(0); }     to{ transform:translateX(-50%); } }
@keyframes indright{ from{ transform:translateX(-50%); } to{ transform:translateX(0); } }
.indchip{ display:inline-flex; align-items:center; gap:12px; flex:none; white-space:nowrap;
  background:var(--surface); border:1px solid var(--line); border-radius:100px; padding:14px 26px;
  box-shadow:var(--shadow-sm); font-weight:600; font-size:16px; color:var(--navy);
  transition:border-color .25s, box-shadow .25s, transform .25s; }
.indchip:hover{ border-color:var(--teal); box-shadow:var(--shadow); transform:translateY(-2px); }
.indchip__emoji{ font-size:22px; }

/* ============================================================
   PRICING
   ============================================================ */
.plans{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; align-items:start; }
.plan{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:34px 30px;
  display:flex; flex-direction:column; gap:8px; box-shadow:var(--shadow-sm); transition:transform .35s var(--ease), border-color .35s, box-shadow .35s; }
.plan:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.plan--featured{ background:linear-gradient(180deg,var(--bg-3),var(--surface)); border-color:var(--teal);
  position:relative; box-shadow:var(--shadow-lg); }
.plan__tag{ position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:linear-gradient(90deg,var(--teal),var(--teal-deep)); color:#fff;
  font-family:var(--mono); font-size:10px; font-weight:700; letter-spacing:.14em; padding:6px 14px; border-radius:100px; }
.plan__name{ font-size:24px; }
.plan__for{ color:var(--muted); font-size:14px; margin-bottom:14px; }
.plan__price{ font-family:var(--display); font-size:46px; font-weight:700; line-height:1; margin-bottom:6px; color:var(--navy); }
.plan__price .rupee{ font-size:26px; vertical-align:super; color:var(--muted); }
.plan__price small{ display:block; font-family:var(--body); font-size:13px; font-weight:400; color:var(--muted); margin-top:8px; }
.plan__price--talk{ color:var(--teal-deep); }
.plan__list{ list-style:none; display:flex; flex-direction:column; gap:11px; margin:18px 0 26px; }
.plan__list li{ position:relative; padding-left:26px; font-size:14.5px; color:var(--text); }
.plan__list li::before{ content:'✓'; position:absolute; left:0; color:var(--teal-deep); font-weight:700; }
.plan .btn{ margin-top:auto; }
.pricing__note{ text-align:center; color:var(--muted-2); font-size:13px; margin-top:30px; }

/* ============================================================
   QUOTES
   ============================================================ */
/* scrolling review carousel with star ratings */
.qmarq{ overflow-x:clip; overflow-y:visible; padding:8px 0;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent); }
.qtrack{ display:flex; gap:20px; width:max-content; will-change:transform; animation:qscroll 70s linear infinite; }
.qmarq:hover .qtrack{ animation-play-state:paused; }
@keyframes qscroll{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
.qcard{ flex:none; width:360px; display:flex; flex-direction:column;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:28px 30px;
  box-shadow:var(--shadow-sm); transition:transform .3s var(--ease), box-shadow .3s, border-color .3s; }
.qcard:hover{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:var(--teal); }
.stars{ color:var(--amber); font-size:17px; letter-spacing:3px; margin-bottom:15px; }
.stars .off{ color:var(--line); }
.qcard blockquote{ font-size:16px; line-height:1.6; color:var(--navy); margin:0 0 20px; flex:1; }
.qcard figcaption{ font-size:14px; color:var(--muted); }
.qcard figcaption strong{ color:var(--teal-deep); font-weight:700; }

/* ============================================================
   FAQ
   ============================================================ */
.faq__wrap{ display:grid; grid-template-columns:0.82fr 1.18fr; gap:56px; align-items:start; max-width:1080px; }
.faq__intro{ position:sticky; top:104px; }
.faq__intro .section__title{ text-align:left; margin-bottom:0; }
.faq__intro .kicker{ text-align:left; }
.faq__help{ color:var(--muted); font-size:16px; margin:16px 0 24px; max-width:34ch; }
.faq__list{ display:flex; flex-direction:column; gap:12px; }
.faq__item{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-sm); padding:4px 24px; transition:border-color .3s, box-shadow .3s; }
.faq__item[open]{ border-color:var(--teal); box-shadow:var(--shadow-sm); }
.faq__item summary{ cursor:pointer; list-style:none; padding:20px 0; font-family:var(--display); font-size:18px; font-weight:500; color:var(--navy);
  display:flex; justify-content:space-between; align-items:center; gap:16px; }
.faq__item summary::-webkit-details-marker{ display:none; }
.faq__item summary::after{ content:'+'; color:var(--teal-deep); font-size:26px; font-weight:300; transition:transform .3s; line-height:1; }
.faq__item[open] summary::after{ transform:rotate(45deg); }
.faq__item p{ color:var(--muted); padding:0 0 22px; font-size:15.5px; }

/* ============================================================
   CTA
   ============================================================ */
.cta{ position:relative; padding:120px 0; overflow:hidden; text-align:center; background:var(--navy); }
.cta__glow{ position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); width:980px; height:560px;
  background:radial-gradient(ellipse, rgba(15,165,194,.32), transparent 65%); filter:blur(20px); pointer-events:none; }
.cta__inner{ position:relative; z-index:2; max-width:680px; }
.cta__inner .kicker{ color:var(--cyan); }
.cta__title{ font-size:clamp(36px,5.5vw,64px); margin:6px 0 18px; color:#fff; }
.cta__sub{ color:#aebccb; font-size:19px; margin-bottom:34px; }
.cta__actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-bottom:24px; }
.cta__actions .btn--line{ background:transparent; border-color:rgba(255,255,255,.25); color:#fff; box-shadow:none; }
.cta__actions .btn--line:hover{ border-color:var(--cyan); color:var(--cyan); }
.cta__call{ font-size:14px; color:#aebccb; }
.cta__call a{ color:var(--cyan); font-weight:700; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ border-top:1px solid var(--line); padding:72px 0 36px; background:var(--bg-2); position:relative; z-index:2; }
.footer__grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.4fr; gap:40px; padding-bottom:48px; border-bottom:1px solid var(--line); }
.footer__logo{ height:42px; width:auto; }
.footer__tag{ color:var(--muted); font-size:14.5px; margin-top:18px; max-width:300px; }
.footer__eco{ display:inline-flex; align-items:center; gap:8px; margin-top:16px; font-size:13px; font-weight:600; color:var(--green); }
.footer__col h4{ font-family:var(--mono); font-size:12px; letter-spacing:.14em; color:var(--muted-2); text-transform:uppercase; margin-bottom:16px; font-weight:700; }
.footer__col a{ display:block; color:var(--muted); font-size:14.5px; padding:6px 0; transition:color .2s; }
.footer__col a:hover{ color:var(--teal-deep); }
.footer__col--contact p{ color:var(--muted); font-size:14px; margin-bottom:14px; line-height:1.7; }
.footer__col--contact a{ display:inline; padding:0; color:var(--muted); }
.footer__col--contact a:hover{ color:var(--teal-deep); }
.footer__bottom{ display:flex; justify-content:space-between; align-items:center; padding-top:28px; font-size:13px; color:var(--muted-2); flex-wrap:wrap; gap:10px; }
.footer__made{ color:var(--muted); }

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

@keyframes pulse{ 0%{ box-shadow:0 0 0 0 rgba(15,165,194,.5);} 70%{ box-shadow:0 0 0 9px rgba(15,165,194,0);} 100%{ box-shadow:0 0 0 0 rgba(15,165,194,0);} }
@keyframes blink{ 50%{ opacity:.45; } }
@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-12px); } }
@keyframes sway{ 0%,100%{ transform:rotate(-.55deg); } 50%{ transform:rotate(.55deg); } }
@keyframes tickerseam{ to{ transform:translateX(-50%); } }
@keyframes marquee{ to{ transform:translateX(-50%); } }
@keyframes eq{ 0%,100%{ opacity:.4; transform:scaleX(.7); } 50%{ opacity:1; transform:scaleX(1); } }
@keyframes slideshow{
  0%,2%   { opacity:0; transform:scale(1.04); }
  4%,22%  { opacity:1; transform:scale(1); }
  25%,100%{ opacity:0; transform:scale(.99); }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1040px){
  .pillars__grid{ grid-template-columns:1fr 1fr; }
  .pillars__grid .card{ grid-column:auto !important; }
  .quotes__grid{ grid-template-columns:1fr; }
  .ind__grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:620px){
  .pillars__grid{ grid-template-columns:1fr; }
}
@media (max-width:900px){
  .nav__links, .nav__cta{ display:none; }
  .nav__burger{ display:flex; }
  .hero__grid{ grid-template-columns:1fr; gap:60px; }
  .hero__stage{ height:420px; max-width:520px; }
  .feature{ grid-template-columns:1fr; gap:34px; }
  .feature--rev .feature__text{ order:0; }
  .steps{ grid-template-columns:1fr; gap:32px; }
  .steps::before{ display:none; }
  .faq__wrap{ grid-template-columns:1fr; gap:30px; }
  .faq__intro{ position:static; }
  .plans{ grid-template-columns:1fr; max-width:440px; margin:0 auto; }
  .footer__grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:560px){
  body{ font-size:16px; }
  .section{ padding:76px 0; }
  .wrap{ padding:0 20px; }
  .hero{ padding:120px 0 60px; }
  .ind__grid{ grid-template-columns:1fr; }
  .footer__grid{ grid-template-columns:1fr; gap:30px; }
  .table__head span, .table__row span{ padding:14px 12px; font-size:13px; }
  .hero__stage{ height:360px; }
}

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

/* ===== Lead capture modal ===== */
.lead-modal{ position:fixed; inset:0; z-index:200; display:none; }
.lead-modal.is-open{ display:block; }
.lead-modal__backdrop{ position:absolute; inset:0; background:rgba(14,33,56,.55); backdrop-filter:blur(3px); }
.lead-modal__card{ position:relative; z-index:1; width:min(440px,92vw); margin:7vh auto 0;
  background:#fff; border-radius:18px; padding:32px 30px; box-shadow:0 40px 90px -30px rgba(14,33,56,.5);
  max-height:86vh; overflow:auto; animation:leadin .3s ease; }
@keyframes leadin{ from{ opacity:0; transform:translateY(14px); } to{ opacity:1; transform:none; } }
.lead-modal__x{ position:absolute; top:14px; right:16px; border:0; background:none; font-size:26px; line-height:1; color:var(--muted); cursor:pointer; }
.lead-modal h3{ font-size:26px; margin:6px 0 6px; }
.lead-sub{ color:var(--muted); font-size:15px; margin-bottom:18px; }
.lead-input{ width:100%; font-family:var(--body); font-size:15px; color:var(--navy);
  background:var(--bg-2); border:1px solid var(--line); border-radius:10px; padding:13px 15px; margin-bottom:12px; }
.lead-input:focus{ outline:none; border-color:var(--teal); background:#fff; }
.lead-otp{ text-align:center; font-size:28px; letter-spacing:14px; font-weight:700; }
.lead-hp{ position:absolute; left:-9999px; width:1px; height:1px; opacity:0; }
.lead-err{ color:#d9365a; font-size:13px; min-height:18px; margin:0 0 8px; }
.lead-resend{ text-align:center; color:var(--muted); font-size:13px; margin-top:14px; }
.lead-resend button{ border:0; background:none; color:var(--teal-deep); font-weight:700; cursor:pointer; }
.lead-resend button:disabled{ color:var(--muted-2); cursor:default; }
.lead-tick{ width:64px; height:64px; border-radius:50%; margin:0 auto 14px; display:grid; place-items:center;
  background:var(--green-soft); color:var(--green); font-size:32px; font-weight:700; }
.lead-step[data-step="success"]{ text-align:center; }
.btn.is-loading{ opacity:.7; pointer-events:none; }

/* inline email verify */
.lead-emailrow{ display:flex; gap:8px; align-items:stretch; margin-bottom:12px; }
.lead-emailrow .lead-input{ flex:1; margin-bottom:0; }
.lead-vbtn{ flex:none; border:1px solid var(--teal); background:#fff; color:var(--teal-deep);
  font-weight:700; font-size:13px; border-radius:10px; padding:0 18px; cursor:pointer;
  transition:background .2s, color .2s; }
.lead-vbtn:hover{ background:var(--teal); color:#fff; }
.lead-vbtn:disabled{ opacity:.55; cursor:default; background:#fff; color:var(--teal-deep); }
.lead-vbadge{ flex:none; display:inline-flex; align-items:center; padding:0 16px; border-radius:10px;
  background:var(--green-soft); color:var(--green); font-weight:700; font-size:13px; white-space:nowrap; }
.lead-input[readonly]{ background:#eef6f3; color:var(--muted); }
.lead-otprow{ background:var(--bg-2); border:1px solid var(--line); border-radius:12px; padding:14px; margin-bottom:12px; }
.lead-otpnote{ font-size:13px; color:var(--muted); margin-bottom:10px; }
.lead-otpline{ display:flex; gap:8px; }
.lead-otpline .lead-otp{ flex:1; margin-bottom:0; letter-spacing:8px; font-size:22px; text-align:center; }
.lead-hint{ text-align:center; font-size:12.5px; color:var(--muted-2); margin-top:10px; }
#leadSubmit:disabled{ opacity:.5; cursor:default; box-shadow:none; transform:none; }

/* ============================================================
   BLOG — list page, post detail, shared states
   ============================================================ */

/* ── Hero strip ─────────────────────────────── */
.blog-hero{
  padding:136px 0 64px;
  background:linear-gradient(160deg, var(--bg-3) 0%, var(--bg) 70%);
  border-bottom:1px solid var(--line);
  text-align:center;
  position:relative;
  overflow:hidden;
}
.blog-hero::before{
  content:'';
  position:absolute;
  top:-120px; right:-60px;
  width:560px; height:560px;
  pointer-events:none;
  background:radial-gradient(circle, rgba(15,165,194,.13), transparent 62%);
  filter:blur(10px);
}
.blog-hero__inner{ position:relative; z-index:2; }
.blog-hero .kicker{ margin-bottom:14px; }
.blog-hero__title{
  font-size:clamp(38px,6vw,68px);
  margin-bottom:16px;
  color:var(--navy);
}
.blog-hero__sub{
  font-size:clamp(16px,2vw,19px);
  color:var(--muted);
  max-width:520px;
  margin:0 auto;
}

/* ── List section spacing ───────────────────── */
.blog-list-section{ padding-top:56px; padding-bottom:108px; }

/* ── Category filter row ────────────────────── */
.blog-filter{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:44px;
}
.blog-chip{
  font-family:var(--mono);
  font-size:12px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:9px 18px;
  border-radius:100px;
  border:1px solid var(--line);
  background:var(--surface);
  color:var(--muted);
  cursor:pointer;
  transition:background .22s, color .22s, border-color .22s, box-shadow .22s, transform .22s;
  white-space:nowrap;
}
.blog-chip:hover{
  border-color:var(--teal);
  color:var(--teal-deep);
  transform:translateY(-1px);
}
.blog-chip--active{
  background:linear-gradient(145deg,var(--teal),var(--teal-deep));
  color:#fff;
  border-color:var(--teal-deep);
  box-shadow:0 8px 20px -8px rgba(3,117,140,.5);
}
.blog-chip--active:hover{ color:#fff; }

/* ── Card grid ──────────────────────────────── */
.blog-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
  margin-bottom:52px;
}
@media (max-width:1000px){ .blog-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:640px){  .blog-grid{ grid-template-columns:1fr; } }

.blog-card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--r);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  box-shadow:var(--shadow-sm);
  transition:transform .32s var(--ease), border-color .32s, box-shadow .32s;
}
.blog-card:hover{
  transform:translateY(-5px);
  box-shadow:var(--shadow);
  border-color:var(--teal);
}

/* cover */
.blog-card__cover-link{
  display:block;
  aspect-ratio:16/9;
  overflow:hidden;
  background:var(--bg-3);
  position:relative;
}
.blog-card__cover-link--placeholder::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,var(--bg-3),var(--bg-2));
}
.blog-card__cover{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .45s var(--ease);
}
.blog-card:hover .blog-card__cover{ transform:scale(1.04); }

/* body */
.blog-card__body{
  padding:22px 24px 26px;
  display:flex;
  flex-direction:column;
  flex:1;
  gap:10px;
}
.blog-card__chip{
  display:inline-block;
  align-self:flex-start;
  font-family:var(--mono);
  font-size:10px;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--teal-deep);
  background:var(--bg-3);
  border:1px solid rgba(15,165,194,.2);
  border-radius:100px;
  padding:5px 12px;
}
.blog-card__title{
  font-size:20px;
  font-family:var(--display);
  font-weight:600;
  line-height:1.2;
  color:var(--navy);
  margin:0;
}
.blog-card__title a{
  color:inherit;
  text-decoration:none;
  transition:color .22s;
}
.blog-card__title a:hover{ color:var(--teal-deep); }
.blog-card__excerpt{
  font-size:14.5px;
  color:var(--muted);
  line-height:1.6;
  flex:1;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
  margin:0;
}
.blog-card__date{
  font-family:var(--mono);
  font-size:11px;
  color:var(--muted-2);
  letter-spacing:.08em;
  margin-top:auto;
}

/* ── Pagination ─────────────────────────────── */
.blog-pagination{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:center;
  margin-top:12px;
}
.blog-page-btn{
  min-width:40px;
  height:40px;
  padding:0 12px;
  border-radius:10px;
  border:1px solid var(--line);
  background:var(--surface);
  color:var(--navy);
  font-family:var(--mono);
  font-size:13px;
  font-weight:700;
  cursor:pointer;
  transition:background .2s, color .2s, border-color .2s, transform .2s;
}
.blog-page-btn:hover:not(:disabled){
  border-color:var(--teal);
  color:var(--teal-deep);
  transform:translateY(-1px);
}
.blog-page-btn--active{
  background:linear-gradient(145deg,var(--teal),var(--teal-deep));
  color:#fff;
  border-color:var(--teal-deep);
}
.blog-page-btn:disabled{ opacity:.4; cursor:default; }

/* ── Loading / empty / error states ─────────── */
.blog-state{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:14px;
  text-align:center;
  padding:72px 20px;
  color:var(--muted);
  font-size:16px;
}
.blog-state--hidden{ display:none !important; }
.blog-state--error{ color:var(--coral); }
.blog-state__icon{ font-size:42px; line-height:1; }
.blog-state__spinner{
  width:38px;
  height:38px;
  border:3px solid var(--bg-3);
  border-top-color:var(--teal);
  border-radius:50%;
  animation:spin .75s linear infinite;
}
@keyframes spin{ to{ transform:rotate(360deg); } }

/* ── Post page layout ───────────────────────── */
.post-wrap{
  padding-top:108px;
  padding-bottom:108px;
  max-width:800px;
}
.post-back{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:14px;
  font-weight:600;
  color:var(--muted);
  margin-bottom:36px;
  transition:color .22s, gap .22s;
}
.post-back:hover{ color:var(--teal-deep); gap:12px; }
.post-back svg{ flex:none; }

/* post states (same classes, different container) */
.post-state{
  padding:80px 0;
  flex-direction:column;
  align-items:flex-start;
}

/* cover */
.post-cover{
  width:100%;
  border-radius:var(--r);
  overflow:hidden;
  margin-bottom:36px;
  background:var(--bg-3);
  aspect-ratio:16/9;
  display:flex;
  align-items:center;
  justify-content:center;
}
.post-cover__img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

/* post header */
.post-header{ margin-bottom:32px; }
.post-meta{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:12px;
  margin-bottom:16px;
}
.post-date{
  font-family:var(--mono);
  font-size:12px;
  color:var(--muted-2);
  letter-spacing:.08em;
}
.post-tags{ display:flex; flex-wrap:wrap; gap:6px; }
.post-tag{
  font-family:var(--mono);
  font-size:10px;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  padding:4px 10px;
  border-radius:100px;
  border:1px solid var(--line);
  color:var(--muted);
  background:var(--bg-2);
}
.post-title{
  font-size:clamp(30px,5vw,50px);
  color:var(--navy);
  line-height:1.1;
  margin-bottom:14px;
}
.post-summary{
  font-size:18px;
  color:var(--muted);
  line-height:1.65;
  border-left:3px solid var(--teal);
  padding-left:18px;
  margin:0;
}

/* ── .blog-article — rich-text body typography ── */
.blog-article .post-body{
  font-size:17px;
  line-height:1.75;
  color:var(--text);
  margin-top:36px;
  padding-top:36px;
  border-top:1px solid var(--line);
}

/* headings */
.blog-article .post-body h1,
.blog-article .post-body h2,
.blog-article .post-body h3,
.blog-article .post-body h4{
  font-family:var(--display);
  font-weight:600;
  color:var(--navy);
  line-height:1.15;
  letter-spacing:-.02em;
  margin:2em 0 .7em;
}
.blog-article .post-body h2{ font-size:clamp(22px,3.2vw,32px); }
.blog-article .post-body h3{ font-size:clamp(19px,2.6vw,26px); }
.blog-article .post-body h4{ font-size:20px; }
.blog-article .post-body h2:first-child,
.blog-article .post-body h3:first-child{ margin-top:0; }

/* paragraphs */
.blog-article .post-body p{ margin:0 0 1.4em; }
.blog-article .post-body p:last-child{ margin-bottom:0; }

/* links */
.blog-article .post-body a{
  color:var(--teal-deep);
  text-decoration:underline;
  text-underline-offset:3px;
  text-decoration-color:rgba(3,117,140,.35);
  transition:color .2s, text-decoration-color .2s;
}
.blog-article .post-body a:hover{
  color:var(--teal);
  text-decoration-color:var(--teal);
}

/* lists */
.blog-article .post-body ul,
.blog-article .post-body ol{
  margin:0 0 1.4em 1.5em;
  padding:0;
}
.blog-article .post-body li{
  margin-bottom:.5em;
  line-height:1.65;
}
.blog-article .post-body ul{ list-style:disc; }
.blog-article .post-body ol{ list-style:decimal; }

/* blockquote */
.blog-article .post-body blockquote{
  margin:2em 0;
  padding:18px 24px;
  background:var(--bg-3);
  border-left:4px solid var(--teal);
  border-radius:0 var(--r-sm) var(--r-sm) 0;
  color:var(--navy);
  font-size:18px;
  font-style:italic;
  line-height:1.65;
}
.blog-article .post-body blockquote p{ margin:0; }
.blog-article .post-body blockquote p + p{ margin-top:.8em; }

/* images */
.blog-article .post-body img{
  max-width:100%;
  height:auto;
  display:block;
  border-radius:var(--r-sm);
  margin:1.6em auto;
  box-shadow:var(--shadow-sm);
}

/* code */
.blog-article .post-body code{
  font-family:var(--mono);
  font-size:.9em;
  background:var(--bg-3);
  padding:2px 6px;
  border-radius:5px;
  color:var(--teal-deep);
}
.blog-article .post-body pre{
  background:var(--navy);
  color:#d4e1eb;
  border-radius:var(--r-sm);
  padding:20px 24px;
  overflow-x:auto;
  margin:1.6em 0;
  font-family:var(--mono);
  font-size:14px;
  line-height:1.7;
}
.blog-article .post-body pre code{
  background:none;
  padding:0;
  color:inherit;
  font-size:inherit;
}

/* horizontal rule */
.blog-article .post-body hr{
  border:0;
  border-top:1px solid var(--line);
  margin:2.4em 0;
}

/* table */
.blog-article .post-body table{
  width:100%;
  border-collapse:collapse;
  margin:1.6em 0;
  font-size:15px;
}
.blog-article .post-body th,
.blog-article .post-body td{
  padding:12px 16px;
  border:1px solid var(--line);
  text-align:left;
}
.blog-article .post-body th{
  background:var(--bg-3);
  font-family:var(--display);
  font-weight:600;
  color:var(--navy);
}
.blog-article .post-body tr:nth-child(even) td{ background:var(--bg-2); }

/* ── Blog responsive ─────────────────────────── */
@media (max-width:900px){
  .blog-hero{ padding:116px 0 52px; }
  .post-wrap{ padding-top:96px; padding-bottom:80px; }
}
@media (max-width:560px){
  .blog-hero{ padding:100px 0 44px; }
  .blog-card__body{ padding:18px 18px 22px; }
  .post-wrap{ padding-top:88px; }
  .post-summary{ font-size:16px; }
}
