/* ===================================================
   AD-APT DESIGN SYSTEM
   Taste-skill + Minimalist-skill hybrid
   =================================================== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Brand */
  --green:#27b36e;--green-soft:#e8f7ef;--green-deep:#1a8a50;--green-muted:#1d7a4e;
  --blue:#1b6ea0;--blue-soft:#e4f0f8;--blue-deep:#145a82;--blue-muted:#1a5f8a;
  --accent:#1b6ea0;--accent-soft:#e4f0f8;--accent-muted:#1a5f8a;
  --grad:linear-gradient(135deg,#1b6ea0 0%,#22a06a 50%,#27b36e 100%);

  /* Pastels */
  --rose-soft:#fdebec;--rose-muted:#9f2f2d;
  --amber-soft:#fbf3db;--amber-muted:#956400;

  /* Neutrals */
  --canvas:#fafaf8;--surface:#f7f6f3;--card:#ffffff;
  --ink:#1c1c1a;--ink-secondary:#52524e;--ink-tertiary:#9b9b97;--ink-faint:#c8c8c4;
  --border:rgba(0,0,0,0.06);--border-solid:#eaeae6;

  /* Layout */
  --radius:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;
  --max:1280px;
  --ease:cubic-bezier(0.16,1,0.3,1);

  /* Fonts */
  --serif:'Instrument Serif','Playfair Display','Georgia',serif;
  --sans:'Outfit','SF Pro Display','Helvetica Neue',sans-serif;
  --body:'Source Sans 3','Outfit',system-ui,sans-serif;
  --mono:'JetBrains Mono','SF Mono',monospace;
}

html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--canvas);line-height:1.7;font-size:17px;overflow-x:hidden;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5{font-family:var(--serif)}
nav,button,.btn,.eyebrow,.nav-logo,.trait,.metric-label,.testi-name,.footer-logo,.step-num,.badge,.svc-link,.btn-white,.form-submit,.result-label{font-family:var(--sans)}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}


/* ----- AMBIENT BACKGROUND ----- */
.ambient{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:0;overflow:hidden}
.ambient-blob{position:absolute;border-radius:50%;filter:blur(120px);opacity:0.035;animation:drift 25s ease-in-out infinite alternate}
.ambient-blob.a{width:600px;height:600px;background:#1b6ea0;top:-10%;left:-5%}
.ambient-blob.b{width:500px;height:500px;background:#27b36e;bottom:-15%;right:-8%;animation-delay:-12s;animation-direction:alternate-reverse}
@keyframes drift{0%{transform:translate(0,0) scale(1)}50%{transform:translate(40px,30px) scale(1.1)}100%{transform:translate(-20px,60px) scale(0.95)}}


/* ----- SKIP LINK ----- */
.skip{position:absolute;top:-100px;left:16px;background:var(--ink);color:#fff;padding:8px 16px;border-radius:var(--radius);z-index:999;font-size:14px;transition:top .2s}
.skip:focus{top:12px}


/* ----- NAV ----- */
nav{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(250,250,248,0.88);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}
.nav-inner{max-width:var(--max);margin:0 auto;padding:0 clamp(20px,4vw,48px);display:flex;align-items:center;justify-content:space-between;height:60px}
.nav-logo{display:flex;align-items:center}
.nav-logo img{height:30px;width:auto}
.nav-links{display:flex;align-items:center;gap:28px;list-style:none}
.nav-links a{font-size:13px;font-weight:500;color:var(--ink-secondary);transition:color .3s var(--ease);letter-spacing:.2px;font-family:var(--sans)}
.nav-links a:hover{color:var(--ink)}
.nav-cta{background:var(--ink);color:var(--canvas)!important;padding:7px 18px;border-radius:var(--radius);font-size:12px!important;font-weight:600!important;letter-spacing:.3px;transition:all .3s var(--ease)}
.nav-cta:hover{background:var(--green)}
.nav-cta:active{transform:scale(0.97)}
.mob-btn{display:none;background:none;border:none;cursor:pointer;padding:8px}
.mob-btn svg{width:22px;height:22px;stroke:var(--ink-secondary);stroke-width:1.5;fill:none}


/* ----- SHARED TYPOGRAPHY ----- */
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:600;letter-spacing:1.4px;text-transform:uppercase;color:var(--green-muted);margin-bottom:28px;font-family:var(--sans)}
.eyebrow::before{content:'';width:24px;height:1.5px;background:var(--green)}
h1{font-size:clamp(44px,5.5vw,72px);line-height:1.02;font-weight:400;letter-spacing:-1.5px;color:var(--ink)}
h1 em{color:var(--green);font-style:italic}
h2{font-size:clamp(32px,3.8vw,52px);font-weight:400;letter-spacing:-1px;line-height:1.08;color:var(--ink);margin-bottom:20px}
h2 em{color:var(--green);font-style:italic}
h3{font-family:var(--sans);font-size:16px;font-weight:700;letter-spacing:-.2px}
h4{font-family:var(--sans);font-size:14px;font-weight:700}
.s-dark h2{color:#fff}


/* ----- BUTTONS ----- */
.btn-row{display:flex;gap:12px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:var(--radius);font-size:14px;font-weight:600;cursor:pointer;border:none;transition:all .35s var(--ease);letter-spacing:.2px;font-family:var(--sans)}
.btn:active{transform:translateY(1px) scale(0.97)}
.btn-dark{background:var(--ink);color:var(--canvas)}
.btn-dark:hover{background:var(--green)}
.btn-outline{background:transparent;color:var(--ink-secondary);border:1.5px solid var(--border-solid)}
.btn-outline:hover{border-color:var(--ink);color:var(--ink)}
.btn svg{width:15px;height:15px;stroke:currentColor;stroke-width:2;fill:none}
.btn-white{background:var(--canvas);color:var(--ink);padding:10px 22px;border-radius:var(--radius);font-size:13px;font-weight:700;transition:all .3s var(--ease);white-space:nowrap;display:inline-flex;align-items:center;gap:6px;border:none;cursor:pointer;letter-spacing:.2px;font-family:var(--sans)}
.btn-white:hover{background:var(--green);color:#fff}
.btn-white:active{transform:scale(0.97)}
.btn-white svg{width:13px;height:13px;stroke:currentColor;stroke-width:2;fill:none}


/* ----- SECTION UTILITIES ----- */
.s{position:relative;z-index:1;max-width:var(--max);margin:0 auto;padding:clamp(72px,9vw,140px) clamp(20px,4vw,48px)}
.s-alt{background:var(--surface);border-top:1px solid var(--border-solid);border-bottom:1px solid var(--border-solid)}
.s-dark{background:var(--ink)}
.s-green{background:var(--grad)}


/* ----- BADGES ----- */
.badge{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius);padding:4px 12px;font-size:12px;font-weight:500;color:var(--ink-tertiary);font-family:var(--sans);transition:border-color .3s var(--ease)}
.badge:hover{border-color:var(--ink-faint)}


/* ----- PILLAR CARDS ----- */
.pillar-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.pillar{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-md);padding:24px;transition:all .45s var(--ease)}
.pillar:hover{border-color:var(--green);box-shadow:0 12px 40px -12px rgba(26,138,92,0.07)}
.p-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.p-icon svg{width:18px;height:18px;stroke-width:1.5;fill:none}
.p-icon.g{background:var(--green-soft)}
.p-icon.g svg{stroke:var(--green-muted)}
.p-icon.b{background:var(--accent-soft)}
.p-icon.b svg{stroke:var(--accent-muted)}
.pillar h4{margin-bottom:5px;color:var(--ink)}
.pillar p{font-size:13px;color:var(--ink-secondary);line-height:1.6}


/* ----- SERVICE CARDS ----- */
.svc-head{max-width:540px;margin-bottom:56px}
.svc-head p{color:var(--ink-secondary);font-size:17px;margin-top:14px;line-height:1.7}
.svc-grid{display:grid;grid-template-columns:7fr 5fr;gap:12px}
.svc-grid>*:nth-child(even){transform:translateY(20px)}
.svc{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-lg);padding:clamp(24px,3vw,36px);transition:all .45s var(--ease);position:relative;overflow:hidden}
.svc::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--green);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.svc:hover::before{transform:scaleX(1)}
.svc:hover{box-shadow:0 16px 48px -12px rgba(0,0,0,0.06)}
.svc-i{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.svc-i svg{width:20px;height:20px;stroke-width:1.5;fill:none}
.svc-i.g{background:var(--green-soft)}
.svc-i.g svg{stroke:var(--green-muted)}
.svc-i.b{background:var(--accent-soft)}
.svc-i.b svg{stroke:var(--accent-muted)}
.svc-i.r{background:var(--rose-soft)}
.svc-i.r svg{stroke:var(--rose-muted)}
.svc-i.a{background:var(--amber-soft)}
.svc-i.a svg{stroke:var(--amber-muted)}
.svc h3{font-family:var(--sans);margin-bottom:8px}
.svc p{font-size:14px;color:var(--ink-secondary);line-height:1.65;max-width:380px}
.svc-link{display:inline-flex;align-items:center;gap:5px;margin-top:16px;font-size:12px;font-weight:600;color:var(--green);letter-spacing:.3px;transition:gap .3s var(--ease)}
.svc-link:hover{gap:10px}
.svc-link svg{width:13px;height:13px;stroke:currentColor;stroke-width:2;fill:none}


/* ----- ONIT BANNER ----- */
.onit{grid-column:1/-1;background:var(--ink);border:1px solid rgba(255,255,255,0.06);border-radius:var(--radius-lg);padding:clamp(28px,3vw,44px);display:flex;align-items:center;justify-content:space-between;gap:32px;transform:translateY(0)!important;margin-top:8px;position:relative;overflow:hidden}
.onit::before{content:'';position:absolute;top:-50%;right:-10%;width:300px;height:300px;background:var(--green);border-radius:50%;filter:blur(100px);opacity:0.08}
.onit h3{color:#fff;font-family:var(--serif);font-size:22px;font-weight:400;letter-spacing:-.3px;margin-bottom:8px}
.onit p{color:rgba(255,255,255,0.5);font-size:14px;max-width:480px;line-height:1.7}


/* ----- PROCESS STEPS ----- */
.proc-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:56px;position:relative}
.proc-steps::before{content:'';position:absolute;top:20px;left:calc(16.67% + 20px);right:calc(16.67% + 20px);height:1px;background:var(--border-solid)}
.step{padding:0 clamp(8px,2vw,28px)}
.step-num{width:40px;height:40px;border-radius:50%;background:var(--card);border:1.5px solid var(--border-solid);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--green);margin-bottom:24px;position:relative;z-index:1;transition:all .3s var(--ease)}
.step:hover .step-num{border-color:var(--green);box-shadow:0 0 0 4px var(--green-soft)}
.step h3{font-family:var(--sans);font-size:15px;margin-bottom:8px}
.step p{font-size:14px;color:var(--ink-secondary);line-height:1.7}


/* ----- RESULTS (DARK) ----- */
.res-inner{max-width:var(--max);margin:0 auto;padding:clamp(72px,9vw,140px) clamp(20px,4vw,48px)}
.res-head{max-width:480px;margin-bottom:56px}
.res-head .eyebrow{color:var(--green)}
.res-head h2{color:#fff}
.res-head p{color:rgba(255,255,255,0.4);font-size:16px;margin-top:12px;line-height:1.7}
.res-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:rgba(255,255,255,0.06);border-radius:var(--radius-md);overflow:hidden}
.res-cell{background:var(--ink);padding:clamp(28px,3vw,48px)}
.res-num{font-family:var(--mono);font-size:clamp(32px,3.5vw,48px);font-weight:500;color:var(--green);letter-spacing:-2px;line-height:1}
.res-num span{font-size:0.55em;opacity:0.7}
.result-label{font-size:14px;font-weight:700;color:#fff;margin:12px 0 8px;letter-spacing:.2px}
.res-desc{font-size:13px;color:rgba(255,255,255,0.35);line-height:1.65}


/* ----- TESTIMONIALS ----- */
.testi-layout{display:grid;grid-template-columns:4fr 8fr;gap:clamp(40px,5vw,80px);align-items:start}
.testi-stack{display:flex;flex-direction:column;gap:12px}
.tc{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-md);padding:28px;transition:all .45s var(--ease)}
.tc:hover{box-shadow:0 8px 32px -8px rgba(0,0,0,0.05)}
.tc.feat{background:var(--ink);border-color:rgba(255,255,255,0.06)}
.tc.feat .tq{color:rgba(255,255,255,0.75)}
.tc.feat .testi-name{color:#fff}
.tc.feat .testi-role{color:rgba(255,255,255,0.35)}
.tc.feat .stars svg{fill:var(--green)}
.stars{display:flex;gap:2px;margin-bottom:14px}
.stars svg{width:13px;height:13px;fill:var(--green);stroke:none}
.tq{font-size:15px;line-height:1.75;color:var(--ink-secondary);font-style:italic}
.ta{margin-top:16px;padding-top:14px;border-top:1px solid var(--border-solid)}
.tc.feat .ta{border-color:rgba(255,255,255,0.08)}
.testi-name{font-weight:700;font-size:13px;color:var(--ink)}
.testi-role{font-size:12px;color:var(--ink-tertiary);margin-top:1px}


/* ----- CTA BAND ----- */
.cta{position:relative;z-index:1;overflow:hidden}
.cta-inner{max-width:var(--max);margin:0 auto;padding:clamp(56px,7vw,100px) clamp(20px,4vw,48px);display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap}
.cta h2{color:#fff;font-family:var(--serif);font-size:clamp(28px,3.2vw,42px);letter-spacing:-.5px;max-width:480px;line-height:1.08;font-weight:400}
.cta p{color:rgba(255,255,255,0.6);margin-top:12px;font-size:15px}
.cta-btns{display:flex;gap:12px;flex-wrap:wrap}
.btn-cta-w{background:var(--canvas);color:var(--green-deep);padding:12px 26px;border-radius:var(--radius);font-size:14px;font-weight:700;font-family:var(--sans);border:none;cursor:pointer;transition:all .3s var(--ease);letter-spacing:.2px}
.btn-cta-w:hover{background:var(--ink);color:#fff}
.btn-cta-w:active{transform:scale(0.97)}
.btn-cta-o{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,0.25);padding:12px 26px;border-radius:var(--radius);font-size:14px;font-weight:600;font-family:var(--sans);cursor:pointer;transition:all .3s var(--ease);letter-spacing:.2px}
.btn-cta-o:hover{border-color:#fff;background:rgba(255,255,255,0.06)}


/* ----- CONTACT FORM ----- */
.contact-grid{display:grid;grid-template-columns:5fr 7fr;gap:clamp(40px,5vw,80px);align-items:start}
.contact-info p{color:var(--ink-secondary);margin-bottom:32px;max-width:360px;line-height:1.7}
.ci-list{display:flex;flex-direction:column;gap:14px}
.ci{display:flex;align-items:center;gap:14px;font-size:14px;color:var(--ink-secondary)}
.ci-icon{width:36px;height:36px;background:var(--green-soft);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ci-icon svg{width:16px;height:16px;stroke:var(--green-muted);stroke-width:1.5;fill:none}
.ci a{color:var(--ink-secondary);transition:color .2s}
.ci a:hover{color:var(--green)}
.form-card{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-lg);padding:clamp(24px,3vw,36px)}
.fg{margin-bottom:18px}
.fg label{display:block;font-size:12px;font-weight:600;font-family:var(--sans);margin-bottom:5px;color:var(--ink-secondary);letter-spacing:.3px}
.fg input,.fg select,.fg textarea{width:100%;border:1.5px solid var(--border-solid);border-radius:var(--radius);padding:11px 14px;font-size:14px;font-family:var(--body);color:var(--ink);background:var(--canvas);transition:border-color .3s var(--ease),box-shadow .3s var(--ease);outline:none}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px var(--green-soft)}
.fg textarea{resize:vertical;min-height:100px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-submit{width:100%;background:var(--ink);color:var(--canvas);border:none;padding:13px;border-radius:var(--radius);font-size:14px;font-weight:700;font-family:var(--sans);cursor:pointer;transition:all .3s var(--ease);letter-spacing:.2px}
.form-submit:hover{background:var(--green)}
.form-submit:active{transform:translateY(1px) scale(0.97)}
.form-success{display:none;background:var(--green-soft);border:1px solid var(--green);border-radius:var(--radius);padding:14px 18px;font-size:14px;color:var(--green-deep);font-family:var(--sans);font-weight:600;margin-top:12px}
.form-error{display:none;background:#fdebec;border:1px solid #f5c2c3;border-radius:var(--radius);padding:14px 18px;font-size:14px;color:#9f2f2d;font-family:var(--sans);margin-top:12px}


/* ----- ONIT LOCKUP (sister brand) ----- */
.onit-lockup{display:inline-flex;align-items:center;gap:10px;line-height:1}
.onit-lockup-icon{width:28px;height:28px;flex-shrink:0}
.onit-wordmark{font-family:'Unbounded',var(--sans);font-weight:800;font-size:22px;letter-spacing:-.5px;display:inline-flex;align-items:baseline;color:#F5F5F5}
.onit-dot{display:inline-block;width:5px;height:5px;border-radius:50%;margin-left:2px;background:#3B82F6;animation:f1a 1.8s ease-in-out infinite;animation-delay:.15s}
.onit-lockup-lg .onit-lockup-icon{width:40px;height:40px}
.onit-lockup-lg .onit-wordmark{font-size:32px}
.onit-lockup-lg .onit-dot{width:7px;height:7px}
@keyframes f1a{0%,100%{opacity:1}15%{opacity:.5}40%{opacity:.9}60%{opacity:.6}80%{opacity:1}}
@keyframes f1b{0%,100%{opacity:.8}20%{opacity:1}50%{opacity:.4}75%{opacity:.9}}
@keyframes f1c{0%,100%{opacity:.6}25%{opacity:1}55%{opacity:.7}80%{opacity:.3}}

/* ----- FOOTER (3-col, with Onit cross-sell) ----- */
footer{background:var(--ink);padding:64px 0 32px;color:rgba(255,255,255,0.4);position:relative;z-index:1}
.footer-inner{max-width:var(--max);margin:0 auto;padding:0 clamp(20px,4vw,48px)}
.footer-3col{display:grid;grid-template-columns:4fr 4fr 5fr;gap:clamp(32px,5vw,72px);margin-bottom:48px}
.footer-contact h4,.footer-nav h4{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:1.2px;color:rgba(255,255,255,0.55);text-transform:uppercase;margin-bottom:16px}
.footer-contact p{color:rgba(255,255,255,0.75);font-size:14px;line-height:1.8;margin-bottom:4px}
.footer-contact p.brand{color:#fff;font-weight:700;font-family:var(--sans);margin-bottom:10px}
.footer-contact a{color:rgba(255,255,255,0.55);font-size:14px;transition:color .2s;display:block;line-height:1.8}
.footer-contact a:hover{color:#fff}
.footer-nav a{display:block;font-size:14px;color:rgba(255,255,255,0.55);margin-bottom:10px;transition:color .2s}
.footer-nav a:hover{color:#fff}
.footer-onit{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08);border-radius:var(--radius-lg);padding:clamp(24px,3vw,32px);position:relative;overflow:hidden}
.footer-onit::before{content:'';position:absolute;top:-40%;right:-10%;width:200px;height:200px;background:#3B82F6;border-radius:50%;filter:blur(80px);opacity:0.18}
.footer-onit-label{font-family:var(--mono);font-size:10px;letter-spacing:1px;color:rgba(255,255,255,0.5);text-transform:uppercase;margin-bottom:12px;position:relative}
.footer-onit p{color:rgba(255,255,255,0.6);font-size:13px;line-height:1.7;margin-bottom:14px;position:relative}
.footer-onit a.onit-link{display:inline-flex;align-items:center;gap:6px;font-family:'Outfit',var(--sans);font-size:13px;font-weight:600;color:#3B82F6;position:relative;transition:gap .3s var(--ease)}
.footer-onit a.onit-link:hover{gap:10px;color:#fff}
.footer-onit a.onit-link svg{width:13px;height:13px;stroke:currentColor;stroke-width:2;fill:none}
.footer-bottom-strip{border-top:1px solid rgba(255,255,255,0.06);padding-top:24px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;font-family:var(--mono);font-size:11px;color:rgba(255,255,255,0.35);letter-spacing:.3px}
.footer-bottom-strip .footer-links a{color:rgba(255,255,255,0.35);font-family:var(--mono);font-size:11px;margin-left:16px;transition:color .2s}
.footer-bottom-strip .footer-links a:hover{color:#fff}
@media(max-width:900px){.footer-3col{grid-template-columns:1fr;gap:36px}}


/* ----- SCROLL REVEALS ----- */
.rv{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv.vis{opacity:1;transform:translateY(0)}
.rv-d1{transition-delay:.1s}
.rv-d2{transition-delay:.2s}
.rv-d3{transition-delay:.3s}


/* ----- HERO VISUAL (index only) ----- */
.vis-canvas{width:100%;aspect-ratio:1/1;border-radius:var(--radius-xl);background:var(--ink);position:relative;overflow:hidden;border:1px solid rgba(255,255,255,0.06)}
.vis-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.04) 1px,transparent 1px);background-size:40px 40px;animation:gridShift 20s linear infinite}
@keyframes gridShift{to{background-position:40px 40px}}
.vis-orb{position:absolute;border-radius:50%;filter:blur(60px)}
.vis-orb.o1{width:220px;height:220px;background:#1b6ea0;opacity:0.25;top:15%;left:20%;animation:orbFloat 12s ease-in-out infinite alternate}
.vis-orb.o2{width:180px;height:180px;background:#27b36e;opacity:0.2;bottom:20%;right:15%;animation:orbFloat 15s ease-in-out infinite alternate-reverse}
.vis-orb.o3{width:120px;height:120px;background:#fff;opacity:0.06;top:50%;left:55%;animation:orbFloat 10s ease-in-out infinite alternate}
@keyframes orbFloat{0%{transform:translate(0,0)}100%{transform:translate(20px,-30px)}}
.vis-particle{position:absolute;width:3px;height:3px;background:rgba(255,255,255,0.3);border-radius:50%;animation:particlePulse 3s ease-in-out infinite}
@keyframes particlePulse{0%,100%{opacity:0.2;transform:scale(1)}50%{opacity:0.7;transform:scale(1.5)}}
.vis-metrics{position:absolute;bottom:24px;left:24px;right:24px;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,0.08);border-radius:var(--radius-md);overflow:hidden}
.vm{background:rgba(12,12,13,0.85);backdrop-filter:blur(12px);padding:16px 18px}
.vm-label{font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-bottom:4px}
.vm-val{font-family:var(--mono);font-size:22px;font-weight:500;color:var(--green);letter-spacing:-1px;line-height:1.2}
.vm-sub{font-size:11px;color:rgba(255,255,255,0.3);margin-top:2px;font-family:var(--sans)}
.vis-tag{position:absolute;top:24px;left:24px;background:rgba(12,12,13,0.7);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,0.08);border-radius:var(--radius);padding:6px 12px;font-family:var(--mono);font-size:11px;color:rgba(255,255,255,0.5);letter-spacing:.5px}
.vis-tag .dot{display:inline-block;width:6px;height:6px;background:var(--green);border-radius:50%;margin-right:6px;animation:blink 2s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}


/* ----- BLOG ----- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.blog-card{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-lg);overflow:hidden;transition:all .45s var(--ease)}
.blog-card:hover{box-shadow:0 16px 48px -12px rgba(0,0,0,0.06);transform:translateY(-2px)}
.blog-card-img{aspect-ratio:16/9;background:var(--surface);overflow:hidden}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.blog-card:hover .blog-card-img img{transform:scale(1.04)}
.blog-card-body{padding:24px}
.blog-meta{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.blog-tag{font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--green);font-family:var(--sans)}
.blog-date{font-size:11px;color:var(--ink-tertiary);font-family:var(--sans)}
.blog-card h3{font-size:17px;font-weight:400;line-height:1.35;margin-bottom:8px;color:var(--ink);font-family:var(--serif)}
.blog-card p{font-size:13px;color:var(--ink-secondary);line-height:1.65}
.blog-read{display:inline-flex;align-items:center;gap:5px;margin-top:16px;font-size:12px;font-weight:600;color:var(--green);font-family:var(--sans);transition:gap .3s var(--ease)}
.blog-read:hover{gap:10px}
.blog-read svg{width:12px;height:12px;stroke:currentColor;stroke-width:2;fill:none}


/* ----- FOCUS RAIL (3D Carousel) ----- */
.rail-wrap{position:relative;width:100%;overflow:hidden;background:var(--ink);user-select:none;-webkit-user-select:none}
.rail-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.rail-bg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:blur(60px) saturate(1.8);opacity:0;transition:opacity .8s ease-out}
.rail-bg img.active{opacity:.35}
.rail-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,var(--ink),rgba(28,28,26,.5),transparent)}

.rail-stage{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;padding:clamp(48px,7vw,96px) 16px clamp(40px,5vw,72px)}

.rail-track{position:relative;width:100%;max-width:1200px;height:380px;perspective:1200px;cursor:grab;touch-action:pan-y}
.rail-track:active{cursor:grabbing}

.rail-card{position:absolute;left:50%;top:50%;width:260px;aspect-ratio:3/4;border-radius:var(--radius-lg);overflow:hidden;background:rgba(28,28,26,.9);border-top:1px solid rgba(255,255,255,.15);box-shadow:0 24px 64px -16px rgba(0,0,0,.5);will-change:transform,opacity,filter;transition:transform .55s cubic-bezier(.16,1,.3,1),opacity .55s cubic-bezier(.16,1,.3,1),filter .55s cubic-bezier(.16,1,.3,1);transform-style:preserve-3d;pointer-events:none}
.rail-card.center{z-index:20;pointer-events:auto}
.rail-card:not(.center){z-index:10;cursor:pointer;pointer-events:auto}
.rail-card img{width:100%;height:100%;object-fit:cover;pointer-events:none}
.rail-card::after{content:'';position:absolute;inset:0;border-radius:var(--radius-lg);background:linear-gradient(to bottom,rgba(255,255,255,.08),transparent);pointer-events:none}

@media(min-width:640px){.rail-card{width:300px}}

.rail-info{position:relative;z-index:2;width:100%;max-width:960px;margin-top:clamp(32px,4vw,56px);display:flex;flex-direction:column;align-items:center;gap:24px}
@media(min-width:768px){.rail-info{flex-direction:row;justify-content:space-between;align-items:flex-end}}

.rail-text{text-align:center;min-height:100px;display:flex;flex-direction:column;justify-content:center}
@media(min-width:768px){.rail-text{text-align:left}}
.rail-meta{font-size:11px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;color:var(--green);font-family:var(--sans);margin-bottom:8px;opacity:0;transform:translateY(6px);transition:opacity .3s,transform .3s}
.rail-title{font-family:var(--serif);font-size:clamp(24px,3.2vw,40px);font-weight:400;color:#fff;letter-spacing:-.5px;line-height:1.1;opacity:0;transform:translateY(6px);transition:opacity .3s .05s,transform .3s .05s}
.rail-desc{font-size:15px;color:rgba(255,255,255,.45);max-width:440px;margin-top:8px;line-height:1.65;opacity:0;transform:translateY(6px);transition:opacity .3s .1s,transform .3s .1s}
.rail-text.in .rail-meta,.rail-text.in .rail-title,.rail-text.in .rail-desc{opacity:1;transform:translateY(0)}

.rail-controls{display:flex;align-items:center;gap:16px;flex-shrink:0}
.rail-nav{display:flex;align-items:center;gap:1px;background:rgba(255,255,255,.06);border-radius:999px;padding:3px;border:1px solid rgba(255,255,255,.08)}
.rail-btn{background:none;border:none;color:rgba(255,255,255,.45);padding:10px;border-radius:50%;cursor:pointer;transition:background .2s,color .2s;display:flex;align-items:center;justify-content:center}
.rail-btn:hover{background:rgba(255,255,255,.1);color:#fff}
.rail-btn:active{transform:scale(.92)}
.rail-btn svg{width:18px;height:18px;stroke:currentColor;stroke-width:2;fill:none}
.rail-counter{font-family:var(--mono);font-size:12px;color:rgba(255,255,255,.3);min-width:40px;text-align:center}
.rail-explore{display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--ink);padding:11px 22px;border-radius:var(--radius);font-size:13px;font-weight:700;font-family:var(--sans);border:none;cursor:pointer;transition:transform .25s var(--ease);letter-spacing:.2px;text-decoration:none}
.rail-explore:hover{transform:scale(1.04)}
.rail-explore:active{transform:scale(.96)}
.rail-explore svg{width:14px;height:14px;stroke:currentColor;stroke-width:2;fill:none;transition:transform .25s var(--ease)}
.rail-explore:hover svg{transform:translate(2px,-2px)}


/* ----- RESPONSIVE ----- */
@media(max-width:900px){
  .hero{grid-template-columns:1fr;gap:48px;min-height:auto;padding-top:100px;padding-bottom:56px}
  .intro-grid,.contact-grid,.testi-layout{grid-template-columns:1fr;gap:40px}
  .svc-grid{grid-template-columns:1fr}
  .svc-grid>*:nth-child(even){transform:none}
  .res-grid{grid-template-columns:1fr}
  .proc-steps{grid-template-columns:1fr;gap:36px}
  .proc-steps::before{display:none}
  .pillar-grid,.trait-grid{grid-template-columns:1fr}
  .onit{flex-direction:column;align-items:flex-start}
  .cta-inner{flex-direction:column;text-align:center;align-items:center}
  .cta-btns{justify-content:center}
  .form-row{grid-template-columns:1fr}
  .nav-links{display:none}
  .mob-btn{display:block}
  .vis-canvas{aspect-ratio:4/3}
  .blog-grid{grid-template-columns:1fr}
}
