/* ============================================================
   ARTEMIS TECH — single-page site styles
   Builds on colors_and_type.css. Forks the website UI kit
   vocabulary (nav, hero streaks, service/process cards, footer)
   and extends it with Why Us, How It Works, FAQ, Contact.
   Palette is strictly blue + navy/white. No ember/warm tones.
   ============================================================ */
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--font-body);background:var(--navy-900);color:var(--fg);-webkit-font-smoothing:antialiased;overflow-x:hidden;}
img{max-width:100%;display:block;}
.container{max-width:1280px;margin:0 auto;padding:0 clamp(20px,4vw,56px);}
.section{padding:var(--space-9) 0;position:relative;}
.section-head{max-width:720px;margin:0 auto var(--space-7);text-align:center;}
.section-head .eyebrow{justify-content:center;display:flex;margin-bottom:16px;}
.section-sub{margin-top:16px;}
.eyebrow-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);display:inline-block;margin-right:9px;vertical-align:middle;}

/* ---------- Buttons (forked from kit) ---------- */
.btn{font-family:var(--font-display);font-weight:600;font-size:15px;border:none;border-radius:var(--radius-sm);padding:12px 22px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:background var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out),border-color var(--dur-base);text-decoration:none;white-space:nowrap;line-height:1;}
.btn-sm{padding:10px 18px;font-size:14px;}
.btn-lg{padding:15px 28px;font-size:16px;}
.btn-arrow{transition:transform var(--dur-base) var(--ease-out);}
.btn:hover .btn-arrow{transform:translateX(4px);}
.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-sm);}
.btn-primary:hover{background:var(--accent-hover);box-shadow:var(--shadow-brand);transform:translateY(-1px);}
.btn-primary:active{background:var(--accent-press);transform:translateY(0);box-shadow:var(--shadow-sm);}
.btn-ghost-light{background:rgba(255,255,255,.07);color:#fff;border:1px solid rgba(255,255,255,.16);}
.btn-ghost-light:hover{background:rgba(255,255,255,.13);border-color:rgba(255,255,255,.28);transform:translateY(-1px);}
.btn-pill{border-radius:var(--radius-pill);}
.btn:focus-visible{outline:3px solid var(--ring);outline-offset:2px;}
.btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none;}

/* ============================================================
   NAV — fixed, full-width. Transparent over hero, navy blur on scroll.
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:80;display:flex;justify-content:center;transition:background var(--dur-base) var(--ease-out),box-shadow var(--dur-base),border-color var(--dur-base);border-bottom:1px solid transparent;}
.nav.is-scrolled{background:rgba(11,34,53,.72);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);border-bottom-color:rgba(255,255,255,.08);box-shadow:0 8px 30px rgba(8,26,41,.4);}
.nav-inner{width:100%;max-width:1600px;display:flex;align-items:center;gap:24px;padding:18px clamp(24px,4vw,56px);transition:padding var(--dur-base) var(--ease-out);}
.nav.is-scrolled .nav-inner{padding:13px clamp(24px,4vw,56px);}
.nav-logo{height:30px;width:auto;transition:height var(--dur-base);}
.nav.is-scrolled .nav-logo{height:27px;}
.brand-lock{display:inline-flex;align-items:center;gap:11px;text-decoration:none;}
.brand-lock img{height:30px;width:auto;transition:height var(--dur-base) var(--ease-out);}
.brand-lock .wm{font-family:var(--font-display);font-weight:800;font-size:21px;letter-spacing:-.025em;color:#fff;line-height:1;white-space:nowrap;}
.nav.is-scrolled .brand-lock img{height:27px;}
.nav-links{display:flex;gap:30px;list-style:none;margin:0;padding:0;flex:1;justify-content:flex-end;}
.nav-links a{font-family:var(--font-display);font-weight:500;font-size:15px;color:rgba(255,255,255,.74);text-decoration:none;transition:color var(--dur-fast);position:relative;cursor:pointer;}
.nav-links a:hover,.nav-links a.active{color:#fff;}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-6px;height:2px;border-radius:2px;background:var(--accent);transition:right var(--dur-base) var(--ease-out);}
.nav-links a:hover::after,.nav-links a.active::after{right:0;}
.nav-cta{display:flex;align-items:center;}
.nav-burger{display:none;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);color:#fff;cursor:pointer;padding:9px;border-radius:var(--radius-sm);}
.nav-sheet{position:absolute;top:74px;left:16px;right:16px;background:var(--navy-800);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:14px;flex-direction:column;gap:4px;display:flex;}
.nav-sheet a{font-family:var(--font-display);font-weight:600;font-size:16px;color:#fff;text-decoration:none;padding:13px 14px;border-radius:var(--radius-sm);cursor:pointer;}
.nav-sheet a:hover{background:rgba(255,255,255,.06);}
.nav-sheet .btn{margin-top:8px;}

/* ============================================================
   HERO — full viewport navy. Dot grid + radial glow + streaks.
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;padding:140px 0 90px;}
.hero-dotgrid{position:absolute;inset:0;background-image:radial-gradient(rgba(143,186,219,.16) 1.2px,transparent 1.2px);background-size:30px 30px;mask-image:radial-gradient(ellipse 80% 65% at 60% 35%,#000 30%,transparent 78%);-webkit-mask-image:radial-gradient(ellipse 80% 65% at 60% 35%,#000 30%,transparent 78%);}
.hero-glow{position:absolute;width:1100px;height:1100px;left:48%;top:-40%;background:radial-gradient(circle,rgba(74,144,196,.28),rgba(74,144,196,.06) 42%,transparent 66%);filter:blur(20px);pointer-events:none;}
.hero-glow.two{left:8%;top:30%;width:760px;height:760px;background:radial-gradient(circle,rgba(45,106,159,.22),transparent 64%);}
.hero-streaks{position:absolute;inset:0;overflow:hidden;pointer-events:none;}
.streak{position:absolute;height:2px;border-radius:2px;background:linear-gradient(90deg,transparent,var(--blue-400));opacity:0;animation:streak-fly 5s var(--ease-out) infinite;}
.streak.s0{top:24%;width:200px;animation-delay:.4s;}
.streak.s1{top:52%;width:300px;animation-delay:2s;}
.streak.s2{top:71%;width:170px;animation-delay:3.1s;}
.streak.s3{top:86%;width:240px;animation-delay:1.2s;background:linear-gradient(90deg,transparent,var(--blue-300));}
@keyframes streak-fly{0%{transform:translateX(-260px);opacity:0;}20%{opacity:.7;}100%{transform:translateX(112vw);opacity:0;}}
.hero-inner{position:relative;z-index:2;width:100%;max-width:1200px;margin:0 auto;padding:0 32px;display:grid;grid-template-columns:1.04fr .96fr;gap:54px;align-items:center;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;padding:8px 16px 8px 12px;border:1px solid rgba(255,255,255,.14);border-radius:var(--radius-pill);background:rgba(255,255,255,.04);}
.hero-eyebrow .eyebrow-mark{height:18px;}
.hero-h1{font-family:var(--font-display);font-weight:800;font-size:clamp(46px,6.4vw,80px);line-height:1.02;letter-spacing:-.03em;color:#fff;margin:24px 0 0;max-width:11ch;}
.hero-h1 .word{display:inline-block;}
.hero-h1 .grad{background:linear-gradient(100deg,var(--blue-300),#dff0fb);-webkit-background-clip:text;background-clip:text;color:transparent;}
.hero-lead{margin:24px 0 0;max-width:48ch;font-size:clamp(17px,1.5vw,20px);line-height:1.6;color:rgba(255,255,255,.78);}
.hero-cta{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap;}
.hero-proof{display:flex;align-items:center;gap:16px;margin-top:34px;font-size:14px;color:rgba(255,255,255,.55);flex-wrap:wrap;}
.hero-proof b{color:#fff;font-family:var(--font-display);font-weight:700;}
.dot-sep{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.4);}

/* Hero word-by-word entrance — auto-runs from CSS (delays set inline) */
.reveal-word{opacity:0;transform:translateY(.6em);display:inline-block;animation:word-in .7s var(--ease-out) both;}
.hero-fade{opacity:0;transform:translateY(14px);animation:fade-up .8s var(--ease-out) both;}
@keyframes word-in{to{opacity:1;transform:translateY(0);}}
@keyframes fade-up{to{opacity:1;transform:translateY(0);}}

/* Hero dashboard mockup — 3D perspective tilt */
.hero-visual{perspective:1500px;display:flex;justify-content:center;}
.hcard{width:100%;max-width:440px;background:linear-gradient(180deg,var(--navy-700),#12314a);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-xl),0 0 0 1px rgba(255,255,255,.03) inset;transform:rotateY(-13deg) rotateX(7deg) translateZ(0);transition:transform .6s var(--ease-out);will-change:transform;}
.hcard:hover{transform:rotateY(-6deg) rotateX(3deg);}
.hcard-glow{position:absolute;inset:-2px;border-radius:var(--radius-lg);background:linear-gradient(140deg,rgba(74,144,196,.5),transparent 50%);opacity:.5;filter:blur(22px);z-index:-1;}
.hcard-top{display:flex;align-items:center;gap:9px;font-family:var(--font-display);font-weight:600;font-size:14.5px;color:#fff;margin-bottom:20px;}
.hcard-dot{width:9px;height:9px;border-radius:50%;background:var(--blue-400);box-shadow:0 0 0 4px rgba(74,144,196,.18);}
.hcard-live{margin-left:auto;display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--blue-300);font-weight:600;font-family:var(--font-mono);}
.pulse{width:7px;height:7px;border-radius:50%;background:var(--blue-300);box-shadow:0 0 0 0 rgba(143,186,219,.6);animation:pulse 2.2s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(143,186,219,.5);}70%{box-shadow:0 0 0 8px rgba(143,186,219,0);}100%{box-shadow:0 0 0 0 rgba(143,186,219,0);}}
.hcard-row{margin-bottom:16px;}
.hcard-row-head{display:flex;justify-content:space-between;align-items:center;font-size:13.5px;color:rgba(255,255,255,.8);margin-bottom:8px;}
.hcard-pct{color:var(--blue-300);font-family:var(--font-mono);font-size:12px;display:inline-flex;align-items:center;gap:4px;}
.hcard-track{height:8px;border-radius:99px;background:rgba(255,255,255,.09);overflow:hidden;}
.hcard-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--blue-600),var(--blue-300));width:0;transition:width 1.1s var(--ease-out);}
.hcard-foot{margin-top:20px;padding-top:18px;border-top:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:9px;font-size:13.5px;color:rgba(255,255,255,.8);}
.hcard-foot svg{color:var(--blue-300);}
.hero-float-chip{position:absolute;font-family:var(--font-mono);font-size:12px;color:#fff;background:rgba(11,34,53,.86);border:1px solid rgba(255,255,255,.16);padding:9px 13px;border-radius:var(--radius-pill);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:8px;backdrop-filter:blur(6px);}
.hero-float-chip svg{color:var(--blue-300);}
.hero-float-chip.a{top:-26px;right:4%;animation:floaty 6s ease-in-out infinite;}
.hero-float-chip.b{bottom:-20px;left:4%;animation:floaty 7s ease-in-out infinite .8s;}
@keyframes floaty{0%,100%{transform:translateY(0);}50%{transform:translateY(-10px);}}

/* ============================================================
   SCROLL REVEAL — generic
   ============================================================ */
.sr{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out);}
.sr.in{opacity:1;transform:none;}
.sr-l{opacity:0;transform:translateX(-32px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out);}
.sr-l.in{opacity:1;transform:none;}
.sr-d2{transition-delay:.08s;}
.sr-d3{transition-delay:.16s;}
.sr-d4{transition-delay:.24s;}

/* ============================================================
   SERVICES — navy band, 4 cards with 3D hover tilt
   ============================================================ */
.services{background:var(--navy-900);}
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.tilt{perspective:900px;}
.svc-card{position:relative;background:linear-gradient(180deg,var(--navy-700),#123048);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:26px;display:flex;flex-direction:column;height:100%;transform-style:preserve-3d;transition:transform .35s var(--ease-out),box-shadow .35s var(--ease-out),border-color .35s;}
.svc-card:hover{box-shadow:var(--shadow-xl);border-color:rgba(74,144,196,.5);}
.svc-card.featured{border-color:rgba(74,144,196,.45);box-shadow:0 0 0 1px rgba(74,144,196,.3),var(--shadow-lg);}
.svc-shine{position:absolute;inset:0;border-radius:var(--radius-lg);background:radial-gradient(420px circle at var(--mx,50%) var(--my,0%),rgba(143,186,219,.14),transparent 60%);opacity:0;transition:opacity .35s;pointer-events:none;}
.svc-card:hover .svc-shine{opacity:1;}
.svc-card>*{transform:translateZ(0.01px);}
.svc-icon{width:50px;height:50px;border-radius:var(--radius-md);background:rgba(74,144,196,.16);color:var(--blue-300);display:flex;align-items:center;justify-content:center;margin-bottom:18px;}
.svc-badge{position:absolute;top:26px;right:26px;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.04em;color:var(--blue-200);background:rgba(74,144,196,.14);border:1px solid rgba(74,144,196,.28);padding:4px 9px;border-radius:var(--radius-pill);text-transform:uppercase;}
.svc-card h3{margin:0 0 8px;color:#fff;font-family:var(--font-display);font-weight:700;font-size:19px;letter-spacing:-.01em;}
.svc-price{font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--blue-300);margin:0 0 14px;line-height:1.4;}
.svc-price .sub{color:rgba(255,255,255,.5);font-weight:500;font-size:13px;}
.svc-card p.svc-body{margin:0;font-size:14.5px;line-height:1.6;color:rgba(255,255,255,.74);flex:1;}
.svc-foot{margin-top:20px;}
.svc-link{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-display);font-weight:600;font-size:14px;color:var(--blue-300);text-decoration:none;cursor:pointer;}
.svc-link:hover{color:var(--blue-200);}
.svc-link:hover .btn-arrow{transform:translateX(4px);}

/* ============================================================
   WHY US — white band, founder story + 2x2 value pillars
   ============================================================ */
.whyus{background:var(--neutral-25);}
.why-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:64px;align-items:center;}
.why-h2{font-family:var(--font-display);font-weight:800;font-size:clamp(34px,3.6vw,46px);line-height:1.06;letter-spacing:-.025em;color:var(--navy-900);margin:18px 0 0;max-width:14ch;}
.why-body{margin-top:24px;display:flex;flex-direction:column;gap:16px;}
.why-body p{margin:0;font-size:16.5px;line-height:1.68;color:var(--neutral-700);}
.why-body p .accent{color:var(--accent-press);font-weight:600;}
.why-sign{margin-top:28px;display:flex;align-items:center;gap:14px;}
.why-avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(140deg,var(--blue-500),var(--blue-700));color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:18px;box-shadow:var(--shadow-md);}
.why-sign-meta b{display:block;font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--navy-900);}
.why-sign-meta span{font-size:13.5px;color:var(--neutral-500);}
.pillars{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.pillar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease-out),box-shadow .3s var(--ease-out);}
.pillar:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.pillar-icon{width:46px;height:46px;border-radius:var(--radius-md);background:var(--blue-50);color:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:16px;}
.pillar h4{margin:0 0 7px;font-family:var(--font-display);font-weight:700;font-size:16.5px;color:var(--navy-900);letter-spacing:-.01em;}
.pillar p{margin:0;font-size:14px;line-height:1.55;color:var(--neutral-600);}

/* ============================================================
   HOW IT WORKS — navy band, 3-step cinematic slider
   ============================================================ */
.how{background:var(--navy-800);overflow:hidden;}
.how-rail{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative;}
.how-line{position:absolute;top:46px;left:8%;right:8%;height:2px;background:linear-gradient(90deg,transparent,rgba(74,144,196,.4),rgba(74,144,196,.4),transparent);z-index:0;}
.how-step{position:relative;z-index:1;background:linear-gradient(180deg,var(--navy-700),#12304a);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-xl);padding:34px 28px;transition:transform .4s var(--ease-out),box-shadow .4s var(--ease-out),border-color .4s;}
.how-step:hover{transform:translateY(-6px);border-color:rgba(74,144,196,.5);box-shadow:var(--shadow-xl);}
.how-num{width:56px;height:56px;border-radius:var(--radius-md);background:rgba(74,144,196,.14);border:1px solid rgba(74,144,196,.3);color:var(--blue-300);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:22px;margin-bottom:22px;}
.how-step.active .how-num{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:var(--shadow-brand);}
.how-eyebrow{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--blue-300);margin-bottom:10px;}
.how-step h3{margin:0 0 10px;color:#fff;font-family:var(--font-display);font-weight:700;font-size:21px;letter-spacing:-.012em;}
.how-step p{margin:0;font-size:15px;line-height:1.62;color:rgba(255,255,255,.74);}
.how-step .step-arrow{position:absolute;top:60px;right:-26px;color:var(--blue-400);z-index:3;}
.how-rail .how-step:last-child .step-arrow{display:none;}

/* ============================================================
   FAQ — white band, accordion
   ============================================================ */
.faq{background:var(--neutral-25);}
.faq-wrap{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:14px;}
.faq-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);overflow:hidden;transition:box-shadow .3s,border-color .3s;}
.faq-item.open{box-shadow:var(--shadow-md);border-color:var(--blue-200);}
.faq-q{width:100%;background:none;border:none;cursor:pointer;display:flex;align-items:center;gap:18px;padding:24px 26px;text-align:left;font-family:var(--font-display);font-weight:600;font-size:18px;color:var(--navy-900);letter-spacing:-.01em;}
.faq-q .faq-ico{margin-left:auto;flex:none;width:34px;height:34px;border-radius:50%;background:var(--blue-50);color:var(--accent);display:flex;align-items:center;justify-content:center;transition:transform .35s var(--ease-out),background .3s;}
.faq-item.open .faq-q .faq-ico{background:var(--accent);color:#fff;transform:rotate(180deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease-out);}
.faq-a-inner{padding:0 26px 26px 26px;font-size:16px;line-height:1.66;color:var(--neutral-700);max-width:62ch;}

/* ============================================================
   CONTACT — navy band, smart inquiry form
   ============================================================ */
.contact{background:var(--navy-900);}
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:56px;align-items:start;}
.contact-h2{font-family:var(--font-display);font-weight:800;font-size:clamp(34px,3.8vw,48px);line-height:1.05;letter-spacing:-.025em;color:#fff;margin:18px 0 0;max-width:12ch;}
.contact-sub{margin-top:20px;font-size:17px;line-height:1.6;color:rgba(255,255,255,.74);max-width:42ch;}
.contact-mail{margin-top:28px;display:inline-flex;align-items:center;gap:11px;color:#fff;text-decoration:none;font-family:var(--font-display);font-weight:600;font-size:16px;padding:13px 18px;border:1px solid rgba(255,255,255,.16);border-radius:var(--radius-sm);background:rgba(255,255,255,.04);transition:background .25s,border-color .25s;}
.contact-mail:hover{background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.3);}
.contact-mail svg{color:var(--blue-300);}
.founder-card{margin-top:30px;display:flex;align-items:center;gap:16px;background:linear-gradient(180deg,var(--navy-700),#12304a);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:20px;max-width:400px;}
.founder-avatar{width:58px;height:58px;border-radius:50%;background:linear-gradient(140deg,var(--blue-400),var(--blue-700));color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:20px;flex:none;box-shadow:var(--shadow-md);}
.founder-meta b{display:block;font-family:var(--font-display);font-weight:700;font-size:16px;color:#fff;}
.founder-meta span{font-size:14px;color:rgba(255,255,255,.6);}

/* Form card */
.form-card{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:30px;}
.form-card.dark{background:linear-gradient(180deg,var(--navy-700),#12304a);border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow-xl);}
.form-title{font-family:var(--font-display);font-weight:700;font-size:20px;color:var(--navy-900);letter-spacing:-.012em;margin:0 0 6px;}
.form-desc{font-size:14.5px;color:var(--neutral-600);margin:0 0 22px;line-height:1.5;}
.svc-select-label{font-family:var(--font-display);font-weight:600;font-size:13px;color:var(--neutral-700);margin-bottom:10px;display:block;}
.svc-select{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:24px;}
.svc-opt{display:flex;align-items:center;gap:10px;padding:13px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;font-family:var(--font-display);font-weight:600;font-size:14px;color:var(--neutral-700);transition:border-color .2s,background .2s,color .2s;text-align:left;}
.svc-opt .svc-opt-ico{flex:none;width:30px;height:30px;border-radius:8px;background:var(--blue-50);color:var(--accent);display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s;}
.svc-opt:hover{border-color:var(--blue-300);}
.svc-opt.sel{border-color:var(--accent);background:var(--blue-50);color:var(--accent-press);box-shadow:0 0 0 1px var(--accent);}
.svc-opt.sel .svc-opt-ico{background:var(--accent);color:#fff;}
.svc-opt.full{grid-column:1/-1;}

.field{margin-bottom:16px;}
.field.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.field label,.fieldset-label{display:block;font-family:var(--font-display);font-weight:600;font-size:13px;color:var(--neutral-700);margin-bottom:7px;}
.req{color:var(--danger-500);margin-left:2px;}
.input,.textarea,.select{width:100%;font-family:var(--font-body);font-size:15px;color:var(--navy-900);background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;transition:border-color .2s,box-shadow .2s;}
.input::placeholder,.textarea::placeholder{color:var(--neutral-400);}
.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--ring);}
.textarea{resize:vertical;min-height:104px;line-height:1.55;}
.input.err,.textarea.err,.select.err{border-color:var(--danger-500);}
.err-msg{font-size:12.5px;color:var(--danger-500);margin-top:6px;font-family:var(--font-body);}
.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%236F7E8E' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px;cursor:pointer;}

/* segmented radio (contact method) */
.seg{display:flex;gap:0;border:1.5px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;}
.seg button{flex:1;background:var(--surface);border:none;border-right:1.5px solid var(--border);padding:11px 10px;font-family:var(--font-display);font-weight:600;font-size:13.5px;color:var(--neutral-600);cursor:pointer;transition:background .2s,color .2s;}
.seg button:last-child{border-right:none;}
.seg button.sel{background:var(--accent);color:#fff;}
.seg button:not(.sel):hover{background:var(--blue-50);color:var(--accent-press);}

.enterprise-block{border-top:1px dashed var(--border);margin-top:6px;padding-top:20px;animation:fade-up .4s var(--ease-out);}
.enterprise-tag{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--accent-press);background:var(--blue-50);border:1px solid var(--blue-200);padding:5px 11px;border-radius:var(--radius-pill);margin-bottom:18px;}
.form-submit{margin-top:8px;width:100%;}
.form-note{margin-top:14px;font-size:12.5px;color:var(--neutral-500);text-align:center;line-height:1.5;}

/* dark form variants (the general/FAQ form sits on navy) */
.form-card.dark .form-title{color:#fff;}
.form-card.dark .form-desc{color:rgba(255,255,255,.66);}
.form-card.dark .field label{color:rgba(255,255,255,.8);}
.form-card.dark .input,.form-card.dark .textarea{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.16);color:#fff;}
.form-card.dark .input::placeholder,.form-card.dark .textarea::placeholder{color:rgba(255,255,255,.4);}
.form-card.dark .input:focus,.form-card.dark .textarea:focus{border-color:var(--blue-300);box-shadow:0 0 0 3px rgba(143,186,219,.25);}
.form-card.dark .form-note{color:rgba(255,255,255,.5);}

/* success state */
.form-success{text-align:center;padding:30px 10px;animation:fade-up .5s var(--ease-out);}
.success-ring{width:72px;height:72px;border-radius:50%;background:var(--success-50);color:var(--success-500);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;}
.form-card.dark .success-ring{background:rgba(46,158,107,.16);}
.form-success h3{font-family:var(--font-display);font-weight:700;font-size:22px;color:var(--navy-900);margin:0 0 8px;letter-spacing:-.012em;}
.form-card.dark .form-success h3{color:#fff;}
.form-success p{font-size:15px;color:var(--neutral-600);margin:0 auto;max-width:34ch;line-height:1.55;}
.form-card.dark .form-success p{color:rgba(255,255,255,.68);}

.general-block{margin-top:26px;}

/* ============================================================
   FOOTER — near-black
   ============================================================ */
.footer{background:var(--navy-950);padding:72px 0 36px;}
.footer-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:40px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.1);}
.footer-logo{height:34px;margin-bottom:18px;}
.footer-brand p{font-size:14.5px;max-width:32ch;color:rgba(255,255,255,.6);line-height:1.6;margin:0 0 18px;}
.footer-mail{display:inline-flex;align-items:center;gap:8px;color:var(--blue-300);text-decoration:none;font-size:14px;font-family:var(--font-display);font-weight:600;}
.footer-mail:hover{color:var(--blue-200);}
.footer-col h5{font-family:var(--font-display);font-weight:700;font-size:13px;color:#fff;margin:0 0 16px;letter-spacing:.01em;}
.footer-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px;}
.footer-col a{font-size:14px;color:rgba(255,255,255,.58);text-decoration:none;transition:color var(--dur-fast);cursor:pointer;}
.footer-col a:hover{color:#fff;}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:26px;font-size:13px;color:rgba(255,255,255,.5);flex-wrap:wrap;gap:12px;}
.footer-legal{display:flex;gap:22px;}
.footer-legal a{color:rgba(255,255,255,.5);text-decoration:none;cursor:pointer;}
.footer-legal a:hover{color:#fff;}

/* ---------- Toast ---------- */
.toast{position:fixed;bottom:26px;left:50%;transform:translate(-50%,90px);background:var(--navy-800);border:1px solid rgba(255,255,255,.14);color:#fff;font-family:var(--font-body);font-size:14px;display:flex;align-items:center;gap:10px;padding:14px 22px;border-radius:var(--radius-pill);box-shadow:var(--shadow-xl);z-index:120;opacity:0;transition:transform .45s var(--ease-spring),opacity .3s;}
.toast svg{color:var(--success-500);}
.toast.show{transform:translate(-50%,0);opacity:1;}

/* ============================================================
   MOTION PREFERENCES
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  .streak,.pulse,.hero-float-chip.a,.hero-float-chip.b{animation:none!important;}
  .streak{opacity:.35;}
  .reveal-word,.hero-fade,.sr,.sr-l{opacity:1!important;transform:none!important;animation:none!important;transition:none!important;}
  html{scroll-behavior:auto;}
}
body.no-motion .streak,body.no-motion .pulse,body.no-motion .hero-float-chip.a,body.no-motion .hero-float-chip.b{animation:none!important;}
body.no-motion .streak{opacity:.3;}
body.no-motion .reveal-word,body.no-motion .hero-fade{opacity:1!important;transform:none!important;animation:none!important;}
body.no-motion .sr,body.no-motion .sr-l{transition:none!important;opacity:1!important;transform:none!important;}
body.no-motion .hcard{transform:rotateY(-10deg) rotateX(5deg);}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1040px){
  .svc-grid{grid-template-columns:1fr 1fr;}
}
@media (max-width:920px){
  .hero-inner,.why-grid,.contact-grid{grid-template-columns:1fr;gap:44px;}
  .hero{min-height:auto;padding:128px 0 80px;}
  .hcard{transform:none;max-width:420px;margin:0 auto;}
  .hcard:hover{transform:none;}
  .how-rail{grid-template-columns:1fr;gap:18px;}
  .how-line{display:none;}
  .how-step .step-arrow{display:none!important;}
  .nav-links,.nav-cta{display:none;}
  .nav-burger{display:block;margin-left:auto;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .pillars{gap:14px;}
}
@media (max-width:560px){
  .container,.nav-inner,.hero-inner{padding-left:20px;padding-right:20px;}
  .svc-grid,.pillars,.svc-select,.field.row2{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;gap:30px;}
  .section{padding:var(--space-8) 0;}
  .hero-float-chip{display:none;}
  .why-grid,.contact-grid{gap:36px;}
}
