/*
Theme Name: Neotoro Technology
Theme URI: https://neotorotech.com/
Author: Neotoro Technology
Author URI: https://neotorotech.com/
Description: Premium nearshore agency theme with scroll animations, light/dark theme and custom post types (Services, Case Studies, Industries). Single-page hero design ported to a full multi-page WordPress theme.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: neotoro
Tags: custom-post-types, dark-mode, animations, agency, business
*/

/* ============================================================
   NEOTORO TECHNOLOGY — Premium WordPress theme 2026
   ============================================================ */

:root{
  /* ---- brand constants (theme-independent) ---- */
  --grad: linear-gradient(120deg,#6e7bf0 0%,#9b6dfb 48%,#f5a9ce 100%);
  --amber: #ffce6b;
  --radius: 20px;
  --radius-sm: 14px;
  --maxw: 1760px;
  --ease: cubic-bezier(.22,1,.36,1);

  /* ---- DARK theme (default) ---- */
  --bg:#0a0a14; --bg-soft:#0e1020; --surface:#14152b; --surface-2:#1a1c38;
  --line:rgba(255,255,255,.09); --line-soft:rgba(255,255,255,.05); --line-hover:rgba(255,255,255,.2);
  --txt:#f4f5fc; --txt-soft:#a7a9c6; --txt-mute:#6b6d8e;
  --violet:#7c8bf5; --violet-2:#a78bfa; --cyan:#8ea2ff;
  --grad-text:linear-gradient(110deg,#aab6ff 0%,#bfa6ff 42%,#f7bcd8 100%);
  --glass:rgba(20,21,42,.66); --glass-brd:rgba(255,255,255,.10);
  --nav-bg:rgba(10,10,20,.72);
  --ghost-bg:rgba(255,255,255,.05); --ghost-bd:rgba(255,255,255,.12);
  --ic-bg:linear-gradient(140deg,rgba(124,139,245,.22),rgba(245,169,206,.14));
  --cta-bg:linear-gradient(140deg,#16183a,#0d1430);
  --on-accent:#0c1030;
  --shadow:0 30px 80px -34px rgba(0,0,0,.8);
  --card-shadow:0 1px 0 rgba(255,255,255,.03) inset, 0 14px 34px -26px rgba(0,0,0,.7);
  --card-shadow-h:0 1px 0 rgba(255,255,255,.06) inset, 0 30px 60px -28px rgba(0,0,0,.85);
  --glow-col:rgba(124,139,245,.14);
  --mesh-op:1;
  color-scheme:dark;
}
html[data-theme="light"]{
  --bg:#f5f6fe; --bg-soft:#eaedfb; --surface:#ffffff; --surface-2:#f3f4fd;
  --line:rgba(24,26,53,.10); --line-soft:rgba(24,26,53,.055); --line-hover:rgba(24,26,53,.22);
  --txt:#171935; --txt-soft:#565b7e; --txt-mute:#8c91b3;
  --violet:#6e7bf0; --violet-2:#9b6dfb; --cyan:#6e7bf0;
  --grad-text:linear-gradient(110deg,#5d6fe6 0%,#9b6dfb 48%,#e07cbb 100%);
  --glass:rgba(255,255,255,.74); --glass-brd:rgba(24,26,53,.08);
  --nav-bg:rgba(245,246,254,.8);
  --ghost-bg:rgba(24,26,53,.04); --ghost-bd:rgba(24,26,53,.12);
  --ic-bg:linear-gradient(140deg,rgba(110,123,240,.16),rgba(245,169,206,.22));
  --cta-bg:linear-gradient(140deg,#edf0ff,#fceff7);
  --on-accent:#14163a;
  --shadow:0 30px 70px -36px rgba(70,80,160,.4);
  --card-shadow:0 2px 4px -2px rgba(70,80,160,.1), 0 14px 30px -16px rgba(70,80,160,.2);
  --card-shadow-h:0 4px 8px -3px rgba(70,80,160,.14), 0 30px 50px -20px rgba(80,70,170,.3);
  --glow-col:rgba(155,109,251,.12);
  --mesh-op:.5;
  color-scheme:light;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}

/* ---------- smooth theme switch ---------- */
@property --bd-angle{syntax:'<angle>';inherits:false;initial-value:0deg}
html.theme-anim, html.theme-anim *, html.theme-anim *::before, html.theme-anim *::after{
  transition:background-color .5s var(--ease), border-color .5s var(--ease),
    color .5s var(--ease), fill .45s var(--ease), stroke .45s var(--ease),
    box-shadow .5s var(--ease), opacity .5s var(--ease) !important;
}
::view-transition-old(root),::view-transition-new(root){animation-duration:.5s;animation-timing-function:cubic-bezier(.22,1,.36,1)}

/* ---------- focus-visible (a11y) ---------- */
:focus{outline:none}
:focus-visible{outline:2px solid var(--violet);outline-offset:3px;border-radius:6px}
.btn:focus-visible,.theme-toggle:focus-visible,.burger:focus-visible{outline-offset:4px}
.field input:focus-visible,.field textarea:focus-visible{outline:none}

body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--bg);
  color:var(--txt);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* ---------- scrollbar ---------- */
::-webkit-scrollbar{width:11px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:linear-gradient(var(--violet),var(--cyan));border-radius:10px;border:3px solid var(--bg)}
::selection{background:var(--violet);color:#fff}

h1,h2,h3,h4{font-family:'Space Grotesk',sans-serif;line-height:1.08;letter-spacing:-.022em;font-weight:600;text-wrap:balance}
p{text-wrap:pretty}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block;height:auto}

.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(22px,4.5vw,72px)}
.wrap-narrow{max-width:1280px}

.mono{font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--cyan)}

.grad-text{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- WP screen-reader text ---------- */
.screen-reader-text{border:0;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;word-wrap:normal!important}
.skip-link{position:absolute;left:-9999px;z-index:999;padding:12px 20px;background:var(--surface);border:1px solid var(--line);border-radius:10px}
.skip-link:focus{left:16px;top:16px}

/* ---------- top progress bar ---------- */
.progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:200;background:var(--grad);box-shadow:0 0 12px var(--violet)}

/* ---------- cursor glow (desktop) ---------- */
.glow{position:fixed;width:520px;height:520px;border-radius:50%;pointer-events:none;z-index:0;
  background:radial-gradient(circle,var(--glow-col),transparent 60%);
  transform:translate(-50%,-50%);transition:opacity .4s;opacity:0;will-change:transform}

/* ============================================================ NAV */
header.site-header{position:fixed;top:0;left:0;width:100%;z-index:100;transition:all .4s var(--ease);padding:18px 0}
header.site-header.scrolled{padding:10px 0;background:var(--nav-bg);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:13px}
.logo-mark{width:50px;height:50px;object-fit:contain;flex:none;
  filter:drop-shadow(0 5px 16px rgba(124,139,245,.5));transition:transform .45s var(--ease)}
.logo:hover .logo-mark{transform:scale(1.07) rotate(-4deg)}
.logo-wm{display:flex;flex-direction:column;line-height:1;font-family:'Space Grotesk'}
.logo-wm b{font-weight:700;font-size:1.4rem;letter-spacing:.004em;color:var(--txt)}
.logo-wm i{font-style:normal;font-size:.64rem;font-weight:500;letter-spacing:.4em;color:var(--txt-mute);margin-top:5px}
header.site-header.scrolled .logo-mark{width:44px;height:44px}
header.site-header.scrolled .logo-wm b{font-size:1.28rem}

.nav-links{display:flex;align-items:center;gap:34px;list-style:none;margin:0;padding:0}
.nav-links li{position:relative}
.nav-links a{font-size:.92rem;color:var(--txt-soft);transition:color .25s;position:relative;font-weight:500;display:inline-block}
.nav-links>li>a::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--grad);transition:width .3s var(--ease)}
.nav-links a:hover{color:var(--txt)}
.nav-links>li>a:hover::after,.nav-links>li.current-menu-item>a::after,.nav-links>li.current_page_item>a::after{width:100%}
.nav-links li.current-menu-item>a,.nav-links li.current_page_item>a{color:var(--txt)}

/* sub-menus */
.nav-links ul.sub-menu{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);min-width:210px;
  background:var(--glass);backdrop-filter:blur(16px);border:1px solid var(--glass-brd);border-radius:14px;padding:10px;
  list-style:none;box-shadow:var(--shadow);opacity:0;visibility:hidden;transition:.3s var(--ease);z-index:120}
.nav-links li:hover>ul.sub-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-links ul.sub-menu li{display:block}
.nav-links ul.sub-menu a{display:block;padding:9px 13px;border-radius:9px;font-size:.9rem;transition:.25s}
.nav-links ul.sub-menu a:hover{background:var(--surface-2);color:var(--txt)}
.nav-links ul.sub-menu a::after{display:none}

.btn{display:inline-flex;align-items:center;gap:9px;font-family:'Space Grotesk';font-weight:600;font-size:.92rem;
  padding:13px 26px;border-radius:100px;cursor:pointer;border:none;transition:all .35s var(--ease);position:relative;overflow:hidden;white-space:nowrap}
.btn-primary{background:var(--grad);color:var(--on-accent);background-size:160% 160%}
.btn-primary:hover{background-position:100% 0;transform:translateY(-2px);box-shadow:0 14px 36px -10px rgba(124,139,245,.6)}
.btn-ghost{background:var(--ghost-bg);color:var(--txt);border:1px solid var(--ghost-bd)}
.btn-ghost:hover{background:var(--surface-2);border-color:var(--violet);transform:translateY(-2px)}
.btn svg{width:16px;height:16px}

.theme-toggle{position:relative;width:42px;height:42px;border-radius:50%;border:1px solid var(--line);
  background:var(--ghost-bg);color:var(--txt);cursor:pointer;display:grid;place-items:center;transition:.3s var(--ease);flex:none}
.theme-toggle:hover{border-color:var(--violet);transform:translateY(-2px);box-shadow:0 8px 22px -10px var(--violet)}
.theme-toggle:active{transform:scale(.9)}
.theme-toggle svg{position:absolute;width:19px;height:19px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:opacity .35s,transform .45s var(--ease)}
html[data-theme="dark"] .ico-sun{opacity:1;transform:rotate(0)}
html[data-theme="dark"] .ico-moon{opacity:0;transform:rotate(-90deg)}
html[data-theme="light"] .ico-sun{opacity:0;transform:rotate(90deg)}
html[data-theme="light"] .ico-moon{opacity:1;transform:rotate(0)}

.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--txt);transition:.3s;border-radius:2px}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============================================================ HERO */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:128px 0 64px;overflow:hidden}
.mesh{position:absolute;inset:0;z-index:0;overflow:hidden;opacity:var(--mesh-op)}
.blob{position:absolute;border-radius:50%;filter:blur(90px);opacity:.5;will-change:transform}
.blob.b1{width:560px;height:560px;background:radial-gradient(circle,#6e7bf0,transparent 70%);top:-160px;right:-120px;animation:float1 16s ease-in-out infinite}
.blob.b2{width:480px;height:480px;background:radial-gradient(circle,#f5a9ce,transparent 70%);bottom:-160px;left:-120px;opacity:.34;animation:float2 19s ease-in-out infinite}
.blob.b3{width:380px;height:380px;background:radial-gradient(circle,#9b6dfb,transparent 70%);top:40%;left:45%;opacity:.22;animation:float1 22s ease-in-out infinite reverse}
@keyframes float1{0%,100%{transform:translate(0,0)}50%{transform:translate(-50px,60px)}}
@keyframes float2{0%,100%{transform:translate(0,0)}50%{transform:translate(60px,-50px)}}

.grid-bg{position:absolute;inset:0;z-index:0;opacity:.4;
  background-image:linear-gradient(var(--line-soft) 1px,transparent 1px),linear-gradient(90deg,var(--line-soft) 1px,transparent 1px);
  background-size:54px 54px;mask-image:radial-gradient(ellipse 80% 60% at 50% 40%,#000 30%,transparent 80%)}

.hero-grid{position:relative;z-index:2;width:100%;display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(40px,5vw,84px);align-items:center}
.hero-content{max-width:720px}
.badge{display:inline-flex;align-items:center;gap:9px;padding:8px 16px;border-radius:100px;border:1px solid var(--line);
  background:var(--ghost-bg);font-size:.82rem;color:var(--txt-soft);margin-bottom:30px;backdrop-filter:blur(8px)}
.badge .dot{width:7px;height:7px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px var(--cyan);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}

.hero h1{font-size:clamp(2.6rem,7vw,5.2rem);font-weight:700;margin-bottom:26px}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .line>span{display:block;transform:translateY(110%);transition:transform 1s var(--ease)}
.hero.in h1 .line:nth-child(1)>span{transition-delay:.05s}
.hero.in h1 .line:nth-child(2)>span{transition-delay:.18s}
.hero.in h1 .line:nth-child(3)>span{transition-delay:.31s}
.hero.in h1 .line>span{transform:translateY(0)}

.hero p.lead{font-size:clamp(1.05rem,2vw,1.32rem);color:var(--txt-soft);max-width:640px;margin-bottom:38px;
  opacity:0;transform:translateY(20px);transition:all .9s var(--ease) .5s}
.hero.in p.lead{opacity:1;transform:none}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;opacity:0;transform:translateY(20px);transition:all .9s var(--ease) .65s}
.hero.in .hero-cta{opacity:1;transform:none}

/* ---- hero visual: brand 3D illustration + glass micro-cards ---- */
.hero-visual{position:relative;opacity:0;transform:translateY(28px) scale(.98);transition:all 1s var(--ease) .5s;justify-self:end;width:100%;max-width:540px}
.hero.in .hero-visual{opacity:1;transform:none}
.hv-illu{position:relative;z-index:2;display:flex;justify-content:center;animation:bob 6.5s ease-in-out infinite}
.hv-illu::before{content:"";position:absolute;inset:-6% -2% 2% -2%;z-index:-1;border-radius:50%;
  background:radial-gradient(circle at 50% 42%,rgba(124,139,245,.42),rgba(245,169,206,.2) 46%,transparent 70%);filter:blur(20px)}
.hv-illu img{width:90%;max-width:420px;height:auto;filter:drop-shadow(0 40px 60px rgba(60,50,140,.4))}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

.hv-float{position:absolute;z-index:3;background:var(--glass);border:1px solid var(--glass-brd);border-radius:16px;
  padding:14px 18px;backdrop-filter:blur(14px);box-shadow:var(--shadow);animation:bob2 5s ease-in-out infinite}
.hv-float .mono{display:block;margin-bottom:3px;color:var(--txt-mute)}
.hv-float .hv-big{font-family:'Space Grotesk';font-size:1.85rem;font-weight:700;line-height:1}
.hv-float .trend{color:var(--violet-2);font-size:.76rem;display:flex;align-items:center;gap:5px;margin-top:5px}
.hv-float .hv-row{display:flex;align-items:center;gap:11px;font-weight:600;font-size:.9rem;color:var(--txt)}
.hv-float .pill{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;flex:none;background:var(--ic-bg);border:1px solid var(--glass-brd)}
.hv-float .pill svg{width:17px;height:17px;stroke:var(--violet-2)}
.hv-float.f1{top:4%;right:-7%;animation-delay:.2s}
.hv-float.f2{bottom:13%;left:-9%;animation-delay:1.6s}
@keyframes bob2{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* ============================================================ MARQUEE */
.marquee-sec{padding:clamp(30px,3.5vw,44px) 0;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);position:relative;z-index:2;background:var(--bg)}
.marquee-label{text-align:center;color:var(--txt-mute);font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;margin-bottom:24px}
.marquee{display:flex;overflow:hidden;-webkit-mask:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
  mask:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee-track{display:flex;gap:64px;padding-right:64px;animation:scroll-x 32s linear infinite;flex:none}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes scroll-x{to{transform:translateX(-50%)}}
.marquee-track span{font-family:'Space Grotesk';font-size:1.4rem;font-weight:600;color:var(--txt-mute);white-space:nowrap;
  transition:color .3s;opacity:.7}
.marquee-track span:hover{color:var(--txt);opacity:1}

/* ============================================================ SECTION SHELL */
section{position:relative}
.section{padding:clamp(58px,7.5vw,100px) 0}
.eyebrow{display:inline-flex;align-items:center;gap:10px;margin-bottom:20px}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--cyan)}
.sec-head{max-width:740px;margin-bottom:clamp(36px,4vw,52px)}
.sec-head h2{font-size:clamp(2rem,4.5vw,3.3rem);font-weight:700;margin-bottom:20px}
.sec-head p{color:var(--txt-soft);font-size:1.08rem}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head.center .eyebrow::before{display:none}

/* reveal */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.show{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}.reveal.d5{transition-delay:.4s}.reveal.d6{transition-delay:.48s}

/* ============================================================ ABOUT */
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:70px;align-items:center}
.about-copy h2{font-size:clamp(1.9rem,4vw,3rem);margin-bottom:24px}
.about-copy p{color:var(--txt-soft);margin-bottom:18px;font-size:1.05rem}
.about-copy strong{color:var(--txt)}
.stat-cards{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;position:relative;overflow:hidden;box-shadow:var(--card-shadow);transition:transform .4s var(--ease),border-color .4s,box-shadow .4s}
.stat-card::before{content:"";position:absolute;inset:0;background:var(--grad);opacity:0;transition:opacity .4s;z-index:0}
.stat-card:hover{transform:translateY(-6px);border-color:transparent;box-shadow:var(--card-shadow-h)}
.stat-card:hover::before{opacity:.08}
.stat-card .num{font-family:'Space Grotesk';font-size:2.6rem;font-weight:700;line-height:1;margin-bottom:8px;position:relative}
.stat-card .lbl{color:var(--txt-soft);font-size:.92rem;position:relative}
.stat-card.tall{grid-column:1/-1}

/* ============================================================ SERVICES */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.svc{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:36px 32px;position:relative;overflow:hidden;
  box-shadow:var(--card-shadow);transition:transform .45s var(--ease),border-color .45s,background .45s,box-shadow .45s;cursor:default;display:block}
.svc::after{content:"";position:absolute;inset:0;border-radius:inherit;padding:1.5px;pointer-events:none;z-index:1;
  background:conic-gradient(from var(--bd-angle),transparent 0deg,transparent 232deg,var(--violet-2) 286deg,#f5a9ce 318deg,var(--violet-2) 344deg,transparent 360deg);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;
  mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask-composite:exclude;
  opacity:0;transition:opacity .45s var(--ease)}
.svc:hover{transform:translateY(-8px);border-color:transparent;background:var(--surface-2);box-shadow:var(--card-shadow-h)}
.svc:hover::after{opacity:1;animation:bd-trace 2.4s linear infinite}
@keyframes bd-trace{to{--bd-angle:360deg}}
.svc .ic{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;margin-bottom:24px;
  background:var(--ic-bg);border:1px solid var(--glass-brd);transition:transform .45s var(--ease);overflow:hidden}
.svc:hover .ic{transform:scale(1.08) rotate(-4deg)}
.svc .ic svg{width:26px;height:26px;stroke:var(--cyan)}
.svc .ic img{width:100%;height:100%;object-fit:cover}
.svc h3{font-size:1.32rem;margin-bottom:13px;font-weight:600}
.svc p{color:var(--txt-soft);font-size:.96rem}
.svc .no{position:absolute;top:30px;right:32px;font-family:'JetBrains Mono';font-size:.78rem;color:var(--txt-mute)}
.svc .svc-more{margin-top:18px;display:inline-flex;align-items:center;gap:7px;font-family:'Space Grotesk';font-weight:600;font-size:.9rem;color:var(--violet-2)}
.svc .svc-more svg{width:15px;height:15px;stroke:currentColor;transition:transform .35s var(--ease)}
.svc:hover .svc-more svg{transform:translateX(4px)}

/* ============================================================ BENEFITS */
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(180px,auto);gap:18px}
.cell{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:32px;position:relative;overflow:hidden;
  box-shadow:var(--card-shadow);transition:transform .4s var(--ease),border-color .4s,box-shadow .4s;display:flex;flex-direction:column;justify-content:space-between}
.cell::after{content:"";position:absolute;inset:0;border-radius:inherit;padding:1.5px;pointer-events:none;z-index:1;
  background:conic-gradient(from var(--bd-angle),transparent 0deg,transparent 232deg,var(--violet-2) 286deg,#f5a9ce 318deg,var(--violet-2) 344deg,transparent 360deg);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;
  mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask-composite:exclude;
  opacity:0;transition:opacity .45s var(--ease)}
.cell:hover{transform:translateY(-5px);border-color:transparent;box-shadow:var(--card-shadow-h)}
.cell:hover::after{opacity:1;animation:bd-trace 2.4s linear infinite}
.cell .k{font-family:'JetBrains Mono';font-size:.74rem;color:var(--cyan);letter-spacing:.1em;margin-bottom:14px}
.cell h3{font-size:1.3rem;margin-bottom:10px}
.cell p{color:var(--txt-soft);font-size:.95rem}
.cell.big{grid-column:span 2;grid-row:span 2;background:linear-gradient(150deg,var(--surface-2),var(--surface));justify-content:flex-end}
.cell.big h3{font-size:1.9rem}
.cell.wide{grid-column:span 2}
.cell .glowring{position:absolute;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(124,139,245,.28),transparent 70%);top:-60px;right:-60px;pointer-events:none}

/* ============================================================ PROCESS */
.process{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;position:relative}
.process::before{content:"";position:absolute;top:38px;left:8%;right:8%;height:1px;
  background:linear-gradient(90deg,transparent,var(--violet),var(--cyan),transparent);z-index:0}
.step{position:relative;z-index:1;text-align:center;padding:0 10px}
.step .circle{width:76px;height:76px;border-radius:50%;margin:0 auto 26px;display:grid;place-items:center;
  background:var(--bg);border:1px solid var(--line);font-family:'Space Grotesk';font-size:1.5rem;font-weight:700;position:relative;transition:transform .4s var(--ease)}
.step .circle::before{content:"";position:absolute;inset:-1px;border-radius:50%;padding:1px;background:var(--grad);
  -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 .4s}
.step:hover .circle{transform:translateY(-6px)}
.step:hover .circle::before{opacity:1}
.step h3{font-size:1.35rem;margin-bottom:12px}
.step p{color:var(--txt-soft);font-size:.98rem;max-width:320px;margin:0 auto}

/* ============================================================ PORTFOLIO / CASE STUDIES GRID */
.port-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.proj{aspect-ratio:1/.82;border-radius:var(--radius);border:1px solid var(--line);position:relative;overflow:hidden;cursor:pointer;
  display:flex;align-items:flex-end;padding:28px;box-shadow:var(--card-shadow);transition:transform .5s var(--ease),border-color .5s,box-shadow .5s}
.proj .bgp{position:absolute;inset:0;z-index:0;transition:transform .7s var(--ease);opacity:.9;background:var(--g);background-size:cover;background-position:center}
html[data-theme="light"] .proj .bgp{background:var(--gl);background-size:cover;background-position:center;opacity:1}
.proj.has-img .bgp{opacity:1}
.proj:hover{transform:translateY(-6px);border-color:var(--line-hover);box-shadow:var(--card-shadow-h)}
.proj:hover .bgp{transform:scale(1.08)}
.proj::before{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(7,7,13,.92),rgba(7,7,13,.25) 60%,transparent);z-index:1}
html[data-theme="light"] .proj::before{background:linear-gradient(to top,rgba(255,255,255,.9),rgba(255,255,255,.3) 55%,rgba(255,255,255,.05))}
.proj .meta{position:relative;z-index:2;width:100%;display:flex;align-items:flex-end;justify-content:space-between;transform:translateY(8px);opacity:.85;transition:.4s var(--ease)}
.proj:hover .meta{transform:none;opacity:1}
.proj .meta h3{font-size:1.4rem}
.proj .meta .tag{font-family:'JetBrains Mono';font-size:.68rem;color:var(--txt-soft);text-transform:uppercase;letter-spacing:.12em}
.proj .arrow{width:40px;height:40px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;flex:none;
  background:rgba(255,255,255,.06);backdrop-filter:blur(6px);transition:.4s var(--ease)}
html[data-theme="light"] .proj .arrow{background:rgba(255,255,255,.6);border-color:rgba(24,26,53,.12)}
.proj:hover .arrow{background:var(--cyan);border-color:var(--cyan)}
.proj:hover .arrow svg{stroke:var(--on-accent);transform:rotate(0)}
.proj .arrow svg{width:16px;height:16px;stroke:var(--txt);transform:rotate(-45deg);transition:.4s}

/* ============================================================ TESTIMONIALS */
.test-wrap{position:relative}
.test-track{display:flex;gap:22px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px 2px 24px;scrollbar-width:none}
.test-track::-webkit-scrollbar{display:none}
.test{flex:0 0 clamp(300px,40vw,440px);scroll-snap-align:start;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:38px 34px;display:flex;flex-direction:column;gap:20px;box-shadow:var(--card-shadow);transition:border-color .4s,transform .4s,box-shadow .4s}
.test:hover{border-color:var(--line-hover);transform:translateY(-4px);box-shadow:var(--card-shadow-h)}
.test .stars{display:flex;gap:3px;color:var(--amber)}
.test .stars svg{width:17px;height:17px;fill:var(--amber)}
.test .quote-t{font-family:'Space Grotesk';font-size:1.18rem;font-weight:600;line-height:1.3}
.test p{color:var(--txt-soft);font-size:.98rem;flex:1}
.test .who{display:flex;align-items:center;gap:13px;padding-top:6px;border-top:1px solid var(--line-soft)}
.test .who .av{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-family:'Space Grotesk';font-weight:700;
  color:#0a0a12;flex:none;font-size:1rem}
.test .who b{display:block;font-size:.95rem;font-weight:600}
.test .who span{font-size:.82rem;color:var(--txt-mute)}
.test-nav{display:flex;gap:12px;justify-content:flex-end;margin-top:8px}
.test-nav button{width:48px;height:48px;border-radius:50%;border:1px solid var(--line);background:var(--surface);color:var(--txt);
  cursor:pointer;display:grid;place-items:center;transition:.3s}
.test-nav button:hover{background:var(--surface-2);border-color:var(--line-hover)}
.test-nav button svg{width:18px;height:18px;stroke:currentColor}

/* ============================================================ CTA */
.cta-sec{padding:clamp(50px,6vw,86px) 0}
.cta-box{position:relative;border-radius:32px;padding:clamp(40px,6vw,72px) clamp(28px,5vw,68px);overflow:hidden;
  background:var(--cta-bg);border:1px solid var(--line);text-align:center}
.cta-box .blob{opacity:.4}
.cta-box .b1{width:400px;height:400px;top:-160px;right:-80px}
.cta-box .b2{width:360px;height:360px;bottom:-160px;left:-60px;opacity:.22}
.cta-box .inner{position:relative;z-index:2;max-width:760px;margin:0 auto}
.cta-box h2{font-size:clamp(2rem,5vw,3.4rem);margin-bottom:22px;font-weight:700}
.cta-box p{color:var(--txt-soft);font-size:1.12rem;margin-bottom:38px}
.cta-box .hero-cta{justify-content:center;opacity:1;transform:none}
.cta-grid{position:relative;z-index:2;display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(20px,4vw,56px);align-items:center;text-align:left}
.cta-grid .inner{max-width:640px;margin:0;text-align:left}
.cta-grid .hero-cta{justify-content:flex-start}
.cta-mascot{display:flex;justify-content:center;position:relative}
.cta-mascot::before{content:"";position:absolute;inset:6% 4% 0 4%;z-index:0;border-radius:50%;
  background:radial-gradient(circle,rgba(124,139,245,.34),transparent 68%);filter:blur(22px)}
.cta-mascot img{position:relative;z-index:1;width:100%;max-width:330px;height:auto;
  filter:drop-shadow(0 30px 50px rgba(40,40,110,.4));animation:bob 6.5s ease-in-out infinite}

/* ============================================================ CONTACT */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:start}
.contact-info h2{font-size:clamp(1.9rem,4vw,2.8rem);margin-bottom:22px}
.contact-info>p{color:var(--txt-soft);margin-bottom:38px;font-size:1.06rem}
.contact-list{display:flex;flex-direction:column;gap:14px}
.cline{display:flex;align-items:center;gap:16px;padding:18px 20px;border:1px solid var(--line);border-radius:var(--radius-sm);
  background:var(--surface);box-shadow:var(--card-shadow);transition:.35s var(--ease)}
.cline:hover{border-color:var(--line-hover);transform:translateX(6px);background:var(--surface-2);box-shadow:var(--card-shadow-h)}
.cline .ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;flex:none;
  background:var(--ic-bg);border:1px solid var(--glass-brd)}
.cline .ic svg{width:21px;height:21px;stroke:var(--cyan)}
.cline span{font-size:.76rem;color:var(--txt-mute);display:block;text-transform:uppercase;letter-spacing:.1em}
.cline b{font-weight:500;font-size:1.02rem}

form.nt-form,form.wpcf7-form,.contact-grid form{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(28px,4vw,42px);box-shadow:var(--card-shadow)}
.field{margin-bottom:20px}
.field label{display:block;font-size:.82rem;color:var(--txt-soft);margin-bottom:9px;letter-spacing:.02em}
.field input,.field textarea,.field select{width:100%;background:var(--bg-soft);border:1px solid var(--line);border-radius:12px;
  padding:14px 16px;color:var(--txt);font-family:inherit;font-size:.96rem;transition:border-color .3s,box-shadow .3s;resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--violet);box-shadow:0 0 0 3px rgba(124,139,245,.2)}
.field input::placeholder,.field textarea::placeholder{color:var(--txt-mute)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
form .btn-primary{width:100%;justify-content:center;margin-top:6px}
.form-note{font-size:.8rem;color:var(--txt-mute);text-align:center;margin-top:14px}
.form-status{margin-top:14px;font-size:.9rem;text-align:center}
.form-status.ok{color:#34d399}
.form-status.err{color:#f472b6}

/* ============================================================ FOOTER */
footer.site-footer{border-top:1px solid var(--line);padding:clamp(44px,5vw,60px) 0 30px;background:var(--bg-soft)}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:50px;margin-bottom:50px}
.foot-brand p{color:var(--txt-soft);font-size:.96rem;margin:18px 0 24px;max-width:330px}
.socials{display:flex;gap:12px}
.socials a{width:42px;height:42px;border-radius:11px;border:1px solid var(--line);display:grid;place-items:center;
  background:var(--surface);transition:.35s var(--ease)}
.socials a:hover{background:var(--grad);transform:translateY(-3px);border-color:transparent}
.socials a:hover svg{fill:var(--on-accent)}
.socials a svg{width:19px;height:19px;fill:var(--txt-soft);transition:fill .3s}
.foot-col h4{font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--txt-mute);margin-bottom:20px;font-weight:500}
.foot-col ul{list-style:none;margin:0;padding:0}
.foot-col a{display:block;color:var(--txt-soft);font-size:.95rem;margin-bottom:13px;transition:color .25s}
.foot-col a:hover{color:var(--cyan)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:28px;border-top:1px solid var(--line-soft);
  color:var(--txt-mute);font-size:.86rem;flex-wrap:wrap;gap:12px}
.foot-legal{display:flex;gap:22px;flex-wrap:wrap;list-style:none;margin:0;padding:0}
.foot-legal a{color:var(--txt-mute);transition:color .25s}
.foot-legal a:hover{color:var(--cyan)}

/* ============================================================ TRUST STRIP */
.trust{border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);background:var(--bg-soft);position:relative;z-index:2}
.trust .wrap{display:flex;align-items:center;justify-content:center;gap:clamp(20px,4vw,52px);flex-wrap:wrap;padding-top:22px;padding-bottom:22px}
.trust-item{display:flex;align-items:center;gap:11px;font-size:.95rem;color:var(--txt-soft)}
.trust-item b{color:var(--txt);font-family:'Space Grotesk';font-weight:700}
.trust-item .stars{display:flex;gap:2px;color:var(--amber)}
.trust-item .stars svg{width:16px;height:16px;fill:var(--amber)}
.trust-sep{width:1px;height:26px;background:var(--line)}
@media(max-width:760px){.trust-sep{display:none}}

/* ============================================================ TECH STACK */
.stack-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stack-cat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px;box-shadow:var(--card-shadow);transition:transform .4s var(--ease),box-shadow .4s,border-color .4s}
.stack-cat:hover{transform:translateY(-5px);box-shadow:var(--card-shadow-h);border-color:var(--line-hover)}
.stack-cat h3{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cyan);margin-bottom:18px;font-family:'JetBrains Mono';font-weight:500}
.stack-pills{display:flex;flex-wrap:wrap;gap:9px}
.pill-tech{display:inline-flex;align-items:center;gap:7px;padding:8px 13px;border-radius:10px;font-size:.86rem;font-weight:500;
  background:var(--ghost-bg);border:1px solid var(--line);color:var(--txt);transition:.3s var(--ease)}
.pill-tech:hover{border-color:var(--violet);transform:translateY(-2px);background:var(--surface-2)}
.pill-tech .d{width:8px;height:8px;border-radius:50%;background:var(--grad);flex:none}

/* ============================================================ FAQ */
.faq-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(30px,5vw,64px);align-items:start}
.faq-list{display:flex;flex-direction:column;gap:12px}
.faq-item{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);overflow:hidden;box-shadow:var(--card-shadow);transition:border-color .3s,box-shadow .3s}
.faq-item[open]{border-color:var(--line-hover);box-shadow:var(--card-shadow-h)}
.faq-item summary{list-style:none;cursor:pointer;padding:22px 24px;display:flex;align-items:center;justify-content:space-between;gap:18px;
  font-family:'Space Grotesk';font-weight:600;font-size:1.08rem;color:var(--txt);transition:color .25s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--violet-2)}
.faq-item .q-ico{width:30px;height:30px;border-radius:9px;border:1px solid var(--line);display:grid;place-items:center;flex:none;transition:.4s var(--ease);background:var(--ghost-bg)}
.faq-item[open] .q-ico{transform:rotate(45deg);background:var(--grad);border-color:transparent}
.faq-item .q-ico svg{width:15px;height:15px;stroke:var(--txt);transition:stroke .3s}
.faq-item[open] .q-ico svg{stroke:var(--on-accent)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .45s var(--ease)}
.faq-answer p{padding:0 24px 24px;color:var(--txt-soft);font-size:.98rem;margin:0}
.faq-aside h2{font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:18px}
.faq-aside p{color:var(--txt-soft);font-size:1.05rem;margin-bottom:26px}

/* ============================================================ BACK TO TOP */
.to-top{position:fixed;right:clamp(18px,3vw,34px);bottom:clamp(18px,3vw,34px);z-index:90;width:50px;height:50px;border-radius:50%;
  border:1px solid var(--glass-brd);background:var(--glass);backdrop-filter:blur(14px);color:var(--txt);cursor:pointer;
  display:grid;place-items:center;box-shadow:var(--shadow);opacity:0;transform:translateY(16px) scale(.85);pointer-events:none;
  transition:opacity .4s var(--ease),transform .4s var(--ease),border-color .3s}
.to-top.show{opacity:1;transform:none;pointer-events:auto}
.to-top:hover{border-color:var(--violet);transform:translateY(-3px)}
.to-top svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}

/* mobile nav controls (visible only on small screens) */
.nav-ctrls{display:none}
.theme-toggle-m{display:none}

/* ============================================================ PAGE HERO (inner pages / singles) */
.page-hero{position:relative;padding:clamp(150px,18vw,210px) 0 clamp(46px,6vw,72px);overflow:hidden}
.page-hero .grid-bg{opacity:.3}
.page-hero-inner{position:relative;z-index:2;max-width:880px}
.page-hero.center .page-hero-inner{margin:0 auto;text-align:center}
.page-hero.center .eyebrow{justify-content:center}
.page-hero.center .eyebrow::before{display:none}
.page-hero h1{font-size:clamp(2.3rem,5.5vw,4rem);font-weight:700;margin-bottom:22px}
.page-hero p.lead{font-size:clamp(1.02rem,2vw,1.28rem);color:var(--txt-soft);max-width:680px}
.page-hero.center p.lead{margin-left:auto;margin-right:auto}

/* breadcrumb */
.crumbs{display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-size:.82rem;color:var(--txt-mute);margin-bottom:22px;font-family:'JetBrains Mono';letter-spacing:.04em}
.page-hero.center .crumbs{justify-content:center}
.crumbs a{color:var(--txt-soft);transition:color .25s}
.crumbs a:hover{color:var(--cyan)}
.crumbs .sep{opacity:.5}

/* ============================================================ CARD GRID (archives) */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card-grid.cols-2{grid-template-columns:repeat(2,1fr)}

/* ---- industry card ---- */
.ind-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--card-shadow);transition:transform .45s var(--ease),border-color .45s,box-shadow .45s;display:flex;flex-direction:column}
.ind-card:hover{transform:translateY(-7px);border-color:var(--line-hover);box-shadow:var(--card-shadow-h)}
.ind-card .ind-thumb{aspect-ratio:16/10;position:relative;overflow:hidden;background:var(--surface-2)}
.ind-card .ind-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.ind-card:hover .ind-thumb img{transform:scale(1.06)}
.ind-card .ind-thumb.placeholder{background:var(--ic-bg);display:grid;place-items:center}
.ind-card .ind-thumb.placeholder svg{width:46px;height:46px;stroke:var(--violet-2);opacity:.7}
.ind-card .ind-body{padding:28px 28px 30px;display:flex;flex-direction:column;flex:1}
.ind-card h3{font-size:1.28rem;margin-bottom:11px}
.ind-card p{color:var(--txt-soft);font-size:.95rem;flex:1}
.ind-card .ind-more{margin-top:18px;display:inline-flex;align-items:center;gap:7px;font-family:'Space Grotesk';font-weight:600;font-size:.9rem;color:var(--violet-2)}
.ind-card .ind-more svg{width:15px;height:15px;stroke:currentColor;transition:transform .35s}
.ind-card:hover .ind-more svg{transform:translateX(4px)}

/* ============================================================ BLOG */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--card-shadow);transition:transform .45s var(--ease),border-color .45s,box-shadow .45s;display:flex;flex-direction:column}
.post-card:hover{transform:translateY(-7px);border-color:var(--line-hover);box-shadow:var(--card-shadow-h)}
.post-card .pc-thumb{aspect-ratio:16/9;overflow:hidden;background:var(--surface-2);position:relative;display:block}
.post-card .pc-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.post-card:hover .pc-thumb img{transform:scale(1.06)}
.post-card .pc-thumb.placeholder{background:var(--ic-bg)}
.post-card .pc-body{padding:26px 26px 28px;display:flex;flex-direction:column;flex:1}
.post-card .pc-cat{display:inline-flex;align-self:flex-start;font-family:'JetBrains Mono';font-size:.68rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--cyan);margin-bottom:13px}
.post-card h3{font-size:1.24rem;margin-bottom:12px;line-height:1.2}
.post-card h3 a{transition:color .25s}
.post-card h3 a:hover{color:var(--violet-2)}
.post-card .pc-ex{color:var(--txt-soft);font-size:.94rem;flex:1}
.post-card .pc-meta{display:flex;align-items:center;gap:10px;margin-top:18px;padding-top:16px;border-top:1px solid var(--line-soft);
  font-size:.8rem;color:var(--txt-mute)}

/* ============================================================ SINGLE / PROSE */
.single-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:clamp(34px,5vw,64px);align-items:start}
.single-layout.no-aside{grid-template-columns:minmax(0,860px);justify-content:center}
.single-feat{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);margin-bottom:42px;box-shadow:var(--card-shadow)}
.single-feat img{width:100%;display:block}
.prose{max-width:820px}
.prose>*{margin-bottom:1.15em}
.prose h2{font-size:clamp(1.6rem,3vw,2.2rem);margin-top:1.6em;margin-bottom:.7em}
.prose h3{font-size:clamp(1.25rem,2.4vw,1.6rem);margin-top:1.4em;margin-bottom:.6em}
.prose h4{font-size:1.15rem;margin-top:1.2em;margin-bottom:.5em}
.prose p,.prose li{color:var(--txt-soft);font-size:1.06rem;line-height:1.75}
.prose ul,.prose ol{padding-left:1.3em}
.prose li{margin-bottom:.5em}
.prose a{color:var(--violet-2);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--line-hover);transition:.25s}
.prose a:hover{text-decoration-color:var(--violet-2)}
.prose strong{color:var(--txt)}
.prose blockquote{border-left:3px solid var(--violet);padding:6px 0 6px 24px;margin:1.6em 0;font-family:'Space Grotesk';
  font-size:1.2rem;color:var(--txt);font-style:italic}
.prose img{border-radius:var(--radius-sm);border:1px solid var(--line);margin:1.4em 0}
.prose code{font-family:'JetBrains Mono';font-size:.86em;background:var(--surface-2);border:1px solid var(--line);
  padding:2px 7px;border-radius:6px;color:var(--violet-2)}
.prose pre{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:20px 22px;overflow-x:auto}
.prose pre code{background:none;border:none;padding:0;color:var(--txt)}
.prose hr{border:none;border-top:1px solid var(--line);margin:2em 0}

/* single aside */
.single-aside{position:sticky;top:96px;display:flex;flex-direction:column;gap:20px}
.aside-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px;box-shadow:var(--card-shadow)}
.aside-card h4{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cyan);margin-bottom:18px;font-family:'JetBrains Mono';font-weight:500}
.aside-meta{display:flex;flex-direction:column;gap:14px}
.aside-meta .row{display:flex;flex-direction:column;gap:3px}
.aside-meta .row span{font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:var(--txt-mute)}
.aside-meta .row b{font-weight:600;font-size:1rem;color:var(--txt)}
.aside-meta .row a{color:var(--violet-2)}
.aside-tags{display:flex;flex-wrap:wrap;gap:8px}

/* results / stat row for case studies */
.cs-results{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin:0 0 42px}
.cs-results .res{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:24px 22px;box-shadow:var(--card-shadow)}
.cs-results .res .num{font-family:'Space Grotesk';font-size:2.1rem;font-weight:700;line-height:1;margin-bottom:6px}
.cs-results .res .lbl{color:var(--txt-soft);font-size:.85rem}

/* ============================================================ PAGINATION */
.pagination{display:flex;justify-content:center;gap:9px;margin-top:clamp(46px,6vw,72px);flex-wrap:wrap}
.pagination .page-numbers{display:inline-grid;place-items:center;min-width:46px;height:46px;padding:0 14px;border-radius:12px;
  border:1px solid var(--line);background:var(--surface);color:var(--txt-soft);font-family:'Space Grotesk';font-weight:600;
  font-size:.95rem;transition:.3s var(--ease)}
.pagination a.page-numbers:hover{border-color:var(--violet);color:var(--txt);transform:translateY(-2px)}
.pagination .page-numbers.current{background:var(--grad);color:var(--on-accent);border-color:transparent}
.pagination .page-numbers.dots{border:none;background:none}

/* WP post nav (prev/next single) */
.post-nav{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:48px;padding-top:34px;border-top:1px solid var(--line-soft)}
.post-nav a{padding:22px 24px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);
  box-shadow:var(--card-shadow);transition:.35s var(--ease)}
.post-nav a:hover{border-color:var(--line-hover);transform:translateY(-3px);box-shadow:var(--card-shadow-h)}
.post-nav span{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--txt-mute);margin-bottom:8px}
.post-nav b{font-family:'Space Grotesk';font-weight:600;font-size:1.02rem}
.post-nav .nxt{text-align:right}

/* empty state */
.empty-state{text-align:center;padding:clamp(40px,6vw,80px) 0;color:var(--txt-soft)}
.empty-state h3{font-size:1.5rem;margin-bottom:12px;color:var(--txt)}

/* ============================================================ COMMENTS */
.comments-area{margin-top:56px;padding-top:40px;border-top:1px solid var(--line-soft)}
.comments-area h3{font-size:1.5rem;margin-bottom:26px}
.comment-list{list-style:none;margin:0 0 36px;padding:0;display:flex;flex-direction:column;gap:20px}
.comment-list .comment-body{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:22px 24px;box-shadow:var(--card-shadow)}
.comment-list .children{list-style:none;margin:18px 0 0 28px;padding:0;display:flex;flex-direction:column;gap:18px}
.comment-author{display:flex;align-items:center;gap:11px;margin-bottom:10px}
.comment-author .avatar{border-radius:50%}
.comment-author .fn{font-family:'Space Grotesk';font-weight:600;color:var(--txt)}
.comment-meta{font-size:.78rem;color:var(--txt-mute);margin-bottom:8px}
.comment-content{color:var(--txt-soft);font-size:.96rem}
.comment-reply-link{font-size:.84rem;color:var(--violet-2)}
.comment-respond{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(26px,4vw,38px);box-shadow:var(--card-shadow)}
.comment-respond .comment-reply-title{font-size:1.3rem;margin-bottom:20px}
.comment-form p{margin-bottom:16px}
.comment-form label{display:block;font-size:.82rem;color:var(--txt-soft);margin-bottom:8px}
.comment-form input[type=text],.comment-form input[type=email],.comment-form input[type=url],.comment-form textarea{
  width:100%;background:var(--bg-soft);border:1px solid var(--line);border-radius:12px;padding:13px 15px;color:var(--txt);
  font-family:inherit;font-size:.95rem;transition:border-color .3s,box-shadow .3s}
.comment-form input:focus,.comment-form textarea:focus{outline:none;border-color:var(--violet);box-shadow:0 0 0 3px rgba(124,139,245,.2)}
.comment-form .form-submit input{display:inline-flex;align-items:center;font-family:'Space Grotesk';font-weight:600;font-size:.92rem;
  padding:13px 26px;border-radius:100px;cursor:pointer;border:none;background:var(--grad);color:var(--on-accent)}

/* ============================================================ WP CORE / GUTENBERG ALIGNMENTS */
.alignleft{float:left;margin:.4em 1.6em 1em 0}
.alignright{float:right;margin:.4em 0 1em 1.6em}
.aligncenter{margin-left:auto;margin-right:auto;display:block}
.wp-caption-text,.wp-element-caption{font-size:.82rem;color:var(--txt-mute);text-align:center;margin-top:8px}
.sticky-badge{display:inline-flex;font-family:'JetBrains Mono';font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--amber);margin-bottom:10px}

/* ============================================================ RESPONSIVE */
@media (max-width:1100px){
  .single-layout{grid-template-columns:1fr}
  .single-aside{position:static;flex-direction:row;flex-wrap:wrap}
  .single-aside .aside-card{flex:1 1 260px}
}
@media (max-width:980px){
  .hero{min-height:auto;padding:116px 0 56px}
  .hero-grid{grid-template-columns:1fr;gap:clamp(38px,6vw,54px);justify-items:start}
  .hero-content{max-width:680px}
  .hero-visual{justify-self:stretch;max-width:540px;width:100%}
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:44px}
  .svc-grid,.port-grid,.card-grid,.blog-grid{grid-template-columns:repeat(2,1fr)}
  .card-grid.cols-2{grid-template-columns:repeat(2,1fr)}
  .bento{grid-template-columns:repeat(2,1fr)}
  .cell.big{grid-column:span 2;grid-row:span 1}
  .process{grid-template-columns:1fr;gap:40px}
  .process::before{display:none}
  .cta-grid{grid-template-columns:1fr;text-align:center;justify-items:center}
  .cta-grid .inner{text-align:center}
  .cta-grid .hero-cta{justify-content:center}
  .cta-mascot{max-width:260px;margin:0 auto}
  .cta-mascot img{max-width:240px}
  .stack-grid{grid-template-columns:repeat(2,1fr)}
  .faq-grid{grid-template-columns:1fr;gap:32px}
  .foot-top{grid-template-columns:1fr 1fr;gap:36px}
  .foot-brand{grid-column:1/-1}
}
@media (max-width:680px){
  .nav-links{position:fixed;top:0;right:0;height:100vh;width:min(78vw,320px);flex-direction:column;justify-content:center;
    gap:30px;background:var(--bg);backdrop-filter:blur(20px);transform:translateX(100%);transition:transform .45s var(--ease);
    border-left:1px solid var(--line);padding:40px;z-index:99;align-items:flex-start;overflow-y:auto}
  .nav-links.open{transform:none}
  .nav-links a{font-size:1.2rem}
  .nav-links ul.sub-menu{position:static;transform:none;opacity:1;visibility:visible;background:none;border:none;box-shadow:none;
    padding:8px 0 0 14px;backdrop-filter:none}
  .nav-links ul.sub-menu a{font-size:1rem;padding:6px 0}
  .nav-links .btn{margin-top:10px}
  .burger{display:flex;z-index:101}
  .svc-grid,.port-grid,.stat-cards,.row2,.card-grid,.card-grid.cols-2,.blog-grid{grid-template-columns:1fr}
  .bento{grid-template-columns:1fr}
  .cell.big,.cell.wide{grid-column:span 1}
  .hv-stats div b{font-size:1.3rem}
  .test{flex-basis:84vw}
  .hv-float{display:none}
  .stack-grid{grid-template-columns:1fr}
  #themeToggle{display:none}
  .nav-ctrls{display:flex;align-items:center;gap:10px}
  .theme-toggle-m{display:grid}
  .foot-top{grid-template-columns:1fr}
  .foot-bottom{flex-direction:column;text-align:center}
  .post-nav{grid-template-columns:1fr}
  .post-nav .nxt{text-align:left}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.01ms!important}
  .reveal,.hero h1 .line>span,.hero p.lead,.hero-cta,.hero-visual{opacity:1!important;transform:none!important}
}
