/* ============================================================
   AgentPro — 僱傭中心管理系統 / Marketing homepage
   Design system + components
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --brand:        #1587C3;   /* logo azure */
  --brand-600:    #0E72AB;
  --brand-700:    #0B5E8F;
  --brand-glow:   rgba(21,135,195,.28);

  --navy:         #0C2A47;
  --navy-900:     #081E33;
  --navy-800:     #0E2F4F;

  --ink:          #15222F;   /* main heading text */
  --muted:        #56697B;   /* body text */
  --muted-2:      #82929F;   /* captions */

  --line:         #E5EDF4;
  --line-2:       #EDF3F8;

  --bg:           #FBFCFE;
  --tint:         #F1F7FC;   /* light blue section */
  --tint-2:       #E4F1FA;
  --tint-3:       #D4E8F6;
  --white:        #FFFFFF;

  --wa:           #25D366;   /* whatsapp green */
  --amber:        #F0A92B;
  --green:        #2BA66B;

  --r-lg: 22px;
  --r-md: 16px;
  --r-sm: 11px;

  --sh-sm: 0 2px 8px -3px rgba(12,42,71,.14);
  --sh-md: 0 16px 40px -20px rgba(12,42,71,.30);
  --sh-lg: 0 34px 70px -30px rgba(12,42,71,.36);
  --sh-card: 0 1px 2px rgba(12,42,71,.05), 0 12px 28px -18px rgba(12,42,71,.22);

  --container: 1200px;
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);

  --font: "Noto Sans TC", system-ui, -apple-system, "PingFang HK", "Microsoft JhengHei", sans-serif;
  --font-num: "Manrope", var(--font);
}

/* accent overridable by Tweaks */
.accent-azure { --brand:#1587C3; --brand-600:#0E72AB; --brand-700:#0B5E8F; --brand-glow:rgba(21,135,195,.28); }
.accent-royal { --brand:#1366E0; --brand-600:#0F54BC; --brand-700:#0C459B; --brand-glow:rgba(19,102,224,.30); }
.accent-navy  { --brand:#1E3A8A; --brand-600:#182F6F; --brand-700:#132456; --brand-glow:rgba(30,58,138,.30); }

/* ---------- Reset ---------- */
*{ box-sizing:border-box; margin:0; padding:0; }
/* sup：用 position 而非 vertical-align，確保在 flex 容器（如 .hero-meta）內仍置於右上角 */
sup{ font-size:.62em; font-weight:inherit; line-height:0; position:relative; top:-.55em; margin-left:.04em; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--font);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }
ul{ list-style:none; }
::selection{ background:var(--brand); color:#fff; }

.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:24px; }

/* ---------- Type helpers ---------- */
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-size:13px; font-weight:700; letter-spacing:.14em;
  color:var(--brand-600); text-transform:uppercase;
}
.eyebrow::before{ content:""; width:22px; height:2px; border-radius:2px; background:var(--brand); }
.eyebrow.center::after{ content:""; width:22px; height:2px; border-radius:2px; background:var(--brand); }
.eyebrow.center{ justify-content:center; }

h1,h2,h3{ color:var(--ink); letter-spacing:-.01em; line-height:1.18; font-weight:800; text-wrap:balance; }
.h-sect{ font-size:clamp(28px,3.5vw,46px); }
.lead{ color:var(--muted); font-size:clamp(16px,1.3vw,19px); line-height:1.75; text-wrap:pretty; }
.num{ font-family:var(--font-num); font-feature-settings:"tnum"; }

/* ---------- Buttons ---------- */
.btn{
  --b:var(--brand);
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  height:54px; padding:0 26px; border-radius:13px;
  font-weight:700; font-size:16px; letter-spacing:.01em;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s, color .25s;
  will-change:transform; white-space:nowrap;
}
.btn svg{ width:19px; height:19px; }
.btn-primary{
  color:#fff; position:relative; overflow:hidden;
  background:linear-gradient(135deg, var(--brand) 0%, var(--brand-600) 100%);
  box-shadow:0 10px 24px -10px var(--brand-glow), inset 0 1px 0 rgba(255,255,255,.22);
}
.btn-primary::after{
  content:""; position:absolute; inset:0; transform:translateX(-120%);
  background:linear-gradient(110deg, transparent 20%, rgba(255,255,255,.35) 50%, transparent 80%);
  transition:transform .7s var(--ease);
}
.btn-primary:hover{ transform:translateY(-3px); box-shadow:0 20px 38px -14px var(--brand-glow), inset 0 1px 0 rgba(255,255,255,.25); }
.btn-primary:hover::after{ transform:translateX(120%); }
.btn-primary:active{ transform:translateY(-1px) scale(.99); }

.btn-ghost{
  color:var(--navy); background:var(--white);
  border:1.5px solid var(--line); box-shadow:var(--sh-sm);
}
.btn-ghost:hover{ transform:translateY(-3px); border-color:var(--tint-3); box-shadow:var(--sh-md); }
.btn-ghost:active{ transform:translateY(-1px); }

.btn-wa{ color:#fff; background:linear-gradient(135deg,#2BD96E,#16B257); box-shadow:0 10px 24px -12px rgba(37,211,102,.6); }
.btn-wa:hover{ transform:translateY(-3px); box-shadow:0 20px 36px -16px rgba(37,211,102,.7); }

.btn-lg{ height:58px; padding:0 32px; font-size:17px; }
.btn-light{ background:#fff; color:var(--navy); }
.btn-light:hover{ transform:translateY(-3px); box-shadow:0 18px 40px -16px rgba(0,0,0,.4); }
.btn-outline-light{ background:rgba(255,255,255,.06); color:#fff; border:1.5px solid rgba(255,255,255,.28); }
.btn-outline-light:hover{ background:rgba(255,255,255,.14); transform:translateY(-3px); }

/* ============================================================
   NAVBAR
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:90;
  transition:background .35s var(--ease), box-shadow .35s, border-color .35s, height .35s;
  height:84px; border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(180%) blur(16px);
  -webkit-backdrop-filter:saturate(180%) blur(16px);
  border-bottom:1px solid var(--line);
  height:70px;
  box-shadow:0 6px 24px -20px rgba(12,42,71,.5);
}
.nav-inner{ height:100%; display:flex; align-items:center; gap:18px; }
.nav-logo{ height:30px; flex-shrink:0; transition:height .35s; }
.nav.scrolled .nav-logo{ height:27px; }
.nav-menu{ display:flex; align-items:center; gap:4px; margin-left:8px; }
.nav-link{
  position:relative; padding:10px 13px; border-radius:9px; white-space:nowrap;
  font-size:15.5px; font-weight:500; color:var(--ink);
  transition:color .2s, background .2s;
}
.nav-link::after{
  content:""; position:absolute; left:14px; right:14px; bottom:5px; height:2px; border-radius:2px;
  background:var(--brand); transform:scaleX(0); transform-origin:left; transition:transform .28s var(--ease);
}
.nav-link:hover{ color:var(--brand-600); }
.nav-link:hover::after{ transform:scaleX(1); }
.nav-spacer{ flex:1; }
.nav-cta{ display:flex; align-items:center; gap:12px; }
.nav-phone{ display:inline-flex; align-items:center; gap:7px; font-weight:600; font-size:14.5px; color:var(--navy); white-space:nowrap; }
.nav-phone svg{ width:17px; height:17px; color:var(--brand); }
.lang-switch{
  display:inline-flex; align-items:center; gap:5px; height:38px; padding:0 13px;
  border-radius:10px; border:1.5px solid var(--line); background:#fff;
  font-size:14px; font-weight:700; color:var(--navy); transition:.25s;
}
.lang-switch:hover{ border-color:var(--tint-3); color:var(--brand-600); transform:translateY(-2px); box-shadow:var(--sh-sm); }
.lang-switch svg{ width:15px; height:15px; }
.mm-link.lang-row{ color:var(--brand-600); font-weight:700; }

.hamburger{ display:none; width:44px; height:44px; border-radius:10px; align-items:center; justify-content:center; }
.hamburger span{ display:block; width:22px; height:2px; background:var(--ink); border-radius:2px; position:relative; transition:.3s; }
.hamburger span::before,.hamburger span::after{ content:""; position:absolute; left:0; width:22px; height:2px; background:var(--ink); border-radius:2px; transition:.3s; }
.hamburger span::before{ top:-7px; } .hamburger span::after{ top:7px; }
.hamburger.open span{ background:transparent; }
.hamburger.open span::before{ top:0; transform:rotate(45deg); }
.hamburger.open span::after{ top:0; transform:rotate(-45deg); }

.mobile-menu{
  position:fixed; inset:0 0 0 auto; width:min(86vw,360px); z-index:95;
  background:#fff; box-shadow:-20px 0 60px -30px rgba(12,42,71,.5);
  transform:translateX(100%); transition:transform .42s var(--ease-out);
  display:flex; flex-direction:column; padding:26px 24px; gap:6px;
}
.mobile-menu.open{ transform:translateX(0); }
.mm-head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:18px; }
.mm-link{ padding:15px 12px; font-size:18px; font-weight:600; border-bottom:1px solid var(--line-2); display:flex; justify-content:space-between; align-items:center; }
.mm-link svg{ width:18px; color:var(--muted-2); }
.scrim{ position:fixed; inset:0; background:rgba(8,30,51,.45); z-index:94; opacity:0; pointer-events:none; transition:opacity .42s; backdrop-filter:blur(2px); }
.scrim.open{ opacity:1; pointer-events:auto; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; padding-top:148px; padding-bottom:90px; overflow:hidden; }
.hero-bg{ position:absolute; inset:0; z-index:0; overflow:hidden; pointer-events:none; }
.blob{ position:absolute; border-radius:50%; filter:blur(60px); opacity:.5; }
.blob.b1{ width:560px; height:560px; top:-180px; right:-120px; background:radial-gradient(circle,#BFE0F5,transparent 70%); animation:drift 18s ease-in-out infinite; }
.blob.b2{ width:460px; height:460px; top:120px; left:-160px; background:radial-gradient(circle,#D9ECF9,transparent 70%); animation:drift 22s ease-in-out infinite reverse; }
.grid-dots{ position:absolute; inset:0; background-image:radial-gradient(var(--tint-3) 1px, transparent 1px); background-size:30px 30px; opacity:.4; -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 30%, #000 30%, transparent 75%); mask-image:radial-gradient(ellipse 80% 60% at 50% 30%, #000 30%, transparent 75%); }

.hero-inner{ position:relative; z-index:2; display:grid; grid-template-columns:1.02fr 1.18fr; gap:54px; align-items:center; }
.hero-copy{ max-width:560px; }
.hero h1{ font-size:clamp(34px,4.6vw,58px); line-height:1.12; font-weight:800; margin:18px 0 0; }
.hero h1 b{ font-weight:inherit; }
.hero h1 .hl{ color:var(--brand-600); }
.hero .sub{ margin-top:22px; }
.hero-actions{ margin-top:34px; display:flex; gap:14px; flex-wrap:wrap; }
.hero-meta{ margin-top:30px; display:flex; gap:26px; flex-wrap:wrap; align-items:center; }
.hero-meta .item{ display:flex; align-items:center; gap:10px; font-size:14.5px; color:var(--muted); font-weight:500; }
.hero-meta .item svg{ width:18px; height:18px; color:var(--green); flex-shrink:0; }
.hero-badge{
  display:inline-flex; align-items:center; gap:9px; padding:7px 14px 7px 8px; border-radius:100px;
  background:#fff; border:1px solid var(--line); box-shadow:var(--sh-sm); font-size:13.5px; font-weight:600; color:var(--navy);
}
.hero-badge .dot{ width:24px; height:24px; border-radius:50%; background:linear-gradient(135deg,var(--brand),var(--brand-600)); color:#fff; display:grid; place-items:center; font-size:12px; }

/* hero entrance — opacity is ALWAYS 1, so content is never blank even if the
   animation/transition clock is frozen (headless capture / play-pending).
   Only transform animates; a frozen frame just shows content slightly offset. */
[data-reveal-hero]{ opacity:1; transform:none; }
.hero-visual{ position:relative; opacity:1; }
.hero-shot{ display:block; width:100%; height:auto; }
@media (prefers-reduced-motion: no-preference){
  .hero.run [data-reveal-hero]:not(.floating-card){ animation:heroRise .7s var(--ease-out) both; }
  .hero.run [data-reveal-hero][data-d="2"]{ animation-delay:.08s; }
  .hero.run [data-reveal-hero][data-d="3"]{ animation-delay:.18s; }
  .hero.run [data-reveal-hero][data-d="4"]{ animation-delay:.28s; }
  .hero.run [data-reveal-hero][data-d="5"]{ animation-delay:.38s; }
  .hero.run .hero-visual{ animation:visualRise 1s var(--ease-out) .2s both; }
}
@keyframes heroRise{ from{ transform:translateY(20px); } to{ transform:translateY(0); } }
@keyframes visualRise{ from{ transform:translateY(34px) scale(.97); } to{ transform:none; } }
@keyframes visualIn{ from{ opacity:0; transform:translateY(40px) scale(.96); } to{ opacity:1; transform:none; } }
.float-wrap{ animation:floaty 7s ease-in-out infinite; }

/* Variant B (centered) */
body.hero-b .hero-inner{ grid-template-columns:1fr; text-align:center; gap:46px; justify-items:center; }
body.hero-b .hero-copy{ max-width:760px; }
body.hero-b .eyebrow{ justify-content:center; }
body.hero-b .hero-actions, body.hero-b .hero-meta{ justify-content:center; }
body.hero-b .hero-visual{ width:100%; max-width:980px; }
body.hero-b .floating-card.fc1{ left:-22px; }
body.hero-b .floating-card.fc3{ right:-22px; }

/* ============================================================
   DASHBOARD MOCKUP
   ============================================================ */
.app-window{
  position:relative; z-index:2; background:#fff; border-radius:18px;
  border:1px solid var(--line); box-shadow:var(--sh-lg);
  overflow:hidden; transform-style:preserve-3d;
}
.aw-bar{ display:flex; align-items:center; gap:8px; padding:12px 16px; border-bottom:1px solid var(--line-2); background:#fff; }
.aw-dots{ display:flex; gap:6px; }
.aw-dots i{ width:11px; height:11px; border-radius:50%; display:block; }
.aw-dots i:nth-child(1){ background:#FF5F57; } .aw-dots i:nth-child(2){ background:#FEBC2E; } .aw-dots i:nth-child(3){ background:#28C840; }
.aw-url{ flex:1; height:26px; border-radius:7px; background:var(--tint); display:flex; align-items:center; gap:7px; padding:0 11px; font-size:12px; color:var(--muted-2); max-width:320px; margin-inline:auto; }
.aw-url svg{ width:13px; height:13px; color:var(--green); }

.app-body{ display:grid; grid-template-columns:172px 1fr; min-height:430px; }
.app-side{ background:linear-gradient(180deg,#0E2F4F,#0C2A47); padding:18px 14px; color:#cfe0ee; }
.side-brand{ display:flex; align-items:center; gap:9px; padding:4px 8px 16px; }
.side-brand .mk{ width:28px; height:28px; border-radius:8px; background:linear-gradient(135deg,var(--brand),var(--brand-600)); display:grid; place-items:center; color:#fff; font-weight:800; font-size:14px; }
.side-brand b{ color:#fff; font-size:14px; letter-spacing:.02em; }
.side-group{ font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:#5e7d99; padding:14px 9px 6px; }
.side-item{ display:flex; align-items:center; gap:10px; padding:9px 10px; border-radius:9px; font-size:13px; color:#b6cadd; margin-bottom:2px; }
.side-item svg{ width:16px; height:16px; opacity:.85; }
.side-item.active{ background:rgba(21,135,195,.22); color:#fff; box-shadow:inset 0 0 0 1px rgba(21,135,195,.4); }
.side-item.active svg{ color:#56b6e6; opacity:1; }

.app-main{ padding:18px 20px; background:linear-gradient(180deg,#FBFDFF,#F4F9FD); overflow:hidden; }
.app-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.app-top h4{ font-size:16px; font-weight:700; color:var(--ink); }
.app-top .sub{ font-size:11.5px; color:var(--muted-2); margin-top:2px; }
.app-search{ display:flex; align-items:center; gap:8px; height:34px; padding:0 12px; border-radius:9px; background:#fff; border:1px solid var(--line); font-size:12px; color:var(--muted-2); min-width:150px; }
.app-search svg{ width:14px; height:14px; }
.app-ava{ width:34px; height:34px; border-radius:50%; background:linear-gradient(135deg,#6FB8E3,#1587C3); display:grid; place-items:center; color:#fff; font-size:12px; font-weight:700; margin-left:10px; }

.stat-row{ display:grid; grid-template-columns:repeat(4,1fr); gap:11px; margin-bottom:14px; }
.stat{ background:#fff; border:1px solid var(--line); border-radius:13px; padding:12px 13px; box-shadow:var(--sh-sm); }
.stat .lab{ font-size:11px; color:var(--muted-2); font-weight:600; display:flex; align-items:center; gap:6px; }
.stat .lab i{ width:7px; height:7px; border-radius:50%; }
.stat .val{ font-family:var(--font-num); font-size:23px; font-weight:800; color:var(--ink); margin-top:5px; letter-spacing:-.02em; }
.stat .chg{ font-size:10.5px; font-weight:700; margin-top:2px; display:flex; align-items:center; gap:3px; }
.stat .chg.up{ color:var(--green); } .stat .chg.down{ color:#E0663E; }

.panel-row{ display:grid; grid-template-columns:1.55fr 1fr; gap:12px; }
.panel{ background:#fff; border:1px solid var(--line); border-radius:13px; padding:13px 14px; box-shadow:var(--sh-sm); }
.panel-h{ display:flex; align-items:center; justify-content:space-between; margin-bottom:11px; }
.panel-h b{ font-size:12.5px; color:var(--ink); font-weight:700; }
.panel-h .more{ font-size:10.5px; color:var(--muted-2); }

/* mini table */
.rec{ display:flex; align-items:center; gap:10px; padding:8px 0; border-top:1px solid var(--line-2); }
.rec:first-of-type{ border-top:none; }
.rec .pic{ width:30px; height:30px; border-radius:8px; flex-shrink:0; display:grid; place-items:center; color:#fff; font-size:11px; font-weight:700; }
.rec .info{ flex:1; min-width:0; }
.rec .nm{ font-size:12px; font-weight:600; color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.rec .meta{ font-size:10.5px; color:var(--muted-2); }
.badge{ font-size:10px; font-weight:700; padding:3px 9px; border-radius:100px; white-space:nowrap; }
.badge.b-green{ background:#E6F6EE; color:#1E8A56; }
.badge.b-amber{ background:#FCF1DC; color:#B47914; }
.badge.b-blue{ background:#E4F1FA; color:var(--brand-700); }
.badge.b-grey{ background:#EEF2F6; color:#697b8a; }

/* bar chart */
.chart{ display:flex; align-items:flex-end; gap:9px; height:120px; padding-top:6px; }
.bar{ flex:1; border-radius:6px 6px 3px 3px; background:linear-gradient(180deg,#9CCDEC,#D7EBF8); position:relative; min-height:8px;
  animation:growBar 1.1s var(--ease-out) both; transform-origin:bottom; }
.bar.hi{ background:linear-gradient(180deg,var(--brand),#56AEDD); }
.chart .axis{ display:flex; gap:9px; }
.chart-wrap .lbls{ display:flex; gap:9px; margin-top:6px; }
.chart-wrap .lbls span{ flex:1; text-align:center; font-size:9.5px; color:var(--muted-2); }
@keyframes growBar{ from{ transform:scaleY(.55); } to{ transform:scaleY(1); } }

/* reminder mini cards */
.rem{ display:flex; gap:9px; align-items:flex-start; padding:9px 0; border-top:1px solid var(--line-2); }
.rem:first-child{ border-top:none; padding-top:2px; }
.rem .ic{ width:26px; height:26px; border-radius:7px; flex-shrink:0; display:grid; place-items:center; }
.rem .ic svg{ width:14px; height:14px; }
.rem .tx b{ display:block; font-size:11.5px; color:var(--ink); font-weight:600; }
.rem .tx span{ font-size:10px; color:var(--muted-2); }

/* floating cards over dashboard */
.floating-card{
  position:absolute; z-index:4; background:#fff; border-radius:14px; padding:13px 15px;
  box-shadow:var(--sh-md); border:1px solid var(--line); display:flex; gap:11px; align-items:center;
}
.floating-card .fi{ width:38px; height:38px; border-radius:11px; display:grid; place-items:center; flex-shrink:0; }
.floating-card .fi svg{ width:20px; height:20px; }
.floating-card .ft b{ display:block; font-size:13px; color:var(--ink); font-weight:700; line-height:1.3; }
.floating-card .ft span{ font-size:11px; color:var(--muted); }
.fc1{ top:8%; left:-40px; animation:floaty 6s ease-in-out infinite; }
.fc2{ bottom:16%; left:-54px; animation:floaty 7.5s ease-in-out infinite .6s; }
.fc3{ top:40%; right:-46px; animation:floaty 6.8s ease-in-out infinite .3s; }
@media(max-width:1180px){ .fc1,.fc2,.fc3{ display:none; } }

@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-13px); } }
@keyframes drift{ 0%,100%{ transform:translate(0,0); } 50%{ transform:translate(26px,30px); } }

/* ============================================================
   SECTION SCAFFOLD
   ============================================================ */
.section{ position:relative; padding:clamp(72px,9vw,128px) 0; }
.section.tint{ background:var(--tint); }
.sec-head{ max-width:680px; margin:0 auto 56px; text-align:center; }
.sec-head .lead{ margin-top:16px; }
.sec-head.left{ margin-inline:0; text-align:left; }

/* reveal on scroll — opacity stays 1 so content is never blank under a frozen
   animation clock; only transform animates (slides up when .in is added). */
[data-reveal]{ opacity:1; transform:translateY(26px); transition:transform .7s var(--ease-out); }
[data-reveal].in{ transform:none; }
[data-reveal][data-d="1"]{ transition-delay:.08s; }
[data-reveal][data-d="2"]{ transition-delay:.16s; }
[data-reveal][data-d="3"]{ transition-delay:.24s; }
[data-reveal][data-d="4"]{ transition-delay:.32s; }
[data-reveal][data-d="5"]{ transition-delay:.4s; }
[data-reveal][data-d="6"]{ transition-delay:.48s; }

/* ============================================================
   PAIN POINTS
   ============================================================ */
.pain-grid{ display:grid; grid-template-columns:1.05fr 1fr; gap:54px; align-items:center; }
.pain-list{ display:flex; flex-direction:column; gap:14px; }
.pain-item{ display:flex; gap:15px; align-items:flex-start; padding:18px 20px; background:#fff; border:1px solid var(--line); border-radius:14px; box-shadow:var(--sh-sm); transition:transform .3s var(--ease), box-shadow .3s; }
.pain-item:hover{ transform:translateX(5px); box-shadow:var(--sh-md); }
.pain-item .x{ width:34px; height:34px; border-radius:10px; background:#FDECEA; color:#D2502E; display:grid; place-items:center; flex-shrink:0; }
.pain-item .x svg{ width:18px; height:18px; }
.pain-item p{ font-size:15.5px; color:var(--ink); font-weight:500; line-height:1.55; }
.pain-visual{ position:relative; }
.chaos{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--sh-md); padding:24px; }
.chaos h5{ font-size:14px; color:var(--muted); font-weight:600; margin-bottom:16px; display:flex; align-items:center; gap:8px; }
.chaos-tags{ display:flex; flex-wrap:wrap; gap:10px; }
.ctag{ display:inline-flex; align-items:center; gap:8px; padding:10px 14px; border-radius:11px; font-size:13px; font-weight:600; background:var(--tint); color:var(--navy); border:1px dashed var(--tint-3); }
.ctag svg{ width:15px; height:15px; color:var(--muted-2); }
.arrow-to{ display:flex; align-items:center; justify-content:center; gap:10px; margin:22px 0; color:var(--brand-600); font-weight:700; font-size:13px; }
.arrow-to .ln{ flex:1; height:2px; background:linear-gradient(90deg,transparent,var(--brand)); border-radius:2px; }
.arrow-to .ln.r{ background:linear-gradient(90deg,var(--brand),transparent); }
.solved{ background:linear-gradient(135deg,var(--brand),var(--brand-600)); border-radius:var(--r-md); padding:18px 20px; color:#fff; display:flex; align-items:center; gap:14px; box-shadow:0 18px 36px -18px var(--brand-glow); }
.solved .ic{ width:44px; height:44px; border-radius:12px; background:rgba(255,255,255,.18); display:grid; place-items:center; flex-shrink:0; }
.solved .ic svg{ width:24px; height:24px; }
.solved b{ display:block; font-size:16px; } .solved span{ font-size:13px; opacity:.9; }

/* ============================================================
   FEATURES GRID
   ============================================================ */
.feat-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.feat-card{
  position:relative; background:#fff; border:1px solid var(--line); border-radius:var(--r-md);
  padding:24px 22px; box-shadow:var(--sh-card); overflow:hidden;
  transition:transform .34s var(--ease), box-shadow .34s, border-color .34s;
}
.feat-card::before{ content:""; position:absolute; left:0; right:0; top:0; height:3px; background:linear-gradient(90deg,var(--brand),var(--brand-600)); transform:scaleX(0); transform-origin:left; transition:transform .4s var(--ease); }
.feat-card:hover{ transform:translateY(-8px); box-shadow:var(--sh-lg); border-color:var(--tint-3); }
.feat-card:hover::before{ transform:scaleX(1); }
.feat-ic{ width:50px; height:50px; border-radius:14px; background:linear-gradient(135deg,var(--tint-2),var(--tint)); color:var(--brand-600); display:grid; place-items:center; margin-bottom:16px; transition:transform .34s var(--ease), background .34s, color .34s; }
.feat-ic svg{ width:25px; height:25px; }
.feat-card:hover .feat-ic{ background:linear-gradient(135deg,var(--brand),var(--brand-600)); color:#fff; transform:scale(1.06) rotate(-4deg); }
.feat-card h3{ font-size:17px; font-weight:700; margin-bottom:7px; }
.feat-card p{ font-size:13.5px; color:var(--muted); line-height:1.6; }
.feat-num{ position:absolute; top:16px; right:18px; font-family:var(--font-num); font-size:13px; font-weight:800; color:var(--tint-3); }

/* ============================================================
   WHATSAPP AUTOMATION
   ============================================================ */
.wa-sect{ background:linear-gradient(160deg,#0C2A47,#0E2F4F 60%,#0B243E); color:#fff; overflow:hidden; position:relative; }
.wa-sect .blob.bw{ width:520px; height:520px; right:-120px; top:40px; background:radial-gradient(circle,rgba(37,211,102,.18),transparent 70%); }
.wa-grid{ display:grid; grid-template-columns:1fr .9fr; gap:60px; align-items:center; position:relative; z-index:2; }
.wa-sect .eyebrow{ color:#6FE0A0; }
.wa-sect .eyebrow::before{ background:#25D366; }
.wa-sect h2{ color:#fff; font-size:clamp(28px,3.4vw,44px); }
.wa-sect .lead{ color:#b9cbdb; margin-top:18px; }
.wa-uses{ display:grid; grid-template-columns:1fr 1fr; gap:11px; margin-top:30px; }
.wa-use{ display:flex; align-items:center; gap:11px; padding:13px 15px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); border-radius:12px; transition:.3s; }
.wa-use:hover{ background:rgba(37,211,102,.12); border-color:rgba(37,211,102,.35); transform:translateY(-3px); }
.wa-use .d{ width:30px; height:30px; border-radius:9px; background:rgba(37,211,102,.18); color:#48E08A; display:grid; place-items:center; flex-shrink:0; }
.wa-use .d svg{ width:16px; height:16px; }
.wa-use span{ font-size:14px; font-weight:600; }

/* phone mockup */
.phone-wrap{ display:flex; justify-content:center; perspective:1400px; }
.phone{ width:300px; background:#0a0f14; border-radius:42px; padding:11px; box-shadow:0 50px 90px -40px rgba(0,0,0,.7), inset 0 0 0 2px #20303d; position:relative; }
.phone .notch{ position:absolute; top:18px; left:50%; transform:translateX(-50%); width:120px; height:26px; background:#0a0f14; border-radius:0 0 16px 16px; z-index:5; }
.phone-screen{ background:#ECE5DD; border-radius:32px; overflow:hidden; height:600px; display:flex; flex-direction:column; }
.wa-head{ background:#075E54; color:#fff; padding:38px 16px 12px; display:flex; align-items:center; gap:11px; }
.wa-head .av{ width:38px; height:38px; border-radius:50%; background:linear-gradient(135deg,var(--brand),var(--brand-600)); display:grid; place-items:center; color:#fff; font-weight:800; font-size:13px; }
.wa-head .nm b{ font-size:14px; display:block; } .wa-head .nm span{ font-size:11px; opacity:.8; }
.wa-head .ed{ margin-left:auto; display:flex; gap:16px; opacity:.9; }
.wa-head .ed svg{ width:18px; height:18px; }
.wa-chat{ flex:1; padding:16px 13px; display:flex; flex-direction:column; gap:9px; overflow:hidden; background-image:linear-gradient(rgba(229,221,213,.6),rgba(229,221,213,.6)); }
.wa-day{ align-self:center; background:#D2E5DC; color:#5a6b62; font-size:10px; font-weight:600; padding:4px 11px; border-radius:7px; margin-bottom:4px; }
.bubble{ max-width:82%; padding:9px 12px; border-radius:9px; font-size:12.5px; line-height:1.5; position:relative; box-shadow:0 1px 1px rgba(0,0,0,.08); }
.bubble.out{ align-self:flex-end; background:#DCF8C6; color:#0c1f14; border-bottom-right-radius:3px; }
.bubble.in{ align-self:flex-start; background:#fff; color:#16222F; border-bottom-left-radius:3px; }
.bubble .tag{ display:inline-block; font-size:9px; font-weight:700; color:var(--brand-600); background:var(--tint-2); padding:1px 7px; border-radius:5px; margin-bottom:5px; }
.bubble .tm{ display:block; text-align:right; font-size:9px; color:#7d8a82; margin-top:3px; }
.bubble .tm.blue svg{ width:14px; color:#34B7F1; vertical-align:middle; }
.wa-input{ background:#F0F0F0; padding:9px 12px; display:flex; align-items:center; gap:9px; }
.wa-input .box{ flex:1; height:34px; background:#fff; border-radius:18px; display:flex; align-items:center; padding:0 13px; font-size:12px; color:#9aa; }
.wa-input .snd{ width:36px; height:36px; border-radius:50%; background:#075E54; display:grid; place-items:center; color:#fff; }
.wa-input .snd svg{ width:16px; }
.bubble{ animation:bubbleIn .5s var(--ease-out) both; }

/* ============================================================
   BENEFITS / STATS
   ============================================================ */
.stat-cards{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-bottom:30px; }
.stat-card{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:28px 24px; box-shadow:var(--sh-card); text-align:center; transition:transform .34s var(--ease), box-shadow .34s; }
.stat-card:hover{ transform:translateY(-6px); box-shadow:var(--sh-lg); }
.stat-card .big{ font-family:var(--font-num); font-size:clamp(34px,4vw,48px); font-weight:800; color:var(--brand-600); letter-spacing:-.03em; line-height:1; }
.stat-card .big .u{ font-size:.5em; color:var(--brand); }
.stat-card .cap{ font-size:14px; color:var(--muted); margin-top:10px; font-weight:500; }
.benefit-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.benefit{ display:flex; gap:14px; align-items:flex-start; padding:20px 22px; background:#fff; border:1px solid var(--line); border-radius:var(--r-md); box-shadow:var(--sh-sm); transition:transform .3s var(--ease), box-shadow .3s; }
.benefit:hover{ transform:translateY(-5px); box-shadow:var(--sh-md); }
.benefit .ck{ width:30px; height:30px; border-radius:9px; background:var(--tint-2); color:var(--brand-600); display:grid; place-items:center; flex-shrink:0; }
.benefit .ck svg{ width:17px; }
.benefit b{ display:block; font-size:15.5px; color:var(--ink); margin-bottom:3px; }
.benefit span{ font-size:13px; color:var(--muted); }

/* ============================================================
   WORKFLOW
   ============================================================ */
.flow{ position:relative; }
.flow-track{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; position:relative; }
.flow-line{ position:absolute; top:36px; left:9%; right:9%; height:2px; background:var(--line); z-index:0; overflow:hidden; }
.flow-line .fill{ position:absolute; inset:0; width:0; background:linear-gradient(90deg,var(--brand),var(--brand-600)); transition:width 1.6s var(--ease); }
.flow.in .flow-line .fill{ width:100%; }
.flow-step{ position:relative; z-index:1; text-align:center; }
.flow-node{ width:72px; height:72px; border-radius:20px; background:#fff; border:1px solid var(--line); box-shadow:var(--sh-md); display:grid; place-items:center; margin:0 auto 18px; color:var(--brand-600); position:relative; transition:transform .4s var(--ease); }
.flow-node svg{ width:30px; height:30px; }
.flow-step:hover .flow-node{ transform:translateY(-6px) scale(1.05); }
.flow-node .n{ position:absolute; top:-8px; right:-8px; width:26px; height:26px; border-radius:50%; background:linear-gradient(135deg,var(--brand),var(--brand-600)); color:#fff; font-family:var(--font-num); font-weight:800; font-size:13px; display:grid; place-items:center; box-shadow:var(--sh-sm); }
.flow-step h4{ font-size:16px; margin-bottom:7px; }
.flow-step p{ font-size:13.5px; color:var(--muted); line-height:1.6; padding-inline:6px; }

/* ============================================================
   TECH / SECURITY
   ============================================================ */
.sec-sect{ background:linear-gradient(165deg,#081E33,#0C2A47); color:#fff; position:relative; overflow:hidden; }
.sec-sect .grid-dots{ opacity:.18; -webkit-mask-image:none; mask-image:none; background-image:radial-gradient(rgba(86,174,221,.25) 1px,transparent 1px); }
.sec-grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:58px; align-items:center; position:relative; z-index:2; }
.sec-sect .eyebrow{ color:#56AEDD; } .sec-sect .eyebrow::before{ background:var(--brand); }
.sec-sect h2{ color:#fff; } .sec-sect .lead{ color:#aec3d5; margin-top:18px; }
.sec-points{ display:flex; flex-direction:column; gap:13px; margin-top:30px; }
.sec-pt{ display:flex; gap:13px; align-items:flex-start; }
.sec-pt .ck{ width:26px; height:26px; border-radius:8px; background:rgba(21,135,195,.2); color:#56AEDD; display:grid; place-items:center; flex-shrink:0; margin-top:1px; }
.sec-pt .ck svg{ width:15px; }
.sec-pt p{ font-size:15px; color:#cdddea; } .sec-pt p b{ color:#fff; font-weight:600; }
.infra{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.infra-card{ background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1); border-radius:var(--r-md); padding:22px; transition:.34s; backdrop-filter:blur(6px); display:flex; align-items:center; gap:16px; }
.infra-card:hover{ background:rgba(21,135,195,.12); border-color:rgba(86,174,221,.4); transform:translateY(-6px); }
.infra-card .lg{ width:48px; height:48px; flex-shrink:0; aspect-ratio:1; border-radius:13px; background:#fff; display:grid; place-items:center; box-shadow:var(--sh-md); }
.infra-card .lg svg{ width:26px; height:26px; }
.infra-card b{ display:block; font-size:16px; color:#fff; margin-bottom:5px; }
.infra-card span{ font-size:12.5px; color:#9fb6c8; line-height:1.55; }
.infra-card.wide{ grid-column:1/-1; }
.infra-card.wide .lg{ align-self:center; }

/* ============================================================
   WHY AGENTPRO
   ============================================================ */
.why-grid{ display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
.why-list{ display:flex; flex-direction:column; gap:4px; }
.why-item{ display:flex; gap:16px; padding:20px 4px; border-bottom:1px solid var(--line); }
.why-item:last-child{ border-bottom:none; }
.why-item .no{ font-family:var(--font-num); font-size:15px; font-weight:800; color:var(--brand); width:34px; flex-shrink:0; }
.why-item .tx b{ display:block; font-size:17px; color:var(--ink); margin-bottom:4px; }
.why-item .tx p{ font-size:14px; color:var(--muted); }
.why-card{ background:linear-gradient(150deg,var(--brand),var(--brand-700)); border-radius:var(--r-lg); padding:40px 36px; color:#fff; box-shadow:0 30px 60px -28px var(--brand-glow); position:relative; overflow:hidden; }
.why-card::after{ content:""; position:absolute; width:280px; height:280px; border-radius:50%; background:rgba(255,255,255,.08); top:-90px; right:-90px; }
.why-card .qm{ font-family:Georgia,serif; font-size:72px; line-height:.6; opacity:.4; }
.why-card .stmt{ font-size:22px; font-weight:700; line-height:1.5; margin:14px 0 24px; position:relative; }
.why-card .stmt em{ font-style:normal; background:rgba(255,255,255,.22); padding:0 6px; border-radius:5px; }
.why-card .vs{ display:flex; align-items:center; gap:14px; position:relative; }
.why-card .vs .a{ font-size:13px; opacity:.7; text-decoration:line-through; }
.why-card .vs .b{ font-size:15px; font-weight:700; padding:7px 14px; background:#fff; color:var(--brand-700); border-radius:10px; }

/* ============================================================
   DEMO FORM
   ============================================================ */
.demo-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:56px; align-items:stretch; }
.demo-left h2{ font-size:clamp(28px,3.2vw,40px); }
.demo-left .lead{ margin-top:16px; }
.demo-perks{ margin-top:28px; display:flex; flex-direction:column; gap:14px; }
.demo-perk{ display:flex; gap:12px; align-items:center; font-size:15px; color:var(--ink); font-weight:500; }
.demo-perk .ck{ width:28px; height:28px; border-radius:8px; background:var(--tint-2); color:var(--brand-600); display:grid; place-items:center; flex-shrink:0; }
.demo-perk .ck svg{ width:16px; }
.demo-contact{ margin-top:30px; padding:20px 22px; background:var(--tint); border:1px solid var(--tint-3); border-radius:var(--r-md); }
.demo-contact .lab{ font-size:12.5px; color:var(--muted); font-weight:600; }
.demo-contact .row{ display:flex; align-items:center; gap:13px; margin-top:11px; flex-wrap:wrap; }
.demo-contact .ph{ display:flex; align-items:center; gap:9px; font-family:var(--font-num); font-size:20px; font-weight:800; color:var(--navy); white-space:nowrap; }
.demo-contact .ph svg{ width:20px; color:var(--brand); }

.form-card{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:34px; box-shadow:var(--sh-md); position:relative; }
.field{ margin-bottom:17px; }
.field label{ display:block; font-size:13.5px; font-weight:600; color:var(--navy); margin-bottom:7px; }
.field label .req{ color:#E0663E; }
.field .ctrl{ position:relative; }
.field input,.field textarea{
  width:100%; font-family:inherit; font-size:15px; color:var(--ink);
  padding:13px 15px; border:1.5px solid var(--line); border-radius:11px; background:var(--bg);
  transition:border-color .25s, box-shadow .25s, background .25s;
}
.field textarea{ resize:vertical; min-height:96px; }
.field input::placeholder,.field textarea::placeholder{ color:var(--muted-2); }
.field input:focus,.field textarea:focus{ outline:none; border-color:var(--brand); background:#fff; box-shadow:0 0 0 4px var(--brand-glow); }
.field.error input,.field.error textarea{ border-color:#E0663E; box-shadow:0 0 0 4px rgba(224,102,62,.14); }
.field .err{ font-size:12px; color:#D2502E; margin-top:6px; display:none; align-items:center; gap:5px; }
.field.error .err{ display:flex; }
.field .err svg{ width:13px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.recaptcha-field{ display:flex; justify-content:flex-start; }
.recaptcha-field .g-recaptcha{ transform-origin:left top; }
@media(max-width:380px){ .recaptcha-field .g-recaptcha{ transform:scale(.86); } }
.form-submit{ width:100%; margin-top:6px; }
.form-foot{ text-align:center; font-size:12px; color:var(--muted-2); margin-top:14px; }
.form-success{
  position:absolute; inset:0; background:#fff; border-radius:var(--r-lg); display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center; padding:40px; gap:8px;
  opacity:0; pointer-events:none; transform:scale(.97); transition:.4s var(--ease);
}
.form-success.show{ opacity:1; pointer-events:auto; transform:none; }
.form-success .tick{ width:74px; height:74px; border-radius:50%; background:linear-gradient(135deg,#2BA66B,#1E8A56); display:grid; place-items:center; color:#fff; margin-bottom:12px; box-shadow:0 16px 30px -14px rgba(43,166,107,.6); animation:pop .5s var(--ease-out); }
.form-success .tick svg{ width:38px; }
.form-success h3{ font-size:22px; } .form-success p{ font-size:14.5px; color:var(--muted); max-width:300px; }
@keyframes pop{ 0%{ transform:scale(0); } 60%{ transform:scale(1.12); } 100%{ transform:scale(1); } }

/* ============================================================
   FINAL CTA
   ============================================================ */
.final{ position:relative; padding:clamp(70px,8vw,110px) 0; overflow:hidden; }
.final-box{ position:relative; background:linear-gradient(135deg,var(--brand-600),var(--navy) 120%); border-radius:30px; padding:clamp(40px,6vw,72px); text-align:center; overflow:hidden; box-shadow:var(--sh-lg); }
.final-box .blob{ filter:blur(70px); }
.final-box .glow{ position:absolute; width:500px; height:500px; border-radius:50%; background:radial-gradient(circle,rgba(86,174,221,.4),transparent 70%); top:-200px; left:50%; transform:translateX(-50%); }
.final-box .rings{ position:absolute; inset:0; background:
  radial-gradient(circle at 50% 50%, transparent 30%, rgba(255,255,255,.04) 30.5%, transparent 31%),
  radial-gradient(circle at 50% 50%, transparent 45%, rgba(255,255,255,.04) 45.5%, transparent 46%); }
.final-box .inner{ position:relative; z-index:2; }
.final-box h2{ color:#fff; font-size:clamp(28px,3.6vw,46px); }
.final-box p{ color:#cfe0ee; font-size:clamp(16px,1.4vw,19px); max-width:620px; margin:18px auto 0; line-height:1.7; }
.final-box .acts{ margin-top:34px; display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--navy-900); color:#9fb6c8; padding:72px 0 30px; }
.foot-top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:40px; padding-bottom:44px; border-bottom:1px solid rgba(255,255,255,.08); }
.foot-logo{ height:30px; margin-bottom:18px; }
.foot-about{ font-size:14px; line-height:1.7; max-width:300px; color:#8ba4b8; }
.foot-col h5{ color:#fff; font-size:14px; font-weight:700; margin-bottom:16px; letter-spacing:.02em; }
.foot-col a{ display:block; font-size:14px; padding:6px 0; color:#9fb6c8; transition:color .2s, padding .2s; }
.foot-col a:hover{ color:var(--brand); padding-left:4px; }
.foot-contact .ci{ display:flex; gap:11px; align-items:flex-start; margin-bottom:14px; font-size:14px; }
.foot-contact .ci svg{ width:18px; color:var(--brand); flex-shrink:0; margin-top:2px; }
.foot-wa{ display:inline-flex; align-items:center; gap:9px; margin-top:6px; padding:11px 18px; background:linear-gradient(135deg,#2BD96E,#16B257); color:#fff; border-radius:11px; font-weight:700; font-size:14px; transition:transform .25s; }
.foot-wa:hover{ transform:translateY(-3px); }
.foot-bottom{ display:flex; justify-content:space-between; align-items:center; padding-top:26px; font-size:13px; color:#6a8499; flex-wrap:wrap; gap:12px; }
.foot-bottom a{ color:#6a8499; } .foot-bottom a:hover{ color:var(--brand); }

/* ============================================================
   FLOATING WHATSAPP
   ============================================================ */
.fab{ position:fixed; right:24px; bottom:24px; z-index:80; display:flex; align-items:center; gap:0; }
.fab-btn{ width:60px; height:60px; border-radius:50%; background:linear-gradient(135deg,#2BD96E,#16B257); display:grid; place-items:center; color:#fff; box-shadow:0 14px 30px -10px rgba(37,211,102,.65); position:relative; transition:transform .3s var(--ease); animation:fabBob 3.5s ease-in-out infinite; }
.fab-btn svg{ width:32px; height:32px; }
.fab-btn::before, .fab-btn::after{ content:""; position:absolute; inset:0; border-radius:50%; border:2px solid rgba(37,211,102,.5); animation:ring 2.6s ease-out infinite; }
.fab-btn::after{ animation-delay:1.3s; }
.fab-btn:hover{ transform:scale(1.08); }
.fab-label{ position:absolute; right:72px; white-space:nowrap; background:#fff; color:var(--navy); font-size:14px; font-weight:600; padding:9px 15px; border-radius:11px; box-shadow:var(--sh-md); opacity:0; transform:translateX(8px); pointer-events:none; transition:.3s; }
.fab-label::after{ content:""; position:absolute; right:-6px; top:50%; transform:translateY(-50%) rotate(45deg); width:12px; height:12px; background:#fff; }
.fab:hover .fab-label{ opacity:1; transform:none; }
@keyframes fabBob{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-7px); } }
@keyframes ring{ 0%{ transform:scale(1); opacity:.7; } 100%{ transform:scale(1.7); opacity:0; } }
@keyframes bubbleIn{ from{ transform:translateY(10px); } to{ transform:translateY(0); } }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1120px){ .nav-phone{ display:none; } }
@media(max-width:1080px){
  .feat-grid{ grid-template-columns:repeat(2,1fr); }
  .stat-cards{ grid-template-columns:repeat(2,1fr); }
  .benefit-grid{ grid-template-columns:1fr 1fr; }
  .infra{ grid-template-columns:1fr 1fr; }
}
@media(max-width:920px){
  .nav-menu, .nav-phone{ display:none; }
  .hamburger{ display:flex; }
  .hero-inner{ grid-template-columns:1fr; text-align:center; gap:44px; justify-items:center; }
  .hero .eyebrow{ justify-content:center; }
  .hero-actions, .hero-meta{ justify-content:center; }
  .hero-copy{ max-width:640px; }
  .hero-visual{ width:100%; max-width:560px; }
  .pain-grid, .wa-grid, .sec-grid, .why-grid, .demo-grid{ grid-template-columns:1fr; gap:42px; }
  .flow-track{ grid-template-columns:1fr 1fr; gap:36px 22px; }
  .flow-line{ display:none; }
  .wa-uses{ max-width:560px; }
}
@media(max-width:560px){
  .nav-cta{ display:none; }
  .nav-inner{ justify-content:space-between; }
}
@media(max-width:640px){
  .container{ padding-inline:18px; }
  .feat-grid{ grid-template-columns:1fr; }
  .stat-cards, .benefit-grid, .infra, .wa-uses, .form-row{ grid-template-columns:1fr; }
  .flow-track{ grid-template-columns:1fr; }
  .hero{ padding-top:120px; }
  .hero h1{ font-size:clamp(30px,8vw,40px); }
  .hero-badge{ max-width:100%; }
  .hero-meta{ gap:12px 20px; }
  .btn{ width:100%; }
  .nav .btn{ width:auto; }
  .hero-actions, .final-box .acts{ width:100%; }
  .app-body{ grid-template-columns:1fr; }
  .app-side{ display:none; }
  .app-search{ display:none; }
  .app-main{ padding:16px 15px; }
  .stat-row{ grid-template-columns:1fr 1fr; }
  .panel-row{ grid-template-columns:1fr; }
  .form-card{ padding:24px 20px; }
  .why-card{ padding:30px 26px; }
  .why-card .stmt{ font-size:19px; }
  .foot-top{ grid-template-columns:1fr 1fr; gap:32px; }
  .sec-head{ margin-bottom:40px; }
  .chaos-tags{ flex-direction:column; }
  .ctag{ width:100%; justify-content:center; }
}
@media(max-width:380px){
  .stat-row{ grid-template-columns:1fr; }
  .foot-top{ grid-template-columns:1fr; gap:26px; }
  .demo-contact .row{ gap:12px; }
}

/* Tweaks: ambient motion off */
body.motion-off .float-wrap,
body.motion-off .floating-card,
body.motion-off .blob,
body.motion-off .fab-btn{ animation:none !important; }
body.motion-off .fab-btn::before,
body.motion-off .fab-btn::after{ animation:none !important; opacity:0; }

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
  [data-reveal],[data-reveal-hero]{ opacity:1 !important; transform:none !important; }
}
