/* ============================================================
   SYNERGENTIC.AI — WEBSITE STYLES
   Premium Violet Alloy · 90 / 8 / 2 restraint
   ============================================================ */
:root{
  /* Foundation */
  --obsidian:#050711; --obsidian-2:#070510; --obsidian-3:#0A1024;
  --surface-base:#050711; --surface-raised:#090D18; --surface-elev:#0D1220; --surface-input:#0B0F1A;
  /* Borders */
  --border-subtle:#1A2030; --border-strong:#232B40; --border-active:#6D35FF;
  /* Text */
  --text-primary:#E8EAF0; --text-secondary:#A7ADBA; --text-muted:#6F7480; --text-disabled:#404652;
  /* Brand */
  --royal-violet:#6D35FF; --electric-orchid:#C13BFF; --deep-indigo:#3215D9;
  --orchid-magenta:#D14BFF; --signal-blue:#2B59FF; --platinum:#E8EAF0; --gunmetal:#6F7480;
  --emerald:#36D399;
  /* Gradients */
  --grad-mark:linear-gradient(135deg,#E24BFF 0%,#A23BF7 42%,#6D35FF 72%,#3215D9 100%);
  --grad-cta:linear-gradient(180deg,#6D35FF 0%,#3215D9 100%);
  --grad-cta-hot:linear-gradient(180deg,#C13BFF 0%,#6D35FF 100%);
  --grad-energy:linear-gradient(135deg,#D14BFF 0%,#5D2CFF 50%,#2B59FF 100%);
  --grad-text:linear-gradient(90deg,#C13BFF 0%,#6D35FF 100%);
  --grad-platinum:linear-gradient(180deg,#FFFFFF 0%,#E8EAF0 40%,#9DA3B0 70%,#F2F4FA 100%);
  --grad-bg:radial-gradient(1200px 700px at 8% -8%,rgba(109,53,255,0.10),transparent 60%),
            radial-gradient(900px 600px at 100% 12%,rgba(193,59,255,0.06),transparent 60%),
            linear-gradient(180deg,#050711 0%,#070510 55%,#0A1024 100%);
  /* Type */
  --font-display:"Geist","Helvetica Neue",Helvetica,Arial,sans-serif;
  --font-body:"Geist","Helvetica Neue",Helvetica,Arial,sans-serif;
  --font-mono:"Geist Mono",ui-monospace,"JetBrains Mono",monospace;
  /* Radius / shadow */
  --r-sm:6px; --r-md:10px; --r-lg:16px; --r-xl:22px;
  --shadow-card:0 1px 0 rgba(255,255,255,0.03) inset,0 20px 60px -30px rgba(0,0,0,0.8);
  --shadow-violet:0 20px 60px -20px rgba(109,53,255,0.45);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
html,body{ margin:0; padding:0; }
body{
  font-family:var(--font-body);
  background:var(--surface-base);
  background-image:var(--grad-bg);
  background-attachment:fixed;
  color:var(--text-secondary);
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"ss01","cv11";
  letter-spacing:-0.005em;
  line-height:1.5;
}
::selection{ background:rgba(193,59,255,0.35); color:#fff; }
a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }
h1,h2,h3,h4,h5{ color:var(--text-primary); font-family:var(--font-display); margin:0; letter-spacing:-0.02em; }

.shell{ max-width:1200px; margin:0 auto; padding:0 32px; }
.eyebrow{ font-family:var(--font-mono); font-size:11px; letter-spacing:0.22em; color:var(--text-muted); text-transform:uppercase; }
.grad-text{ background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent; }
.platinum-text{ background:var(--grad-platinum); -webkit-background-clip:text; background-clip:text; color:transparent; }

.skip-link{ position:absolute; left:-999px; top:0; background:var(--royal-violet); color:#fff; padding:10px 16px; border-radius:0 0 var(--r-md) 0; z-index:200; }
.skip-link:focus{ left:0; }

/* ---- buttons ---- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  padding:13px 22px; border-radius:999px;
  font-family:var(--font-display); font-size:14px; font-weight:500; letter-spacing:0.01em; line-height:1;
  border:1px solid transparent; cursor:pointer; color:#fff;
  transition:transform .15s ease,box-shadow .2s ease,border-color .2s ease,background .2s ease;
}
.btn:hover{ transform:translateY(-1px); }
.btn-primary{ background:var(--grad-cta-hot); border:none; background-clip:padding-box; box-shadow:0 8px 24px -14px rgba(141,58,233,0.7); }
.btn-primary:hover{ background:var(--grad-cta-hot); box-shadow:0 14px 34px -14px rgba(141,58,233,0.78); }
.btn-secondary{ background:var(--surface-elev); color:var(--text-primary); border-color:rgba(111,116,128,0.3); }
.btn-secondary:hover{ border-color:var(--royal-violet); }
.btn-ghost{ background:transparent; color:var(--text-primary); border-color:transparent; padding-left:6px; padding-right:6px; }
.btn-ghost:hover{ color:var(--electric-orchid); }
.btn .arrow{ width:14px; height:14px; }
.btn-lg{ padding:16px 28px; font-size:15px; }

/* ---- announcement bar ---- */
.announce{
  display:flex; align-items:center; justify-content:center; gap:10px;
  padding:9px 20px; font-family:var(--font-mono); font-size:11px; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--text-secondary); text-align:center; white-space:nowrap;
  background:linear-gradient(90deg,rgba(109,53,255,0.10),rgba(193,59,255,0.08),rgba(43,89,255,0.10));
  border-bottom:1px solid var(--border-subtle); position:relative; z-index:60;
}
.announce > span:last-child{ min-width:0; }
@media (max-width:560px){ .announce .a-link{ display:none; } }
.announce .pulse{ width:6px; height:6px; border-radius:50%; background:var(--emerald); box-shadow:0 0 12px var(--emerald); }
.announce a{ color:var(--text-primary); border-bottom:1px solid rgba(193,59,255,0.4); padding-bottom:1px; }
.announce a:hover{ color:var(--electric-orchid); }

/* ---- nav ---- */
.topbar{ position:sticky; top:0; z-index:50; backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  background:rgba(5,7,17,0.72); border-bottom:1px solid var(--border-subtle); }
.topbar-inner{ display:flex; align-items:center; justify-content:space-between; height:72px; }
.brand{ display:flex; align-items:center; gap:12px; }
.brand .mark{ width:34px; height:34px; }
.brand .wm{ height:21px; width:auto; }
.nav{ display:flex; gap:22px; }
.nav a{ color:var(--text-secondary); font-size:13px; white-space:nowrap; transition:color .15s ease; }
.nav a:hover{ color:var(--text-primary); }
.nav-cta{ display:flex; align-items:center; gap:8px; }
.nav-cta .btn{ padding:8px 15px; font-size:12.5px; }
.nav-link-ghost{ font-size:12.5px; color:var(--text-secondary); white-space:nowrap; }
.nav-link-ghost:hover{ color:var(--text-primary); }
.menu-toggle{ display:none; background:none; border:1px solid var(--border-subtle); border-radius:var(--r-sm); padding:8px; cursor:pointer; }
.menu-toggle svg{ width:20px; height:20px; color:var(--text-primary); }

/* ---- language switch (EN / ES) ---- */
.lang-switch{ display:inline-flex; align-items:center; gap:1px; padding:2px; border-radius:999px;
  border:1px solid var(--border-subtle); background:rgba(13,18,32,0.55); }
.ls-btn{ font-family:var(--font-mono); font-size:10.5px; letter-spacing:0.06em; font-weight:500;
  color:var(--text-muted); background:none; border:none; cursor:pointer; padding:4px 8px; border-radius:999px;
  transition:color .15s ease, background .2s ease; }
.ls-btn:hover{ color:var(--text-secondary); }
.ls-btn.active{ color:#fff; background:var(--grad-cta-hot); }
/* attention shimmer — runs once on page load for 10s */
@keyframes langShimmer{
  0%,100%{ border-color:var(--border-subtle); box-shadow:none; }
  12%{ border-color:rgba(193,59,255,0.7); box-shadow:0 0 12px rgba(193,59,255,0.35); }
  24%{ border-color:var(--border-subtle); box-shadow:none; }
  36%{ border-color:rgba(109,53,255,0.7); box-shadow:0 0 12px rgba(109,53,255,0.35); }
  48%{ border-color:var(--border-subtle); box-shadow:none; }
}
.topbar .lang-switch{ animation:langShimmer 2.5s ease 4; }
.mm-lang{ margin-top:22px; align-self:flex-start; }
.mm-lang .ls-btn{ font-size:13px; padding:9px 16px; }

/* ---- hero ---- */
.hero{ position:relative; overflow:hidden; padding:84px 0 72px; border-bottom:1px solid var(--border-subtle); }
.hero::before{ content:""; position:absolute; left:50%; top:-30%; width:1000px; height:1000px; transform:translateX(-50%);
  background:radial-gradient(closest-side,rgba(109,53,255,0.16),transparent 70%); pointer-events:none; }
.hero::after{ content:""; position:absolute; right:-12%; top:6%; width:620px; height:620px;
  background:radial-gradient(closest-side,rgba(193,59,255,0.12),transparent 70%); pointer-events:none; }
.hero-grid{ display:grid; grid-template-columns:1.05fr 0.95fr; gap:60px; align-items:center; position:relative; z-index:1; }
.hero-pill{ display:inline-flex; align-items:center; gap:10px; padding:7px 15px; border-radius:999px;
  border:1px solid var(--border-subtle); background:rgba(13,18,32,0.6);
  font-family:var(--font-mono); font-size:11px; letter-spacing:0.14em; color:var(--text-secondary); text-transform:uppercase; }
.hero-pill .pulse{ width:6px; height:6px; border-radius:50%; background:var(--electric-orchid); box-shadow:0 0 14px var(--electric-orchid); }
.hero h1{ font-size:clamp(40px,5.6vw,72px); font-weight:600; line-height:0.98; letter-spacing:-0.035em; margin:22px 0 0; }
.hero h1 .grad{ background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero .lede{ font-size:18px; line-height:1.55; max-width:520px; margin:22px 0 0; color:var(--text-secondary); }
.hero-actions{ display:flex; gap:12px; margin-top:30px; flex-wrap:wrap; }
.hero-leadform{ margin-top:26px; }
.hero-leadform .lf-row{ display:flex; gap:10px; max-width:480px; }
.hero-leadform input{ flex:1; background:var(--surface-input); border:1px solid var(--border-subtle); color:var(--text-primary);
  padding:14px 16px; border-radius:999px; font-family:var(--font-body); font-size:14px; outline:none; transition:border-color .15s ease,box-shadow .15s ease; }
.hero-leadform input:focus{ border-color:var(--royal-violet); box-shadow:0 0 0 3px rgba(109,53,255,0.18); }
.hero-leadform .lf-note{ font-family:var(--font-mono); font-size:10.5px; letter-spacing:0.08em; color:var(--text-muted); margin-top:12px; display:flex; align-items:center; gap:8px; }
.hero-leadform .lf-note::before{ content:""; width:5px; height:5px; border-radius:50%; background:var(--emerald); box-shadow:0 0 10px var(--emerald); }
.hero-meta{ display:flex; gap:30px; margin-top:34px; padding-top:26px; border-top:1px solid var(--border-subtle);
  font-family:var(--font-mono); font-size:11px; letter-spacing:0.04em; color:var(--text-muted); }
.hero-meta .v{ font-size:24px; color:var(--text-primary); font-weight:600; letter-spacing:-0.02em; display:block; margin-bottom:4px; font-family:var(--font-display); }
.hero-meta .v.grad{ background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent; }

/* hero product card */
.hero-visual{ position:relative; }
.glass-card{ background:linear-gradient(180deg,rgba(13,18,32,0.85),rgba(9,13,24,0.85)); border:1px solid var(--border-subtle);
  border-radius:var(--r-xl); box-shadow:var(--shadow-card); overflow:hidden; }
.gc-head{ display:flex; align-items:center; gap:10px; padding:14px 18px; border-bottom:1px solid var(--border-subtle); background:rgba(13,18,32,0.6); }
.gc-head .dots{ display:flex; gap:6px; }
.gc-head .dots i{ width:9px; height:9px; border-radius:50%; background:#1A2030; display:block; }
.gc-head .title{ font-family:var(--font-mono); font-size:11px; color:var(--text-muted); letter-spacing:0.08em; }
.gc-head .live{ margin-left:auto; font-family:var(--font-mono); font-size:10px; letter-spacing:0.12em; text-transform:uppercase; color:var(--emerald);
  display:inline-flex; align-items:center; gap:6px; }
.gc-head .live::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--emerald); box-shadow:0 0 10px var(--emerald); }
.gc-body{ padding:18px; display:flex; flex-direction:column; gap:10px; }
.agent-row{ display:grid; grid-template-columns:10px 1fr auto auto; gap:14px; align-items:center; padding:13px 14px; border-radius:var(--r-md);
  background:var(--surface-input); border:1px solid var(--border-subtle); }
.agent-row .dot{ width:9px; height:9px; border-radius:50%; background:var(--emerald); box-shadow:0 0 12px var(--emerald); }
.agent-row .dot.idle{ background:var(--text-muted); box-shadow:none; }
.agent-row .dot.alert{ background:var(--electric-orchid); box-shadow:0 0 12px var(--electric-orchid); }
.agent-row .nm{ font-size:13.5px; color:var(--text-primary); font-weight:500; }
.agent-row .sub{ font-family:var(--font-mono); font-size:10px; color:var(--text-muted); letter-spacing:0.04em; margin-top:3px; }
.agent-row .val{ font-family:var(--font-mono); font-size:12px; color:var(--text-secondary); }
.agent-row .pill{ font-family:var(--font-mono); font-size:9.5px; padding:4px 9px; border-radius:999px; letter-spacing:0.06em; text-transform:uppercase; }
.pill.live{ background:rgba(54,211,153,0.12); color:var(--emerald); border:1px solid rgba(54,211,153,0.3); }
.pill.idle{ background:rgba(111,116,128,0.12); color:var(--text-muted); border:1px solid var(--border-subtle); }
.pill.alert{ background:rgba(193,59,255,0.12); color:var(--electric-orchid); border:1px solid rgba(193,59,255,0.3); }
.gc-foot{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--border-subtle); border-top:1px solid var(--border-subtle); }
.gc-foot .cell{ background:var(--surface-raised); padding:16px 18px; }
.gc-foot .cell .k{ font-family:var(--font-mono); font-size:9.5px; letter-spacing:0.12em; text-transform:uppercase; color:var(--text-muted); }
.gc-foot .cell .n{ font-size:20px; color:var(--text-primary); font-weight:600; margin-top:6px; letter-spacing:-0.02em; }
.gc-foot .cell .n.grad{ background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent; }

/* ---- logo cloud ---- */
.cloud{ padding:44px 0; border-bottom:1px solid var(--border-subtle); }
.cloud .lbl{ text-align:center; font-family:var(--font-mono); font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:var(--text-muted); margin-bottom:26px; }
.cloud .logos{ display:flex; align-items:center; justify-content:center; gap:clamp(28px,5vw,64px); flex-wrap:wrap; }
.cloud .logos span{ font-family:var(--font-display); font-weight:600; font-size:18px; letter-spacing:0.02em; color:var(--text-secondary); opacity:0.62; transition:opacity .2s ease; }
.cloud .logos span:hover{ opacity:1; }

/* ---- section scaffolding ---- */
section.block{ padding:96px 0; border-bottom:1px solid var(--border-subtle); position:relative; }
.sec-head{ max-width:720px; margin:0 auto 56px; text-align:center; }
.sec-head.left{ margin-left:0; text-align:left; }
.sec-head .tag{ font-family:var(--font-mono); font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:var(--electric-orchid); display:inline-flex; align-items:center; gap:9px; }
.sec-head .tag::before{ content:""; width:6px; height:6px; background:var(--royal-violet); display:inline-block; }
.sec-head h2{ font-size:clamp(30px,4vw,46px); font-weight:600; line-height:1.05; letter-spacing:-0.025em; margin:16px 0 0; }
.sec-head p{ font-size:17px; line-height:1.55; color:var(--text-secondary); margin:16px auto 0; max-width:620px; }
.sec-head.left p{ margin-left:0; }

/* ---- features ---- */
.feat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.feat{ background:var(--surface-raised); border:1px solid var(--border-subtle); border-radius:var(--r-lg); padding:30px; position:relative; overflow:hidden; transition:border-color .2s ease,transform .2s ease; }
.feat:hover{ border-color:rgba(109,53,255,0.45); transform:translateY(-2px); }
.feat .ico{ width:46px; height:46px; border-radius:var(--r-md); background:linear-gradient(180deg,rgba(193,59,255,0.18),rgba(109,53,255,0.08)); border:1px solid rgba(193,59,255,0.2); display:grid; place-items:center; margin-bottom:22px; color:var(--electric-orchid); }
.feat .ico svg{ width:22px; height:22px; }
.feat h3{ font-size:19px; font-weight:600; margin:0 0 8px; letter-spacing:-0.01em; }
.feat p{ font-size:14px; line-height:1.55; color:var(--text-secondary); margin:0; }
.feat .index{ position:absolute; top:22px; right:24px; font-family:var(--font-mono); font-size:11px; color:var(--text-muted); }

/* ---- process / steps ---- */
.steps{ display:grid; grid-template-columns:repeat(5,1fr); gap:14px; counter-reset:step; }
.step{ background:var(--surface-raised); border:1px solid var(--border-subtle); border-radius:var(--r-lg); padding:26px 22px; position:relative; }
.step .num{ font-family:var(--font-mono); font-size:12px; color:var(--electric-orchid); letter-spacing:0.1em; }
.step h3{ font-size:17px; font-weight:600; margin:16px 0 8px; }
.step p{ font-size:13px; line-height:1.5; color:var(--text-secondary); margin:0; }
.step:not(:last-child)::after{ content:"→"; position:absolute; right:-11px; top:30px; color:var(--text-muted); font-family:var(--font-mono); z-index:2; }

/* ---- pricing / solutions ---- */
.pricing{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; align-items:stretch; }
.price{ background:var(--surface-raised); border:1px solid var(--border-subtle); border-radius:var(--r-lg); padding:28px; display:flex; flex-direction:column; }
.price.featured{ border-color:rgba(193,59,255,0.4); background:radial-gradient(700px 200px at 50% 0%,rgba(193,59,255,0.12),transparent 60%),var(--surface-raised); box-shadow:0 30px 80px -40px rgba(109,53,255,0.6); position:relative; }
.price.featured::before{ content:"Most chosen"; position:absolute; top:-12px; left:50%; transform:translateX(-50%); font-family:var(--font-mono); font-size:10px; letter-spacing:0.16em; text-transform:uppercase; background:var(--grad-mark); color:#fff; padding:6px 12px; border-radius:999px; white-space:nowrap; }
.price .nm{ font-family:var(--font-mono); font-size:11px; letter-spacing:0.16em; color:var(--text-muted); text-transform:uppercase; }
.price .amt{ font-size:34px; font-weight:600; color:var(--text-primary); margin:16px 0 4px; letter-spacing:-0.02em; }
.price .amt .per{ font-size:13px; color:var(--text-muted); font-weight:400; letter-spacing:0; }
.price .sum{ font-size:13.5px; color:var(--text-secondary); margin:0 0 22px; line-height:1.5; }
.price ul{ list-style:none; padding:0; margin:0 0 24px; display:flex; flex-direction:column; gap:11px; flex:1; }
.price li{ font-size:13px; color:var(--text-secondary); display:flex; gap:10px; align-items:flex-start; line-height:1.45; }
.price li::before{ content:""; width:6px; height:6px; background:var(--royal-violet); border-radius:2px; margin-top:6px; flex:0 0 6px; }
.price.featured li::before{ background:var(--electric-orchid); }
.price .btn{ width:100%; }

/* ---- proof / testimonial ---- */
.proof-grid{ display:grid; grid-template-columns:1.5fr 1fr; gap:18px; }
.testimonial{ background:var(--surface-raised); border:1px solid var(--border-subtle); border-radius:var(--r-lg); padding:40px; display:flex; flex-direction:column; justify-content:space-between; }
.testimonial blockquote{ margin:0; font-family:var(--font-display); font-size:24px; line-height:1.4; color:var(--text-primary); font-weight:500; letter-spacing:-0.01em; }
.testimonial.compact blockquote{ font-size:18px; }
.testimonial .who{ margin-top:28px; display:flex; align-items:center; gap:14px; }
.testimonial .avatar{ width:42px; height:42px; border-radius:50%; background:linear-gradient(135deg,#2a2740,#0f1224); border:1px solid var(--border-subtle); display:grid; place-items:center; font-family:var(--font-mono); color:var(--text-primary); font-size:13px; }
.testimonial .who .name{ font-size:14px; color:var(--text-primary); }
.testimonial .who .role{ font-family:var(--font-mono); font-size:11px; letter-spacing:0.08em; color:var(--text-muted); text-transform:uppercase; margin-top:3px; }

/* ---- FAQ ---- */
.faq{ max-width:820px; margin:0 auto; display:flex; flex-direction:column; gap:12px; }
.faq details{ background:var(--surface-raised); border:1px solid var(--border-subtle); border-radius:var(--r-md); overflow:hidden; }
.faq details[open]{ border-color:rgba(109,53,255,0.4); }
.faq summary{ list-style:none; cursor:pointer; padding:22px 24px; display:flex; align-items:center; justify-content:space-between; gap:16px; font-size:16px; color:var(--text-primary); font-weight:500; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .ic{ flex:0 0 auto; width:20px; height:20px; position:relative; }
.faq summary .ic::before,.faq summary .ic::after{ content:""; position:absolute; background:var(--electric-orchid); transition:transform .2s ease; }
.faq summary .ic::before{ top:9px; left:2px; width:16px; height:2px; }
.faq summary .ic::after{ left:9px; top:2px; width:2px; height:16px; }
.faq details[open] summary .ic::after{ transform:scaleY(0); }
.faq .answer{ padding:0 24px 22px; font-size:14.5px; line-height:1.6; color:var(--text-secondary); }

/* ---- big CTA + form ---- */
.cta-band{ padding:96px 0; }
.cta-card{ position:relative; overflow:hidden; border-radius:var(--r-xl); border:1px solid rgba(193,59,255,0.25);
  background:radial-gradient(800px 320px at 78% 0%,rgba(193,59,255,0.18),transparent 60%),
            radial-gradient(560px 320px at 0% 100%,rgba(43,89,255,0.12),transparent 60%),
            linear-gradient(180deg,#0B0E1C,#07091A);
  display:grid; grid-template-columns:1fr 1fr; gap:48px; padding:56px; align-items:center; }
.cta-copy h2{ font-size:clamp(28px,3.4vw,40px); font-weight:600; letter-spacing:-0.025em; margin:14px 0 0; line-height:1.05; }
.cta-copy p{ font-size:16px; color:var(--text-secondary); margin:16px 0 0; max-width:440px; line-height:1.55; }
.cta-copy .assure{ display:flex; flex-direction:column; gap:11px; margin-top:26px; }
.cta-copy .assure li{ list-style:none; font-size:14px; color:var(--text-secondary); display:flex; gap:11px; align-items:center; }
.cta-copy .assure li svg{ width:18px; height:18px; color:var(--emerald); flex:0 0 18px; }
.lead-form{ background:rgba(5,7,17,0.5); border:1px solid var(--border-subtle); border-radius:var(--r-lg); padding:28px; }
.field{ display:flex; flex-direction:column; gap:7px; margin-bottom:14px; }
.field label{ font-family:var(--font-mono); font-size:10px; color:var(--text-muted); letter-spacing:0.12em; text-transform:uppercase; }
.field input,.field select,.field textarea{ background:var(--surface-input); border:1px solid var(--border-subtle); color:var(--text-primary);
  padding:12px 14px; border-radius:var(--r-md); font-family:var(--font-body); font-size:14px; outline:none; transition:border-color .15s ease,box-shadow .15s ease; }
.field input:focus,.field select:focus,.field textarea:focus{ border-color:var(--royal-violet); box-shadow:0 0 0 3px rgba(109,53,255,0.18); }
.field textarea{ min-height:84px; resize:vertical; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.lead-form .btn{ width:100%; margin-top:6px; }
.lead-form .legal{ font-family:var(--font-mono); font-size:10px; letter-spacing:0.04em; color:var(--text-muted); margin:14px 0 0; text-align:center; line-height:1.5; }
.form-success{ display:none; text-align:center; padding:30px 10px; }
.form-success.show{ display:block; }
.form-success .check{ width:54px; height:54px; border-radius:50%; background:rgba(54,211,153,0.12); border:1px solid rgba(54,211,153,0.4); display:grid; place-items:center; margin:0 auto 18px; color:var(--emerald); }
.form-success h3{ font-size:22px; margin:0 0 8px; }
.form-success p{ font-size:14px; color:var(--text-secondary); margin:0; }

/* ---- footer ---- */
.site-footer{ padding:72px 0 40px; }
.foot-grid{ display:grid; grid-template-columns:1.6fr repeat(3,1fr); gap:40px; padding-bottom:48px; border-bottom:1px solid var(--border-subtle); }
.foot-brand .wm{ height:24px; width:auto; margin-bottom:18px; }
.foot-brand p{ font-size:13.5px; color:var(--text-muted); max-width:300px; line-height:1.6; margin:0 0 20px; }
.foot-social{ display:flex; gap:10px; }
.foot-social a{ width:36px; height:36px; border-radius:50%; border:1px solid var(--border-subtle); display:grid; place-items:center; color:var(--text-secondary); transition:border-color .2s ease,color .2s ease; }
.foot-social a:hover{ border-color:var(--royal-violet); color:var(--text-primary); }
.foot-social svg{ width:16px; height:16px; }
.foot-col h4{ font-family:var(--font-mono); font-size:11px; letter-spacing:0.16em; color:var(--text-muted); text-transform:uppercase; margin:0 0 16px; font-weight:500; }
.foot-col ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:11px; }
.foot-col a{ font-size:13.5px; color:var(--text-secondary); }
.foot-col a:hover{ color:var(--text-primary); }
.foot-bottom{ display:flex; align-items:center; justify-content:space-between; padding-top:26px; font-family:var(--font-mono); font-size:11px; letter-spacing:0.06em; color:var(--text-muted); }
.foot-bottom .links{ display:flex; gap:22px; }
.foot-bottom a:hover{ color:var(--text-primary); }

/* ---- reveal ---- */
.reveal{ opacity:0; transform:translateY(18px); transition:opacity .6s ease,transform .6s ease; }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; transition:none; } html{ scroll-behavior:auto; } }

/* ---- responsive ---- */
@media (max-width:1080px){
  .hero-grid{ grid-template-columns:1fr; gap:44px; }
  .hero-visual{ max-width:560px; }
  .feat-grid{ grid-template-columns:1fr 1fr; }
  .steps{ grid-template-columns:1fr 1fr 1fr; }
  .step:not(:last-child)::after{ display:none; }
  .pricing{ grid-template-columns:1fr 1fr; }
  .proof-grid{ grid-template-columns:1fr; }
  .cta-card{ grid-template-columns:1fr; gap:32px; padding:40px; }
}
@media (max-width:720px){
  .shell{ padding:0 20px; }
  .nav,.nav-cta .nav-link-ghost{ display:none; }
  .menu-toggle{ display:inline-flex; }
  section.block{ padding:64px 0; }
  .feat-grid,.steps,.pricing{ grid-template-columns:1fr; }
  .step:not(:last-child)::after{ display:none; }
  .hero-meta{ flex-wrap:wrap; gap:20px; }
  .field-row{ grid-template-columns:1fr; }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:28px; }
  .foot-brand{ grid-column:1 / -1; }
  .foot-bottom{ flex-direction:column; gap:14px; align-items:flex-start; }
  .hero-leadform .lf-row{ flex-direction:column; }
  .hero-leadform input{ border-radius:var(--r-md); }
}
/* graceful header degradation:
   >1180px  → full bar (nav + lang + Free assessment + Try it free)
   ≤1180px  → drop the "Free assessment" ghost link (still in the menu)
   ≤1000px  → collapse the whole nav to the hamburger */
@media (max-width:1180px){
  .nav-cta .nav-link-ghost{ display:none; }
}
@media (max-width:1000px){
  .nav{ display:none; }
  .menu-toggle{ display:inline-flex; }
}

/* mobile menu */
.mobile-menu{ display:none; position:fixed; inset:0; z-index:100; background:rgba(5,7,17,0.97); backdrop-filter:blur(8px); padding:28px; flex-direction:column; gap:8px; }
.mobile-menu.open{ display:flex; }
.mobile-menu .mm-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:24px; }
.mobile-menu a{ font-size:20px; color:var(--text-primary); padding:14px 0; border-bottom:1px solid var(--border-subtle); }
.mobile-menu .btn{ margin-top:18px; }
.mobile-menu .mm-close{ background:none; border:1px solid var(--border-subtle); border-radius:var(--r-sm); padding:8px; cursor:pointer; color:var(--text-primary); }
.mobile-menu .mm-close svg{ width:20px; height:20px; }
