:root{
    --bg-0:#ffffff;
    --bg-1:#e8f1f7;
    --bg-2:#d3e4ef;
    --surface:rgba(14,22,47,0.03);
    --surface-2:rgba(14,22,47,0.05);
    --border:rgba(14,22,47,0.10);
    --border-strong:rgba(63,156,204,0.34);
    --text:#0a1a30;
    --text-soft:#11294a;
    --muted:#1a3253;
    /* Brand palette — sourced from the official Prosfar hex codes. */
    --brand-1:#3F9CCC;            /* light cyan-blue (primary) */
    --brand-2:#1D537D;            /* mid blue (interpolated bridge) */
    --brand-3:#0E162F;            /* deepest navy */
    --brand-deep-alt:#0D1C34;     /* secondary deep navy */
    --accent:#3F9CCC;
    --accent-teal:#3BBFBA;        /* teal accent from the brand sheet */
    /* The following gradient vars are STATIC FALLBACKS only.
       functions.php overrides them at runtime with values computed from the
       Customizer Colour scheme / brand pickers, so the entire site retints
       automatically when an admin changes the palette. */
    --grad-brand:linear-gradient(180deg,#3F9CCC 0%,#1D537D 50%,#0E162F 100%);
    --grad-soft:linear-gradient(135deg,rgba(63,156,204,0.14),rgba(29,83,125,0.06));
    /* Section background overlay (sits on top of the mesh image).
       Replicates the brand-reference background: #3F9CCC at the top
       transitioning through mid-blue and landing on #0E162F at the bottom.
       Alphas tuned so the mesh stays visible and dark headings remain
       readable on the upper light band. */
    --grad-section-bg:linear-gradient(180deg,
        rgba(63,156,204,0.40) 0%,
        rgba(63,156,204,0.55) 30%,
        rgba(46,120,165,0.70) 55%,
        rgba(29,83,125,0.80) 78%,
        rgba(21,49,82,0.86) 93%,
        rgba(14,22,47,0.90) 100%);
    /* Footer overlay (kept darker so light text remains legible). */
    --grad-footer-bg:linear-gradient(180deg,
        rgba(29,83,125,0.78) 0%,
        rgba(21,49,82,0.86) 45%,
        rgba(21,49,82,0.90) 80%,
        rgba(14,22,47,0.93) 100%);
    /* Solid colour shown if the mesh image fails to load (brand-1, vibrant). */
    --section-bg-fallback:#3F9CCC;
    --shadow-sm:0 4px 14px -6px rgba(14,22,47,0.12);
    --shadow-md:0 16px 36px -16px rgba(14,22,47,0.20);
    --shadow-glow:0 20px 48px -20px rgba(63,156,204,0.38);
    --radius-lg:22px;
    --radius-md:14px;
    --radius-sm:10px;
    --container:1200px;
    --ease:cubic-bezier(.22,.8,.22,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:clip}
body{
    font-family:'Manrope',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
    background:var(--bg-0);
    color:var(--text);
    line-height:1.55;
    -webkit-font-smoothing:antialiased;
    overflow-x:clip;
    -webkit-text-size-adjust:100%;
}
body.menu-open{overflow:hidden}
img,svg,video,canvas{max-width:100%}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block;height:auto}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
::selection{background:rgba(29,163,200,0.25);color:var(--brand-3)}

.screen-reader-text{
    border:0;clip:rect(1px,1px,1px,1px);
    clip-path:inset(50%);height:1px;width:1px;
    margin:-1px;overflow:hidden;padding:0;position:absolute;word-wrap:normal!important;
}
.screen-reader-text:focus{
    background:#fff;clip:auto!important;clip-path:none;
    color:var(--text);display:block;font-size:14px;font-weight:600;
    height:auto;left:5px;line-height:normal;padding:15px 23px 14px;
    text-decoration:none;top:5px;width:auto;z-index:100000;
}

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

/* ===== Header ===== */
header.nav{
    position:fixed;top:0;left:0;right:0;z-index:9999;
    backdrop-filter:blur(14px) saturate(160%);
    -webkit-backdrop-filter:blur(14px) saturate(160%);
    background:rgba(255,255,255,0.72);
    border-bottom:1px solid transparent;
    transition:border-color .3s var(--ease), background .3s var(--ease);
}
header.nav.scrolled{
    border-bottom-color:var(--border);
    background:rgba(255,255,255,0.92);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:80px}

.logo{display:inline-flex;align-items:center;gap:10px}
.logo img{height:48px;width:auto;display:block}

.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a:not(.btn){
    color:var(--text-soft);font-weight:600;font-size:15px;
    transition:color .25s var(--ease);position:relative;
}
.nav-links a:not(.btn):hover{color:var(--text)}
.nav-links a:not(.btn)::after{
    content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;
    background:var(--grad-brand);transform:scaleX(0);transform-origin:left;
    transition:transform .3s var(--ease);border-radius:2px;
}
.nav-links a:not(.btn):hover::after{transform:scaleX(1)}
.nav-links a.btn-primary{color:#fff}
.nav-links ul{list-style:none;display:flex;gap:32px;align-items:center;margin:0;padding:0}
.nav-links li{list-style:none}

.btn{
    display:inline-flex;align-items:center;gap:8px;
    padding:12px 22px;border-radius:999px;font-weight:600;font-size:15px;
    transition:transform .25s var(--ease), box-shadow .3s var(--ease), background .3s var(--ease);
    white-space:nowrap;font-family:inherit;
}
.btn-primary{
    background:linear-gradient(135deg,#062236 0%,#0b5a7a 55%,#0e6a8e 100%);
    color:#fff;
    font-weight:700;
    letter-spacing:.01em;
    text-shadow:0 1px 2px rgba(0,0,0,0.25);
    box-shadow:0 10px 24px -10px rgba(8,40,68,0.55), inset 0 0 0 1px rgba(255,255,255,0.14);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 36px -10px rgba(8,40,68,0.65)}
.btn-primary svg{stroke:#fff}
.btn-ghost{
    background:#fff;
    border:1px solid var(--border);color:var(--text);
}
.btn-ghost:hover{background:var(--bg-1);border-color:var(--border-strong)}

.menu-toggle{
    display:none;width:42px;height:42px;border-radius:10px;
    border:1px solid var(--border);background:#fff;
    align-items:center;justify-content:center;
}
.menu-toggle span{width:18px;height:2px;background:var(--text);position:relative;display:block;border-radius:2px;transition:all .3s var(--ease)}
.menu-toggle span::before,.menu-toggle span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--text);border-radius:2px;transition:all .3s var(--ease)}
.menu-toggle span::before{top:-6px}.menu-toggle span::after{top:6px}
.menu-toggle.open span{background:transparent}
.menu-toggle.open span::before{top:0;transform:rotate(45deg)}
.menu-toggle.open span::after{top:0;transform:rotate(-45deg)}

/* ===== Hero ===== */
.hero{
    position:relative;padding:140px 0 80px;overflow:hidden;
    background-color:var(--section-bg-fallback);
    background-image:
        var(--grad-section-bg),
        url('../images/mesh-bg-light.webp');
    background-size:cover, cover;
    background-position:center top, center top;
    background-repeat:no-repeat, no-repeat;
}
.hero::after{
    content:"";position:absolute;inset:0;pointer-events:none;
    background:
        radial-gradient(900px 500px at 78% 0%, rgba(29,163,200,0.12), transparent 65%),
        radial-gradient(700px 420px at 0% 70%, rgba(125,233,255,0.10), transparent 60%);
}
.section-particles{
    position:absolute;inset:0;width:100%;height:100%;
    pointer-events:none;z-index:1;
    opacity:0;transition:opacity 1.2s var(--ease);
}
.section-particles.ready{opacity:1}
#waitlist > .container{position:relative;z-index:5}

.hero > .container{position:relative;z-index:5}
.hero-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:60px;align-items:center}
.hero-grid > *{min-width:0}

.eyebrow{
    display:inline-flex;align-items:center;gap:10px;
    padding:7px 14px;border-radius:999px;
    background:#fff;border:1px solid var(--border-strong);
    box-shadow:var(--shadow-sm);
    font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
    color:var(--brand-2);
}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--brand-1);box-shadow:0 0 10px rgba(29,163,200,0.55);animation:pulse 2.2s var(--ease) infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(.9)}}

h1{
    font-family:'Bricolage Grotesque','Manrope',sans-serif;
    font-size:clamp(30px,4.4vw,56px);font-weight:600;letter-spacing:-0.025em;
    line-height:1.05;margin:22px 0 22px;color:var(--text);
}
h1 .grad{
    background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent;
    background-size:200% 200%;animation:hue 8s var(--ease) infinite;
}
@keyframes hue{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

.type-cursor{
    display:inline-block;
    width:3px;height:0.85em;
    margin:0 4px -2px 6px;
    background:linear-gradient(180deg,#1da3c5,#0e6a8e);
    border-radius:2px;vertical-align:baseline;
    animation:typeBlink .9s steps(1) infinite;
}
@keyframes typeBlink{0%,49%{opacity:1}50%,100%{opacity:0}}
.type-target{white-space:nowrap}
h1 .type-line{display:block;white-space:nowrap;min-height:1lh;overflow:hidden}

.lead{
    color:var(--text-soft);font-size:clamp(16px,1.3vw,18px);
    max-width:560px;margin-bottom:34px;
    font-weight:500;
}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:38px}
.hero-meta{
    display:flex;align-items:center;gap:24px;
    color:var(--text);font-size:14px;font-weight:600;
}
.hero-meta strong{color:var(--text);font-weight:800}

.store-badges{display:flex;gap:14px;margin-top:24px;flex-wrap:wrap}
.store-badge{
    display:inline-flex;align-items:center;gap:12px;
    padding:10px 18px;border-radius:14px;
    background:var(--brand-3);
    color:#fff;text-decoration:none;
    transition:transform .25s var(--ease), box-shadow .25s var(--ease);
    min-width:160px;
    border:1px solid rgba(255,255,255,0.16);
    box-shadow:0 10px 26px -10px rgba(0,0,0,0.45), inset 0 0 0 1px rgba(255,255,255,0.06);
}
.store-badge:hover{transform:translateY(-2px);box-shadow:0 14px 28px -10px rgba(8,40,68,0.30)}
.store-badge svg{flex-shrink:0;color:#fff}
.store-badge span{display:flex;flex-direction:column;line-height:1.1}
.store-badge small{
    font-size:10px;letter-spacing:0.04em;text-transform:uppercase;
    color:rgba(255,255,255,0.78);font-weight:500;
}
.store-badge strong{font-size:16px;font-weight:600;letter-spacing:-0.01em}

.avatars{display:flex}
.avatars span{
    width:34px;height:34px;border-radius:50%;border:2px solid var(--bg-0);
    margin-left:-10px;background:var(--grad-brand);
    display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff;
}
.avatars span:first-child{margin-left:0}
.avatars span:nth-child(2){background:linear-gradient(135deg,#1da3c5,#0e6a8e)}
.avatars span:nth-child(3){background:linear-gradient(135deg,#0e6a8e,#082848)}
.avatars span:nth-child(4){background:linear-gradient(135deg,#082848,#1da3c5)}

.phone-stage{position:relative;height:720px;z-index:10;display:flex;align-items:center;justify-content:center}
.phone{
    position:relative;
    will-change:transform;
    aspect-ratio:378/659;
}
.phone img{width:100%;height:100%;object-fit:contain;display:block}
.phone.p1{
    width:78%;max-width:420px;z-index:3;
    animation:floatA 6.5s ease-in-out infinite;
}
@keyframes floatA{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

/* Hero — iframe-based live phone (mirrors .showcase-visual but sized
   to fit the 720px hero phone-stage). Shares the .phone-frame /
   .phone-screen bezel styles defined further down and the phoneFloat
   keyframe used in the showcase. */
.hero-phone{
    position:relative;
    width:72%;max-width:332px;z-index:3;
    aspect-ratio:9/19.5;
    animation:phoneFloat 7s ease-in-out infinite;
    will-change:transform;
}
.hero-phone::before{content:"";display:block;padding-top:216.667%}
@supports (aspect-ratio: 9/19.5){
    .hero-phone::before{display:none}
}

.hero-fade-up{
    opacity:0;
    translate:0 80px;
    transition:opacity 1.1s var(--ease), translate 1.1s var(--ease);
}
.hero-fade-up.in{opacity:1;translate:0 0}

section{padding:110px 0;position:relative}
.section-head{text-align:center;max-width:720px;margin:0 auto 56px}
.section-head .eyebrow{margin-bottom:18px}
.section-head h2{
    font-family:'Bricolage Grotesque','Manrope',sans-serif;
    font-size:clamp(28px,3.6vw,46px);font-weight:600;letter-spacing:-0.025em;line-height:1.08;
    color:var(--text);
}
.section-head h2 .grad{background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent}
.section-head p{color:var(--muted);margin-top:16px;font-size:17px}

section.tinted{background:var(--bg-1)}

.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.feature{
    position:relative;padding:34px 30px;border-radius:var(--radius-lg);
    background:#fff;border:1px solid var(--border);
    perspective:1400px;transform-style:preserve-3d;
    transform:perspective(1400px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateZ(0);
    transition:transform .5s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease);
    will-change:transform;
    box-shadow:var(--shadow-sm);
}
.feature:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md)}
.feature::before{
    content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
    background:var(--grad-brand);
    -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
    -webkit-mask-composite:xor;mask-composite:exclude;
    opacity:0;transition:opacity .35s var(--ease);
    pointer-events:none;transform:translateZ(1px);
}
.feature:hover::before{opacity:1}

.card-spot{
    position:absolute;inset:0;border-radius:inherit;
    background:radial-gradient(380px circle at var(--mx,50%) var(--my,50%), rgba(29,163,200,0.12), transparent 50%);
    opacity:0;transition:opacity .35s var(--ease);
    pointer-events:none;transform:translateZ(2px);
}
.feature:hover .card-spot,
.step:hover .card-spot{opacity:1}

.feature .icon{
    width:52px;height:52px;border-radius:14px;display:grid;place-items:center;
    background:var(--grad-soft);border:1px solid var(--border-strong);margin-bottom:20px;
    color:var(--brand-2);
    transform:translateZ(50px);
    transition:transform .5s var(--ease), box-shadow .35s var(--ease);
}
.feature h3{
    font-family:'Bricolage Grotesque','Manrope',sans-serif;
    font-size:19px;font-weight:600;margin-bottom:10px;letter-spacing:-0.01em;
    color:var(--text);
    transform:translateZ(34px);position:relative;
}
.feature p{
    color:var(--muted);font-size:15px;line-height:1.6;
    transform:translateZ(18px);position:relative;
}

@media (hover: none){
    .feature{perspective:none;transform:none}
    .feature .icon,.feature h3,.feature p{transform:none}
}

#showcase{
    background:linear-gradient(180deg, var(--bg-1) 0%, var(--bg-0) 100%);
}
.showcase{
    display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:center;
}
.showcase-media{position:relative;width:100%;display:flex;justify-content:center;align-items:center;padding:20px 0}
.showcase-visual{
    position:relative;
    width:82%;max-width:350px;
    aspect-ratio:9/19.5;
    animation:phoneFloat 7s ease-in-out infinite;
    will-change:transform;
}
.showcase-visual::before{
    content:"";display:block;padding-top:216.667%;
}
@supports (aspect-ratio: 9/19.5){
    .showcase-visual::before{display:none}
}
.showcase-visual img{
    position:absolute;inset:0;width:100%;height:100%;
    object-fit:contain;display:block;
}

.phone-frame{
    position:absolute;inset:0;
    border-radius:14% / 6.5%;
    background:
        linear-gradient(135deg,
            #4a4d52 0%,
            #2c2f35 18%,
            #16181d 50%,
            #2a2d33 82%,
            #3a3d42 100%);
    padding:9px;
    box-shadow:
        inset 0 1.5px 0 rgba(255,255,255,0.22),
        inset 0 -1px 0 rgba(255,255,255,0.06),
        inset 2px 0 0 rgba(255,255,255,0.08),
        inset -2px 0 0 rgba(255,255,255,0.05),
        inset 0 0 0 9px #07090c,
        0 50px 80px -32px rgba(0,0,0,0.55),
        0 30px 50px -28px rgba(8,40,68,0.50);
}
.phone-screen{
    position:relative;width:100%;height:100%;
    border-radius:11.5% / 5.3%;
    overflow:hidden;background:#000;
    isolation:isolate;
    -webkit-overflow-scrolling:touch;
}
.phone-screen iframe{
    display:block;
    width:1px;min-width:100%;
    height:1px;min-height:100%;
    border:0;background:#fff;
}
.phone-island{
    position:absolute;top:1.6%;left:50%;transform:translateX(-50%);
    width:33%;height:3.6%;
    background:#000;border-radius:999px;
    z-index:3;pointer-events:none;
    box-shadow:
        inset 0 0 4px rgba(0,0,0,0.95),
        0 0 0 0.5px rgba(255,255,255,0.05);
}
.phone-btn{
    position:absolute;width:3px;
    background:linear-gradient(90deg,#3a3d42,#1a1d22 50%,#0c0e12);
    border-radius:1.5px;z-index:0;
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.10);
}
.phone-btn.left{left:-2px}
.phone-btn.right{right:-2px}
.btn-action{top:13%;height:3.6%}
.btn-vol-up{top:20%;height:7%}
.btn-vol-down{top:29%;height:7%}
.btn-power{top:21%;height:13%}
@keyframes phoneFloat{
    0%,100%{transform:translateY(0)}
    50%{transform:translateY(-14px)}
}
.showcase h2{
    font-family:'Bricolage Grotesque','Manrope',sans-serif;
    font-size:clamp(28px,3.4vw,42px);
    font-weight:600;line-height:1.08;letter-spacing:-0.025em;margin-bottom:18px;
    color:var(--text);
}
.showcase h2 .grad{background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent}
.showcase p.lead{font-size:17px;margin-bottom:28px}

.check-list{
    display:grid;gap:12px;margin-bottom:28px;list-style:none;
}
.check-list li{
    position:relative;
    display:flex;align-items:center;gap:14px;
    padding:14px 18px;
    border-radius:14px;
    background:#fff;
    border:1px solid var(--border);
    color:var(--text-soft);font-size:15px;line-height:1.45;
    transition:border-color .3s var(--ease), box-shadow .3s var(--ease), transform .3s var(--ease);
    box-shadow:var(--shadow-sm);
}
.check-list li:hover{
    border-color:var(--border-strong);
    box-shadow:var(--shadow-md);
    transform:translateY(-1px);
}
.check-list .tick{
    flex:0 0 32px;width:32px;height:32px;border-radius:50%;
    display:grid;place-items:center;
    background:var(--grad-brand);
    color:#fff;font-size:14px;font-weight:700;
    box-shadow:0 6px 14px -4px rgba(14,106,142,0.45);
}

.steps-grid{
    display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:step;
    perspective:1400px;
}
.step{
    padding:74px 24px 26px;border-radius:var(--radius-lg);
    background:#fff;border:1px solid var(--border);
    position:relative;counter-increment:step;
    transform-style:preserve-3d;
    transform:rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateZ(0);
    transition:transform .5s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease);
    will-change:transform;
    box-shadow:var(--shadow-sm);
}
.step::after{
    content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
    background:var(--grad-brand);
    -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
    -webkit-mask-composite:xor;mask-composite:exclude;
    opacity:0;transition:opacity .35s var(--ease);
    pointer-events:none;transform:translateZ(1px);
}
.step:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md)}
.step:hover::after{opacity:1}
.step::before{
    content:"0" counter(step);
    position:absolute;top:22px;left:24px;
    font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:28px;
    background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent;
    transform:translateZ(28px);
}
.step .step-icon{
    position:absolute;top:18px;right:20px;
    width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
    background:var(--grad-soft);color:var(--brand-2);border:1px solid var(--border-strong);
    transform:translateZ(38px);
}
.step h4{
    font-family:'Bricolage Grotesque','Manrope',sans-serif;
    font-size:18px;font-weight:600;margin:0 0 8px;letter-spacing:-0.01em;
    color:var(--text);
    transform:translateZ(22px);position:relative;
}
.step p{
    color:var(--muted);font-size:14px;
    transform:translateZ(12px);position:relative;
}
@media (hover: none){
    .step{perspective:none;transform:none}
    .step h4,.step p,.step::before,.step .step-icon{transform:none}
}

.forms{
    padding-top:0;
    background-color:var(--section-bg-fallback);
    background-image:
        var(--grad-section-bg),
        url('../images/mesh-bg-light.webp');
    background-size:cover, cover;
    background-position:center top, center top;
    background-repeat:no-repeat, no-repeat;
}
.forms-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:30px}
.forms-stack{display:flex;flex-direction:column;gap:30px;max-width:760px;margin:0 auto}

/* Two-column split: supporting info on the left + form card on the right */
.forms-split{
    display:grid;grid-template-columns:0.9fr 1.1fr;gap:56px;
    align-items:start;max-width:1180px;margin:0 auto;
}
.forms-info{position:sticky;top:100px}

/* Benefit bullets (Section 1) */
.benefits{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:24px}
.benefits li{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:start;list-style:none}
.benefit-icon{
    width:42px;height:42px;border-radius:12px;
    display:grid;place-items:center;flex-shrink:0;
    background:rgba(29,163,200,0.12);color:var(--brand-2);
}
.benefit-text h4{
    font-family:'Bricolage Grotesque','Manrope',sans-serif;
    font-size:17px;font-weight:600;color:var(--text);margin:0 0 6px;letter-spacing:-0.01em;
}
.benefit-text p{font-size:14.5px;color:var(--muted);margin:0;line-height:1.6}

/* Trust badge under benefits */
.trust-badge{
    display:flex;align-items:center;gap:12px;
    margin-top:32px;padding:16px 18px;border-radius:14px;
    background:#fff;border:1px solid var(--border);
    box-shadow:0 12px 30px -16px rgba(8,40,68,0.12);
}
.trust-badge svg{flex-shrink:0;color:var(--brand-2)}
.trust-badge span{color:var(--text-soft);font-weight:500;font-size:13.5px;line-height:1.45}

/* Contact methods (Section 2) */
.contact-methods{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:16px}
.contact-methods li{
    display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:center;list-style:none;
    padding:18px 22px;border-radius:14px;
    background:#fff;border:1px solid var(--border);
    box-shadow:0 10px 24px -16px rgba(8,40,68,0.10);
    transition:transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
}
.contact-methods li:hover{
    transform:translateY(-2px);
    border-color:var(--border-strong);
    box-shadow:0 18px 36px -18px rgba(8,40,68,0.18);
}
.method-icon{
    width:44px;height:44px;border-radius:12px;
    display:grid;place-items:center;flex-shrink:0;
    background:var(--grad-brand);color:#fff;
    box-shadow:0 8px 18px -8px rgba(14,106,142,0.45);
}
.method-text h4{
    font-family:'Bricolage Grotesque','Manrope',sans-serif;
    font-size:12px;font-weight:700;color:var(--text-soft);margin:0 0 3px;
    text-transform:uppercase;letter-spacing:.08em;
}
.method-text p,
.method-text a{
    font-size:15.5px;font-weight:600;color:var(--text);margin:0;
    text-decoration:none;line-height:1.4;
}
.method-text a:hover{color:var(--brand-2)}

/* Section 1 (forms-pro): give the previously zero top-padding some breathing room */
.forms-pro{padding-top:80px}

/* Section 2 (forms-contact): own light->deep navy gradient so it reads as a distinct band. */
.forms-contact{
    padding:90px 0;
    background-color:var(--section-bg-fallback);
    background-image:
        var(--grad-section-bg),
        url('../images/mesh-bg-light.webp');
    background-size:cover, cover;
    background-position:center top, center top;
    background-repeat:no-repeat, no-repeat;
}

/* Contact Form 7 — match the .form-card / .field design */
.form-card .wpcf7{margin:0}
.form-card .wpcf7 form{margin:0}
.form-card .wpcf7 p{margin:0 0 14px}
.form-card .wpcf7-form-control-wrap{display:block;position:relative}
.form-card .wpcf7 label{
    display:block;font-size:13px;font-weight:600;
    color:var(--text-soft);margin-bottom:8px;letter-spacing:.02em;
}
.form-card .wpcf7-form-control:not(.wpcf7-submit):not(.wpcf7-acceptance):not(.wpcf7-radio):not(.wpcf7-checkbox):not(.wpcf7-list-item){
    width:100%;padding:14px 16px;border-radius:12px;
    background:var(--bg-1);
    border:1px solid var(--border);
    color:var(--text);font-size:15px;font-family:inherit;
    transition:border-color .25s var(--ease), background .25s var(--ease), box-shadow .25s var(--ease);
}
.form-card .wpcf7 textarea{resize:vertical;min-height:120px}
.form-card .wpcf7 input:focus,
.form-card .wpcf7 select:focus,
.form-card .wpcf7 textarea:focus{
    outline:none;border-color:var(--brand-1);
    background:#fff;
    box-shadow:0 0 0 4px rgba(29,163,200,0.15);
}
.form-card .wpcf7 input::placeholder,
.form-card .wpcf7 textarea::placeholder{color:#94a3b8}

/* Two-column rows via wrapper class added in CF7 markup */
.form-card .wpcf7 .cf7-row-2{
    display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;
}
.form-card .wpcf7 .cf7-row-2 > p{margin:0}

/* Submit button — match .btn .btn-primary used elsewhere.
   !important is used because CF7 + browser defaults on input[type="submit"]
   and the .submitting / :disabled states often override custom backgrounds. */
.form-card .wpcf7 input[type="submit"],
.form-card .wpcf7 button[type="submit"],
.form-card .wpcf7 .wpcf7-submit{
    -webkit-appearance:none !important;appearance:none !important;
    display:inline-block !important;width:100% !important;
    padding:15px 22px !important;font-size:16px !important;font-weight:600 !important;
    margin-top:8px !important;cursor:pointer !important;
    border-radius:12px !important;border:none !important;
    color:#fff !important;
    background:var(--grad-brand) !important;
    background-color:#0e6a8e !important;
    text-shadow:none !important;line-height:1.2 !important;
    transition:transform .2s var(--ease), box-shadow .2s var(--ease), filter .2s var(--ease) !important;
}
.form-card .wpcf7 input[type="submit"]:hover,
.form-card .wpcf7 button[type="submit"]:hover,
.form-card .wpcf7 .wpcf7-submit:hover{
    filter:brightness(1.05);transform:translateY(-1px);
    box-shadow:0 12px 24px -10px rgba(14,106,142,0.35);
}
.form-card .wpcf7 input[type="submit"]:disabled,
.form-card .wpcf7 .wpcf7-submit:disabled,
.form-card .wpcf7-form.submitting input[type="submit"],
.form-card .wpcf7-form.submitting .wpcf7-submit{
    opacity:.75;cursor:wait;
    color:#fff !important;
    background:var(--grad-brand) !important;
    background-color:#0e6a8e !important;
}

/* CF7 status / response messages */
.form-card .wpcf7-response-output{
    margin:18px 0 0 !important;padding:14px 16px !important;border-radius:12px !important;
    font-size:14px;font-weight:500;border:1px solid transparent !important;
}
.form-card .wpcf7-mail-sent-ok .wpcf7-response-output{
    background:rgba(29,163,200,0.10) !important;border-color:rgba(29,163,200,0.35) !important;color:var(--brand-2) !important;
}
.form-card .wpcf7-mail-sent-ng .wpcf7-response-output,
.form-card .wpcf7-validation-errors .wpcf7-response-output,
.form-card .wpcf7-acceptance-missing .wpcf7-response-output,
.form-card .wpcf7-invalid .wpcf7-response-output{
    background:rgba(220,38,38,0.08) !important;border-color:rgba(220,38,38,0.35) !important;color:#b91c1c !important;
}
.form-card .wpcf7-not-valid-tip{
    color:#b91c1c;font-size:12px;margin-top:6px;display:block;
}
.form-card .wpcf7-spinner{margin:0 0 0 10px;vertical-align:middle}
.form-card{
    position:relative;padding:42px;border-radius:24px;
    background:#fff;
    border:1px solid var(--border);
    overflow:hidden;
    box-shadow:var(--shadow-md);
}
.form-card.waitlist{
    background:
        radial-gradient(500px 280px at 100% 0%, rgba(29,163,200,0.12), transparent 60%),
        radial-gradient(500px 280px at 0% 100%, rgba(14,106,142,0.08), transparent 60%),
        #fff;
    border-color:var(--border-strong);
}
.form-card h3{
    font-family:'Bricolage Grotesque','Manrope',sans-serif;
    font-size:clamp(22px,2.2vw,30px);font-weight:600;letter-spacing:-0.02em;margin-bottom:10px;
    color:var(--text);
}
.form-card p.sub{color:var(--muted);margin-bottom:26px;font-size:15px}
.form-row{display:grid;gap:14px;margin-bottom:14px}
.form-row.cols-2{grid-template-columns:1fr 1fr}
.field{position:relative}
.field label{
    display:block;font-size:13px;font-weight:600;
    color:var(--text-soft);margin-bottom:8px;letter-spacing:.02em;
}
.field input,.field select,.field textarea{
    width:100%;padding:14px 16px;border-radius:12px;
    background:var(--bg-1);
    border:1px solid var(--border);
    color:var(--text);font-size:15px;font-family:inherit;
    transition:border-color .25s var(--ease), background .25s var(--ease), box-shadow .25s var(--ease);
}
.field textarea{resize:vertical;min-height:120px}
.field input:focus,.field select:focus,.field textarea:focus{
    outline:none;border-color:var(--brand-1);
    background:#fff;
    box-shadow:0 0 0 4px rgba(29,163,200,0.15);
}
.field input::placeholder,.field textarea::placeholder{color:#94a3b8}
.form-card .btn{width:100%;justify-content:center;padding:15px 22px;font-size:16px;margin-top:8px}
.form-note{margin-top:14px;font-size:13px;color:var(--muted);text-align:center}
.success-msg{
    display:none;margin-top:16px;padding:14px 16px;border-radius:12px;
    background:rgba(29,163,200,0.10);border:1px solid rgba(29,163,200,0.35);
    color:var(--brand-2);font-size:14px;font-weight:500;
}
.success-msg.show{display:block;animation:fadeIn .35s var(--ease)}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

.stats{
    position:relative;
    display:grid;grid-template-columns:repeat(4,1fr);gap:30px;
    padding:50px 40px;border-radius:24px;
    background:
        radial-gradient(700px 360px at 80% 0%, rgba(29,163,200,0.14), transparent 65%),
        radial-gradient(520px 320px at 0% 100%, rgba(125,233,255,0.12), transparent 60%),
        linear-gradient(180deg, #ffffff 0%, #f6fbfd 100%);
    color:var(--text);
    border:1px solid var(--border);
    box-shadow:0 30px 60px -28px rgba(8,40,68,0.18);
    overflow:hidden;
    isolation:isolate;
}
.stats::before{
    content:"";position:absolute;inset:0;border-radius:inherit;
    background:radial-gradient(700px 360px at 70% 0%, rgba(29,163,200,0.10), transparent 65%);
    pointer-events:none;z-index:-1;
}
.stat .num{
    font-family:'Bricolage Grotesque','Manrope',sans-serif;
    font-size:clamp(28px,3vw,42px);font-weight:700;
    background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.stat .lbl{color:var(--muted);font-size:14px;margin-top:6px}

footer{
    position:relative;padding:80px 0 40px;
    border-top:1px solid var(--border);
    background:var(--bg-1);
}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;margin-bottom:50px}
.foot-brand .logo{margin-bottom:18px}
.foot-brand .logo img{height:48px;width:auto}
.foot-brand p{color:var(--text-soft);font-size:14px;line-height:1.6;max-width:320px}
.foot-col h5{
    position:relative;
    font-family:'Bricolage Grotesque','Manrope',sans-serif;
    font-size:13px;text-transform:uppercase;letter-spacing:.14em;
    color:var(--brand-3);margin-bottom:20px;font-weight:700;
    padding-bottom:10px;
}
.foot-col h5::after{
    content:"";position:absolute;left:0;bottom:0;
    width:28px;height:2px;border-radius:2px;background:var(--grad-brand);
}
footer ul{list-style:none;display:grid;gap:12px;margin:0;padding:0}
footer ul li{list-style:none}
footer ul a{
    color:var(--text-soft);font-size:14.5px;font-weight:500;
    transition:color .2s var(--ease), transform .2s var(--ease);
    display:inline-block;
}
footer ul a:hover{color:var(--brand-2);transform:translateX(3px)}
.socials{display:flex;gap:10px;margin-top:20px}
.socials a{
    width:38px;height:38px;border-radius:10px;display:grid;place-items:center;
    background:#fff;border:1px solid var(--border);transition:all .25s var(--ease);
    color:var(--text-soft);
}
.socials a:hover{background:var(--grad-brand);border-color:transparent;transform:translateY(-3px);color:#fff}
.foot-bot{
    display:flex;justify-content:space-between;align-items:center;padding-top:24px;
    border-top:1px solid var(--border);color:var(--text-soft);font-size:13px;flex-wrap:wrap;gap:14px;
}

/* Inner pages (page.php / single.php / 404 / index list) */
.page-section{padding:140px 0 80px;background:var(--bg-1)}
.page-section .page-title{
    font-family:'Bricolage Grotesque','Manrope',sans-serif;
    font-size:clamp(28px,3vw,40px);font-weight:600;letter-spacing:-0.02em;color:var(--text);
}
.page-section .page-thumb{margin:22px 0;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-md)}
.page-section .page-content{font-size:16px;line-height:1.7;color:var(--text-soft);max-width:780px;margin:0 auto}
.page-section .page-content p{margin:0 0 1em}
.page-section .page-content h2,.page-section .page-content h3{font-family:'Bricolage Grotesque','Manrope',sans-serif;color:var(--text);margin:1.4em 0 .6em}
.page-section .post-list{display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:32px}
.page-section .post-card{padding:24px;border-radius:18px;background:#fff;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.page-section .post-card .post-title a{color:var(--text);font-weight:600}
.page-section .post-card .post-meta{color:var(--muted);font-size:13px;margin:8px 0 12px}
.page-section .post-card .post-thumb img{border-radius:12px;margin-bottom:14px}
.pagination{margin-top:32px;display:flex;justify-content:center;gap:8px}
.pagination .page-numbers{padding:8px 14px;border-radius:8px;background:#fff;border:1px solid var(--border);color:var(--text-soft);font-weight:600}
.pagination .page-numbers.current{background:var(--grad-brand);color:#fff;border-color:transparent}
.search-form{display:flex;gap:8px;max-width:560px;margin:0 auto}
.search-form .search-field{flex:1;padding:14px 16px;border-radius:12px;border:1px solid var(--border);background:#fff}

.reveal{opacity:0;translate:0 24px;transition:opacity .8s var(--ease), translate .8s var(--ease)}
.reveal.in{opacity:1;translate:0 0}
.reveal-d1{transition-delay:.08s}
.reveal-d2{transition-delay:.16s}
.reveal-d3{transition-delay:.24s}
.reveal-d4{transition-delay:.32s}

.step.reveal{
    opacity:0;translate:0 36px;scale:0.96;
    transition:opacity .7s var(--ease), translate .7s var(--ease), scale .7s var(--ease);
}
.step.reveal.in{opacity:1;translate:0 0;scale:1}
.step.reveal{transition-delay:0ms}
.step.reveal.reveal-d1{transition-delay:140ms}
.step.reveal.reveal-d2{transition-delay:280ms}
.step.reveal.reveal-d3{transition-delay:420ms}

@media (max-width: 980px){
    .container{padding:0 20px}
    .nav-inner{height:112px}
    /* Force the responsive height so the inline style="height:48px"
       emitted by header.php (Customizer setting) doesn't keep the logo
       artificially small on tablets. The nav height above gives the
       logo breathing room top/bottom. */
    .logo img{height:100px !important;max-height:100px;width:auto !important}
    .hero{padding:132px 0 60px}
    .hero-grid{grid-template-columns:1fr;gap:30px}
    .phone-stage{
        position:relative;height:auto;width:100%;
        display:flex;justify-content:center;align-items:center;padding:20px 0;
    }
    .phone{
        position:relative;
        width:auto;height:auto;
        flex:0 0 auto;
    }
    .phone.p1{width:62%;max-width:340px;aspect-ratio:378/659}
    .phone img{width:100%;height:100%;object-fit:contain;object-position:top center}
    .hero-phone{width:64%;max-width:300px}
    .features-grid{grid-template-columns:repeat(2,1fr);gap:20px}
    .feature{padding:30px 26px}
    .steps-grid{grid-template-columns:repeat(2,1fr)}
    .showcase{grid-template-columns:1fr;gap:40px}
    .showcase-media{padding:30px 0}
    .showcase-visual{width:84%;max-width:336px}
    .forms-grid{grid-template-columns:1fr}
    .forms-split{grid-template-columns:1fr;gap:36px;max-width:760px}
    .forms-info{position:static;top:auto}
    .form-card .wpcf7 .cf7-row-2{grid-template-columns:1fr}
    .forms-pro{padding-top:60px}
    .forms-contact{padding:60px 0}
    .foot-grid{
        grid-template-columns:1fr 1fr 1fr;
        grid-template-areas:
            "brand brand brand"
            "prod  comp  legal";
        gap:32px 28px;
    }
    .foot-brand{grid-area:brand;max-width:520px}
    .foot-col-product{grid-area:prod}
    .foot-col-company{grid-area:comp}
    .foot-col-legal{grid-area:legal}
    body > .nav-links{
        display:flex !important;
        position:fixed;inset:112px 0 0 0;
        background:#ffffff;
        flex-direction:column;justify-content:flex-start;align-items:flex-start;
        gap:0;padding:30px 20px;
        z-index:99999;
        transform:translateX(100%);
        transition:transform .35s var(--ease);
        pointer-events:none;
        box-shadow:-12px 0 30px -12px rgba(8,40,68,0.15);
    }
    body > .nav-links.open{transform:translateX(0);pointer-events:auto}
    .nav-links a:not(.btn){padding:18px 0;border-bottom:1px solid var(--border);width:100%;font-size:18px;color:var(--text)}
    .nav-links .btn{margin-top:14px;width:100%;justify-content:center}
    .nav-links a.btn-primary{color:#fff}
    .nav-links ul{flex-direction:column;width:100%;gap:0}
    .menu-toggle{display:flex !important;position:relative;z-index:61}
    .stats{grid-template-columns:repeat(2,1fr);padding:36px 24px}
    section{padding:90px 0}
    .section-head{margin-bottom:48px}
}

@media (max-width: 580px){
    .container{padding:0 18px}
    .logo img{height:88px !important;max-height:88px;width:auto !important}
    .nav-inner{height:100px}
    .nav-links{inset:100px 0 0 0}
    section{padding:70px 0}
    .hero{padding:120px 0 40px}
    .eyebrow{font-size:11px;padding:6px 12px}
    .lead{font-size:15px}
    .hero-cta{flex-direction:column;width:100%}
    .hero-cta .btn{width:100%;justify-content:center}
    .features-grid{grid-template-columns:1fr;gap:16px}
    .feature{padding:28px 24px}
    .feature .icon{width:48px;height:48px;margin-bottom:18px}
    .feature h3{font-size:18px;margin-bottom:10px}
    .feature p{font-size:14.5px}
    .steps-grid{grid-template-columns:1fr;gap:14px}
    .step{padding:70px 22px 24px}
    .step::before{font-size:24px;top:20px;left:22px}
    .step .step-icon{width:38px;height:38px;top:18px;right:18px}
    .form-row.cols-2{grid-template-columns:1fr}
    .form-card{padding:26px 22px;border-radius:22px}
    .form-card h3{font-size:22px}
    .foot-grid{
        grid-template-columns:1fr 1fr;
        grid-template-areas:
            "brand brand"
            "prod  comp"
            "legal legal";
        gap:30px 24px;
        margin-bottom:36px;
    }
    .foot-col h5{font-size:12px;margin-bottom:16px;padding-bottom:8px}
    footer ul{gap:10px}
    footer ul a{font-size:14px}
    .foot-bot{flex-direction:column;align-items:flex-start;gap:8px;text-align:left}
    .stats{grid-template-columns:repeat(2,1fr);gap:18px;padding:28px 20px}
    .phone.p1{width:70%;max-width:300px;margin:0}
    .hero-phone{width:72%;max-width:280px;margin:0}
    .hero-meta{flex-direction:column;align-items:flex-start;gap:14px}
    .check-list li{padding:12px 14px;font-size:14px}
    .check-list .tick{width:30px;height:30px;flex-basis:30px}
}

@media (max-width: 400px){
    .container{padding:0 14px}
    .nav-inner{height:122px}
    .nav-links{inset:122px 0 0 0}
    .logo img{height:110px !important;max-height:110px;width:auto !important}
    .hero{padding:142px 0 32px}
    section{padding:60px 0}
    .hero-meta{font-size:13px}
    .phone.p1{width:78%;max-width:260px;margin:0}
    .hero-phone{width:80%;max-width:250px;margin:0}
    .features-grid,.steps-grid{gap:14px}
    .feature{padding:24px 20px}
    .step{padding:64px 20px 22px}
    .form-card{padding:22px 18px}
}

/* Section gradients pull from CSS variables computed in functions.php from
   the Customizer Colour scheme / brand pickers, so switching the scheme
   recolours every section automatically. Mesh image preserved underneath. */
section.tinted,
#showcase{
    background-color:var(--section-bg-fallback);
    background-image:
        var(--grad-section-bg),
        url('../images/mesh-bg-light.webp');
    background-size:cover, cover;
    background-position:center top, center top;
    background-repeat:no-repeat, no-repeat;
}

/* Footer: also driven by the Colour scheme. The overlay is darker so
   light text and links remain legible at every palette. */
footer{
    background-color:var(--brand-3);
    background-image:
        var(--grad-footer-bg),
        url('../images/mesh-bg-light.webp');
    background-size:cover, cover;
    background-position:center top, center top;
    background-repeat:no-repeat, no-repeat;
    border-top-color:rgba(255,255,255,0.10);
    color:#e8f1f7;
}
/* Convert the logo to a clean white silhouette so it pops on the dark footer. */
footer .foot-brand .logo img{
    filter:brightness(0) invert(1);
    opacity:.95;
    height:52px;
}
footer .foot-brand p{color:rgba(230,241,247,0.85)}
footer .foot-col h5{color:#ffffff}
footer .foot-col h5::after{background:linear-gradient(90deg,#7dc8de,#1da3c5)}
footer ul a{color:rgba(230,241,247,0.78)}
footer ul a:hover{color:#ffffff}
footer .socials a{
    background:rgba(255,255,255,0.08);
    border-color:rgba(255,255,255,0.18);
    color:#e6f1f7;
}
footer .socials a:hover{background:var(--grad-brand);border-color:transparent;color:#fff}
footer .foot-bot{
    border-top-color:rgba(255,255,255,0.12);
    color:rgba(230,241,247,0.72);
}

@media (prefers-reduced-motion: reduce){
    *{animation:none !important;transition:none !important}
}
