/* ---------- TOKENS ---------- */
:root{
  --orange:#FF7A00;
  --orange-2:#FF9A3C;
  --orange-3:#FFB876;
  --orange-glow:rgba(255,122,0,.28);
  --orange-soft:rgba(255,122,0,.08);
  --orange-text:#C25400; /* WCAG AA-safe orange for small text on light backgrounds; brand orange stays #FF7A00 for backgrounds, buttons, and large display accents */

  --ink:#111111;
  --ink-2:#0A0A0B;
  --ink-3:#1A1A1D;
  --ink-4:#26262A;
  --ink-line:rgba(255,255,255,.08);
  --ink-line-2:rgba(255,255,255,.14);

  --white:#FFFFFF;
  --bg:#FFFFFF;
  --bg-2:#F8F9FB;
  --bg-3:#F1F3F7;
  --line:#E8EAF0;
  --line-2:#DCDFE6;

  --text:#111111;
  --text-2:#3F4451;
  --muted:#6B7280;
  --muted-2:#8A8F98;

  --radius-sm:10px;
  --radius:16px;
  --radius-lg:22px;
  --radius-xl:28px;
  --radius-2xl:36px;

  --shadow-sm:0 1px 2px rgba(17,17,17,.04), 0 1px 3px rgba(17,17,17,.06);
  --shadow:0 8px 24px -12px rgba(17,17,17,.12), 0 2px 8px rgba(17,17,17,.05);
  --shadow-lg:0 30px 60px -25px rgba(17,17,17,.22), 0 8px 24px -8px rgba(17,17,17,.10);
  --shadow-orange:0 20px 50px -20px rgba(255,122,0,.55);

  --grad-orange:linear-gradient(135deg,#FF7A00 0%,#FF9A3C 100%);
  --grad-orange-soft:linear-gradient(135deg,rgba(255,122,0,.14),rgba(255,154,60,.04));
  --grad-ink:linear-gradient(180deg,#0A0A0B 0%,#111114 100%);

  --f-display:"Inter Tight","Inter",system-ui,sans-serif;
  --f-body:"Inter",system-ui,sans-serif;
  --f-serif:"Instrument Serif",Georgia,serif;
  --f-mono:"JetBrains Mono",ui-monospace,monospace;

  --header-h:72px;
  --container:1220px;

  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- RESET / BASE ---------- */
*{box-sizing:border-box}
*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%}
body{
  font-family:var(--f-body);
  font-size:16px;
  line-height:1.6;
  color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img,svg{display:block; max-width:100%}
button{font-family:inherit; cursor:pointer; border:0; background:none; color:inherit}
a{color:inherit; text-decoration:none}
h1,h2,h3,h4,h5,h6{margin:0; font-family:var(--f-display); font-weight:700; letter-spacing:-.02em; line-height:1.08}
h1{font-size:clamp(2.5rem, 6vw, 4.75rem); letter-spacing:-.035em}
h2{font-size:clamp(2rem, 4.2vw, 3.25rem); letter-spacing:-.03em}
h3{font-size:clamp(1.35rem, 2.4vw, 1.85rem); letter-spacing:-.02em}
h4{font-size:1.1rem; letter-spacing:-.01em}
p{margin:0}

/* ---------- LAYOUT ---------- */
.container{max-width:var(--container); margin:0 auto; padding:0 24px}
@media (max-width:640px){ .container{padding:0 18px} }

.section{padding:96px 0; position:relative}
.section-sm{padding:64px 0}
.section-lg{padding:128px 0}
@media (max-width:768px){
  .section{padding:64px 0}
  .section-lg{padding:80px 0}
}

.dark{background:var(--ink-2); color:#F5F6F8}
.dark h1,.dark h2,.dark h3,.dark h4{color:#fff}
.dark p{color:#B8BCC6}
.soft{background:var(--bg-2)}

/* ---------- TYPE UTILITIES ---------- */
.eyebrow{
  font-family:var(--f-mono);
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--orange-text);
  font-weight:500;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.eyebrow::before{
  content:""; width:8px; height:8px; border-radius:2px;
  background:var(--orange);
  box-shadow:0 0 0 3px rgba(255,122,0,.18);
}
.dark .eyebrow{color:var(--orange-2)}
.serif-i{font-family:var(--f-serif); font-style:italic; font-weight:400; letter-spacing:-.01em}
.lead{font-size:clamp(1.05rem,1.35vw,1.2rem); color:var(--text-2); line-height:1.65; max-width:640px}
.dark .lead{color:#B8BCC6}
.muted{color:var(--muted)}
.mono{font-family:var(--f-mono); font-size:12.5px; letter-spacing:.02em}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:12px 20px;
  border-radius:999px;
  font-weight:600; font-size:14.5px;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease), color .2s var(--ease);
  white-space:nowrap;
}
.btn-primary{
  background:var(--ink);
  color:#fff;
  box-shadow:0 1px 0 rgba(255,255,255,.06) inset, 0 8px 20px -8px rgba(17,17,17,.35);
}
.btn-primary:hover{ background:#000; transform:translateY(-1px); box-shadow:0 12px 28px -10px rgba(17,17,17,.4) }
.btn-orange{
  background:var(--grad-orange);
  color:#fff;
  box-shadow:var(--shadow-orange), 0 1px 0 rgba(255,255,255,.2) inset;
}
.btn-orange:hover{ transform:translateY(-1px); box-shadow:0 26px 60px -20px rgba(255,122,0,.65) }
.btn-ghost{
  background:transparent;
  color:var(--ink);
  border:1px solid var(--line-2);
}
.btn-ghost:hover{ background:var(--bg-2); border-color:var(--ink) }
.dark .btn-ghost{ color:#fff; border-color:var(--ink-line-2) }
.dark .btn-ghost:hover{ background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.35) }
.btn-lg{ padding:16px 26px; font-size:15.5px }
.btn .arrow{
  display:inline-flex; width:18px; height:18px; align-items:center; justify-content:center;
  transition:transform .25s var(--ease);
}
.btn:hover .arrow{ transform:translateX(3px) }

/* ---------- HEADER ---------- */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:80;
  height:var(--header-h);
  display:flex; align-items:center;
  transition:background .25s var(--ease), border-color .25s var(--ease), backdrop-filter .25s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header .header-inner{
  width:100%;
  display:flex; align-items:center; justify-content:space-between;
  gap:24px;
}
.site-header.scrolled{
  background:rgba(255,255,255,.78);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom-color:var(--line);
}
body.page-dark-header .site-header:not(.scrolled){ color:#fff }
body.page-dark-header .site-header:not(.scrolled) .nav-link{ color:rgba(255,255,255,.85) }
body.page-dark-header .site-header:not(.scrolled) .btn-primary{ background:#fff; color:var(--ink) }

.logo{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--f-display); font-weight:700; letter-spacing:-.02em; font-size:17px;
  color:var(--ink);
}
.site-header.scrolled .logo, .site-header .logo{ color:var(--ink) }
body.page-dark-header .site-header:not(.scrolled) .logo{ color:#fff }
.brand-logo{
  display:block;
  width:150px;
  height:auto;
  max-width:none;
}
.brand-logo-footer{
  width:158px;
  padding:5px 9px;
  border-radius:10px;
  background:#fff;
}
body.page-dark-header .site-header:not(.scrolled) .brand-logo{
  width:158px;
  padding:4px 8px;
  border-radius:10px;
  background:rgba(255,255,255,.95);
  box-shadow:0 8px 24px -18px rgba(0,0,0,.45);
}
/* nav */
.nav{ display:flex; align-items:center; gap:6px }
.nav-link{
  padding:8px 14px;
  border-radius:999px;
  font-size:14px; font-weight:500;
  color:var(--text-2);
  transition:background .2s, color .2s;
  position:relative;
  display:inline-flex;
  align-items:center;
  white-space:nowrap;
}
.nav-link:hover{ color:var(--ink); background:rgba(17,17,17,.05) }
.nav-link.active{ color:var(--ink) }
.nav-link.active::after{
  content:""; position:absolute; left:50%; bottom:-2px; transform:translateX(-50%);
  width:4px; height:4px; border-radius:50%; background:var(--orange);
}

.site-header.scrolled .nav-link:hover, .site-header .nav-link:hover{ background:rgba(17,17,17,.05); color:var(--ink) }
body.page-dark-header .site-header:not(.scrolled) .nav-link:hover{ background:rgba(255,255,255,.08); color:#fff }

/* mega menu */
.has-mega{ position:relative }
.mega{
  position:absolute; top:100%; left:50%; transform:translateX(-50%) translateY(6px);
  width:min(720px, 92vw);
  background:transparent; color:var(--ink);
  border:0;
  border-radius:22px;
  padding:14px 0 0;
  box-shadow:none;
  display:grid; grid-template-columns:1fr 1fr;
  gap:8px;
  opacity:0; visibility:hidden; pointer-events:none;
  transition:opacity .2s var(--ease), transform .2s var(--ease);
}
.mega::before{
  content:"";
  position:absolute;
  inset:14px 0 0;
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow:var(--shadow-lg);
  z-index:-1;
}
.has-mega:hover .mega, .has-mega:focus-within .mega{
  opacity:1; visibility:visible; pointer-events:auto;
  transform:translateX(-50%) translateY(0);
}
.mega-item{
  position:relative;
  z-index:1;
  display:flex; gap:12px; padding:12px; border-radius:14px;
  transition:background .2s;
}
.mega-item:hover{ background:var(--bg-2) }
.mega-item .mi-icon{
  width:38px; height:38px; border-radius:10px;
  background:var(--orange-soft);
  color:var(--orange);
  display:inline-flex; align-items:center; justify-content:center;
  flex-shrink:0;
}
.mega-item .mi-title{ font-weight:600; font-size:14.5px }
.mega-item .mi-desc{ font-size:12.5px; color:var(--muted); margin-top:2px; line-height:1.5 }

.header-cta{ display:flex; align-items:center; gap:10px }
.mobile-toggle{
  display:none;
  width:40px; height:40px; border-radius:10px;
  align-items:center; justify-content:center;
  border:1px solid var(--line);
}
.mobile-toggle span{
  display:block; width:16px; height:1.5px; background:var(--ink); border-radius:2px;
  position:relative;
}
.mobile-toggle span::before, .mobile-toggle span::after{
  content:""; position:absolute; left:0; width:16px; height:1.5px; background:var(--ink); border-radius:2px;
  transition:transform .2s;
}
.mobile-toggle span::before{ top:-5px }
.mobile-toggle span::after{ top:5px }
body.page-dark-header .site-header:not(.scrolled) .mobile-toggle{ border-color:rgba(255,255,255,.2) }
body.page-dark-header .site-header:not(.scrolled) .mobile-toggle span,
body.page-dark-header .site-header:not(.scrolled) .mobile-toggle span::before,
body.page-dark-header .site-header:not(.scrolled) .mobile-toggle span::after{ background:#fff }

/* mobile menu */
.mobile-menu{
  position:fixed; inset:0; z-index:70;
  background:rgba(10,10,11,.6);
  backdrop-filter:blur(8px);
  opacity:0; pointer-events:none;
  transition:opacity .2s;
}
.mobile-menu.open{ opacity:1; pointer-events:auto }
.mobile-menu-panel{
  position:absolute; top:0; right:0; bottom:0;
  width:min(360px, 88vw);
  background:#fff;
  padding:24px 20px 32px;
  transform:translateX(100%);
  transition:transform .3s var(--ease);
  display:flex; flex-direction:column; gap:6px;
  overflow-y:auto;
}
.mobile-menu.open .mobile-menu-panel{ transform:translateX(0) }
.mobile-menu-panel .mm-top{ display:flex; justify-content:space-between; align-items:center; margin-bottom:18px }
.mm-close{ width:36px; height:36px; border-radius:10px; border:1px solid var(--line); display:inline-flex; align-items:center; justify-content:center }
.mm-link{
  display:flex; justify-content:space-between; align-items:center;
  padding:14px 12px; border-radius:12px;
  font-weight:600; font-size:16px;
  border-bottom:1px solid var(--line);
}
.mm-link:hover{ background:var(--bg-2) }
.mm-group-title{ font-family:var(--f-mono); font-size:11px; letter-spacing:.14em; color:var(--muted); text-transform:uppercase; padding:16px 12px 6px }
.mm-sub{ padding:10px 12px; font-size:14.5px; color:var(--text-2); border-radius:10px }
.mm-sub:hover{ background:var(--bg-2) }
.mm-cta{ margin-top:20px }

@media (max-width:960px){
  .nav, .header-cta .btn:not(.mobile-toggle){ display:none }
  .mobile-toggle{ display:inline-flex }
}

/* ---------- PAGES ---------- */
.page{ display:block; padding-top:var(--header-h) }

/* ---------- HERO GENERAL ---------- */
.hero{
  position:relative;
  padding:96px 0 88px;
  overflow:hidden;
}
.hero.dark-hero{
  background:var(--ink-2);
  color:#fff;
}
@media (max-width:768px){ .hero{ padding:64px 0 56px } }

/* Mesh backdrop */
.mesh{
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:
    radial-gradient(circle at 20% 15%, rgba(255,122,0,.14), transparent 40%),
    radial-gradient(circle at 85% 30%, rgba(255,154,60,.08), transparent 45%),
    radial-gradient(circle at 60% 90%, rgba(255,122,0,.06), transparent 50%);
}
.dark-hero .mesh, .dark .mesh{
  background-image:
    radial-gradient(circle at 15% 20%, rgba(255,122,0,.18), transparent 40%),
    radial-gradient(circle at 85% 40%, rgba(255,154,60,.10), transparent 45%),
    radial-gradient(circle at 60% 100%, rgba(255,122,0,.08), transparent 55%);
}
.dotgrid{
  position:absolute; inset:0; z-index:0; pointer-events:none; opacity:.5;
  background-image:radial-gradient(rgba(17,17,17,.10) 1px, transparent 1px);
  background-size:22px 22px;
  mask-image:radial-gradient(ellipse at center, black 40%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center, black 40%, transparent 75%);
}
.dark-hero .dotgrid, .dark .dotgrid{
  background-image:radial-gradient(rgba(255,255,255,.09) 1px, transparent 1px);
}

.hero .container{ position:relative; z-index:2 }

/* ---------- HOME HERO ---------- */
.home-hero-grid{
  display:grid; grid-template-columns:1.05fr .95fr; gap:56px; align-items:center;
}
.home-hero-grid > *{ min-width:0 }
@media (max-width:960px){ .home-hero-grid{ grid-template-columns:1fr; gap:40px } }

.hero-badge{
  display:inline-flex; align-items:center; gap:10px;
  padding:6px 12px 6px 6px;
  border-radius:999px;
  background:rgba(255,255,255,.65);
  border:1px solid var(--line);
  font-size:13px; color:var(--text-2);
  backdrop-filter:blur(8px);
  margin-bottom:24px;
}
.hero-badge .hb-tag{
  display:inline-flex; align-items:center; gap:6px;
  padding:4px 10px; border-radius:999px;
  background:var(--ink); color:#fff; font-weight:500; font-size:11.5px;
  font-family:var(--f-mono); letter-spacing:.06em;
}
.hero-badge .hb-tag::before{
  content:""; width:6px; height:6px; border-radius:50%; background:var(--orange);
  box-shadow:0 0 0 3px rgba(255,122,0,.25);
}

.headline{
  font-size:clamp(2.6rem, 6.2vw, 5rem);
  line-height:1.02;
  letter-spacing:-.038em;
  margin-bottom:22px;
}
.headline .serif-i{
  color:var(--orange);
  display:inline-block;
}

.hero-cta-row{
  display:flex; gap:12px; flex-wrap:wrap; align-items:center;
  margin-top:32px;
}
.hero-meta{
  display:flex; gap:22px; margin-top:36px; padding-top:24px;
  border-top:1px solid var(--line);
  flex-wrap:wrap;
}
.dark-hero .hero-meta{ border-color:var(--ink-line) }
.hero-meta-item .hm-num{ font-family:var(--f-display); font-weight:700; font-size:22px; letter-spacing:-.02em }
.hero-meta-item .hm-label{ font-size:12.5px; color:var(--muted); font-family:var(--f-mono); letter-spacing:.05em; text-transform:uppercase; margin-top:2px }

/* Hero visual — floating console */
.hero-visual{
  position:relative;
  width:100%;
  aspect-ratio:1/1.02;
  max-width:520px;
  margin-left:auto;
}
.hero-visual-img{
  position:absolute;
  inset:-30px -28px auto auto;
  width:92%;
  height:62%;
  object-fit:cover;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 30px 70px -35px rgba(0,0,0,.55), 0 18px 50px -28px rgba(255,122,0,.7);
  opacity:.92;
  z-index:0;
}
.hero-visual-img::selection{ background:transparent }
.console{
  position:absolute;
  inset:78px 0 0;
  background:linear-gradient(180deg,#101012 0%,#0A0A0B 100%);
  border-radius:26px;
  padding:20px;
  border:1px solid var(--ink-line-2);
  box-shadow:0 40px 80px -30px rgba(0,0,0,.45), 0 20px 40px -20px rgba(255,122,0,.25);
  color:#E5E7EE;
  overflow:hidden;
  z-index:1;
}
.console::before{
  content:""; position:absolute; inset:-1px; border-radius:26px; padding:1px;
  background:linear-gradient(160deg, rgba(255,122,0,.5), rgba(255,255,255,0) 40%);
  -webkit-mask:linear-gradient(#000,#000) content-box, linear-gradient(#000,#000);
  -webkit-mask-composite:xor; mask-composite:exclude;
  pointer-events:none;
}
.console-bar{
  display:flex; align-items:center; gap:8px; padding-bottom:14px; border-bottom:1px solid var(--ink-line);
  margin-bottom:14px;
}
.dot{ width:10px; height:10px; border-radius:50% }
.dot.r{ background:#FF5F57 } .dot.y{ background:#FEBC2E } .dot.g{ background:#28C840 }
.console-title{ margin-left:8px; font-family:var(--f-mono); font-size:12px; color:#8A8F98 }
.console-title strong{ color:#F0F1F4; font-weight:500 }

.console-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:12px;
}
.c-card{
  background:rgba(255,255,255,.03);
  border:1px solid var(--ink-line);
  border-radius:14px;
  padding:14px;
}
.c-card.full{ grid-column:1/-1 }
.c-label{ font-family:var(--f-mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:#8A8F98 }
.c-value{ font-family:var(--f-display); font-size:22px; font-weight:700; letter-spacing:-.02em; margin-top:6px }
.c-value.orange{ color:var(--orange-2) }
.c-sub{ font-size:11.5px; color:#A6ABB6; margin-top:4px }

.c-bars{ display:flex; align-items:flex-end; gap:6px; height:70px; margin-top:10px }
.c-bars i{
  flex:1; background:linear-gradient(180deg, var(--orange-2), var(--orange));
  border-radius:3px 3px 0 0;
  opacity:.9;
  animation:bar 2.5s var(--ease) infinite alternate;
}
.c-bars i:nth-child(1){ height:35% } .c-bars i:nth-child(2){ height:55%; animation-delay:.2s }
.c-bars i:nth-child(3){ height:40%; animation-delay:.35s } .c-bars i:nth-child(4){ height:75%; animation-delay:.5s }
.c-bars i:nth-child(5){ height:50%; animation-delay:.65s } .c-bars i:nth-child(6){ height:90%; animation-delay:.8s }
.c-bars i:nth-child(7){ height:65%; animation-delay:.95s }
@keyframes bar{ from{opacity:.6} to{opacity:1} }

.c-lines{ display:flex; flex-direction:column; gap:8px; margin-top:8px }
.c-line{ display:flex; align-items:center; gap:10px; font-size:12.5px; color:#C7CBD3 }
.c-line .c-pulse{ width:8px; height:8px; border-radius:50%; background:var(--orange); box-shadow:0 0 0 4px rgba(255,122,0,.18); flex-shrink:0 }

.float-tag{
  position:absolute;
  z-index:2;
  background:#fff; color:var(--ink);
  padding:10px 14px 10px 12px; border-radius:14px;
  box-shadow:0 20px 40px -20px rgba(17,17,17,.35);
  display:inline-flex; align-items:center; gap:10px;
  font-size:13px; font-weight:600;
  border:1px solid var(--line);
  animation:float 6s ease-in-out infinite;
}
.float-tag .ft-ico{ width:24px; height:24px; border-radius:6px; background:var(--orange-soft); color:var(--orange); display:inline-flex; align-items:center; justify-content:center }
.float-tag.a{ top:-14px; right:-8px; animation-delay:.2s }
.float-tag.b{ bottom:24px; left:-24px; animation-delay:1.2s }
@keyframes float{
  0%,100%{ transform:translateY(0) }
  50%{ transform:translateY(-8px) }
}
@media (max-width:960px){
  .hero-visual{
    margin-right:auto;
    min-height:640px;
  }
}
@media (max-width:560px){
  .hero-visual{
    width:calc(100vw - 36px);
    max-width:none;
    min-height:640px;
  }
  .hero-visual-img{
    inset:-10px 0 auto 0;
    width:100%;
    height:46%;
  }
  .console{
    inset:130px 0 0;
  }
  .float-tag.a{ top:10px; right:10px }
  .float-tag.b{ bottom:-8px; left:8px }
}

/* ---------- TRUST STRIP ---------- */
.trust{
  padding:44px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:var(--bg-2);
}
.trust-head{ text-align:center; margin-bottom:22px }
.trust-head p{ font-family:var(--f-mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted) }
.marquee{ overflow:hidden; mask-image:linear-gradient(90deg, transparent, black 12%, black 88%, transparent) }
.marquee-track{ display:flex; gap:64px; align-items:center; width:max-content; animation:scroll 30s linear infinite }
.marquee-track .m-logo{
  font-family:var(--f-display); font-weight:700; font-size:20px; letter-spacing:-.02em;
  color:var(--muted-2); opacity:.75; white-space:nowrap;
  display:inline-flex; align-items:center; gap:8px;
}
.marquee-track .m-logo .m-dot{ width:8px; height:8px; border-radius:2px; background:var(--muted-2) }
@keyframes scroll{ from{ transform:translateX(0) } to{ transform:translateX(-50%) } }

/* ---------- SECTION HEADS ---------- */
.section-head{ max-width:760px; margin-bottom:56px }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center }
.section-head h2{ margin-top:14px }
.section-head .lead{ margin-top:18px }
.section-head.center .lead{ margin-left:auto; margin-right:auto }

/* ---------- BENTO / CARDS ---------- */
.bento{
  display:grid;
  gap:16px;
}
.bento-4{ grid-template-columns:repeat(4,1fr) }
.bento-3{ grid-template-columns:repeat(3,1fr) }
.bento-2{ grid-template-columns:repeat(2,1fr) }
@media (max-width:900px){ .bento-4{ grid-template-columns:repeat(2,1fr) } .bento-3{ grid-template-columns:repeat(2,1fr) } }
@media (max-width:560px){ .bento-4, .bento-3, .bento-2{ grid-template-columns:1fr } }

.card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:26px;
  position:relative;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
}
.card:hover{ transform:translateY(-2px); box-shadow:var(--shadow); border-color:var(--line-2) }
.card .c-ico{
  width:44px; height:44px; border-radius:12px;
  background:var(--orange-soft); color:var(--orange);
  display:inline-flex; align-items:center; justify-content:center;
  margin-bottom:18px;
}
.card h3{ font-size:1.15rem; margin-bottom:8px }
.card p{ color:var(--muted); font-size:14.5px; line-height:1.6 }
.card .c-link{
  display:inline-flex; align-items:center; gap:6px;
  font-size:13.5px; font-weight:600; color:var(--ink);
  margin-top:16px;
}
.card .c-link .arrow{ transition:transform .2s var(--ease) }
.card:hover .c-link .arrow{ transform:translateX(3px) }

.card.dark{ background:var(--ink-2); border-color:var(--ink-line-2); color:#fff }
.card.dark p{ color:#B8BCC6 }
.card.dark:hover{ border-color:rgba(255,122,0,.5) }
.card.dark .c-link{ color:#fff }

.card.feature{
  grid-column:span 2;
  background:var(--grad-ink);
  color:#fff;
  border-color:var(--ink-line-2);
  padding:36px;
  overflow:hidden;
}
.card.feature h3{ font-size:1.55rem; margin-bottom:10px }
.card.feature p{ color:#B8BCC6; max-width:420px }
.card.feature .c-ico{ background:rgba(255,122,0,.15); color:var(--orange-2) }
.card.feature .feature-viz{
  position:absolute; right:-40px; bottom:-40px;
  width:260px; height:260px; border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(255,122,0,.35), transparent 60%);
  pointer-events:none;
}
@media (max-width:900px){ .card.feature{ grid-column:span 2; padding:28px } }
@media (max-width:560px){ .card.feature{ grid-column:span 1 } }

/* ---------- WHY BENTO (Home) ---------- */
.why-bento{
  display:grid;
  grid-template-columns:repeat(6, 1fr);
  gap:16px;
}
.why-bento .b{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:28px;
  position:relative;
  overflow:hidden;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.why-bento .b:hover{ transform:translateY(-2px); box-shadow:var(--shadow) }
.why-bento .b.wide{ grid-column:span 4 }
.why-bento .b.tall{ grid-column:span 2 }
.why-bento .b.full{ grid-column:span 6 }
.why-bento .b.full p{ max-width:560px }
.why-bento .b.dark{ background:var(--ink-2); color:#fff; border-color:var(--ink-line-2) }
.why-bento .b.orange{
  background:var(--grad-orange); color:#fff; border-color:transparent;
}
.why-bento .b h3{ font-size:1.2rem; margin-bottom:8px }
.why-bento .b p{ font-size:14px; color:var(--muted); line-height:1.6 }
.why-bento .b.dark p, .why-bento .b.orange p{ color:rgba(255,255,255,.85) }
.why-bento .b .stat{ font-family:var(--f-display); font-size:clamp(2.4rem,5vw,3.5rem); font-weight:700; letter-spacing:-.03em; line-height:1 }
.why-bento .b .stat + p{ margin-top:10px }
.why-bento .b .b-ico{ width:40px; height:40px; border-radius:10px; background:var(--orange-soft); color:var(--orange); display:inline-flex; align-items:center; justify-content:center; margin-bottom:16px }
.why-bento .b.dark .b-ico{ background:rgba(255,255,255,.08); color:var(--orange-2) }
.why-bento .b.orange .b-ico{ background:rgba(255,255,255,.18); color:#fff }
@media (max-width:900px){
  .why-bento{ grid-template-columns:repeat(2,1fr) }
  .why-bento .b.wide, .why-bento .b.tall, .why-bento .b.full{ grid-column:span 2 }
}
@media (max-width:560px){
  .why-bento{ grid-template-columns:1fr }
  .why-bento .b.wide, .why-bento .b.tall, .why-bento .b.full{ grid-column:span 1 }
}

/* ---------- SERVICES ROW ---------- */
.svc-grid{
  display:grid; grid-template-columns:repeat(6,1fr); gap:16px;
}
.svc-tile{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:28px; position:relative;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
  display:flex; flex-direction:column;
  min-height:280px;
  overflow:hidden;
  cursor:pointer;
}
.svc-tile:hover{ transform:translateY(-3px); box-shadow:var(--shadow); border-color:var(--ink) }
.svc-tile.hero-svc{ grid-column:span 3; background:var(--grad-ink); color:#fff; border-color:var(--ink-line-2) }
.svc-tile.med{ grid-column:span 3 }
.svc-tile.small{ grid-column:span 2 }
.svc-tile.hero-svc:hover{ border-color:rgba(255,122,0,.5) }
.svc-tile .s-num{
  font-family:var(--f-mono); font-size:11.5px; color:var(--muted); letter-spacing:.14em;
}
.svc-tile.hero-svc .s-num{ color:var(--orange-2) }
.svc-tile h3{ margin-top:16px; font-size:1.35rem }
.svc-tile p{ margin-top:10px; color:var(--muted); font-size:14.5px; line-height:1.6; max-width:420px }
.svc-tile.hero-svc p{ color:#B8BCC6 }
.svc-tile .s-tags{ display:flex; gap:6px; flex-wrap:wrap; margin-top:auto; padding-top:20px }
.svc-tile .s-tag{
  font-family:var(--f-mono); font-size:11.5px;
  padding:5px 10px; border-radius:999px;
  background:var(--bg-2); color:var(--text-2);
  border:1px solid var(--line);
}
.svc-tile.hero-svc .s-tag{ background:rgba(255,255,255,.07); color:#B8BCC6; border-color:var(--ink-line-2) }
.svc-tile .s-arrow{
  position:absolute; top:24px; right:24px;
  width:36px; height:36px; border-radius:10px;
  background:var(--bg-2); border:1px solid var(--line);
  display:inline-flex; align-items:center; justify-content:center;
  transition:transform .25s var(--ease), background .2s;
}
.svc-tile.hero-svc .s-arrow{ background:rgba(255,255,255,.08); border-color:var(--ink-line-2); color:#fff }
.svc-tile:hover .s-arrow{ transform:translate(3px,-3px); background:var(--orange); color:#fff; border-color:var(--orange) }
@media (max-width:960px){
  .svc-grid{ grid-template-columns:repeat(2,1fr) }
  .svc-tile.hero-svc, .svc-tile.med, .svc-tile.small{ grid-column:span 2 }
}
@media (max-width:560px){
  .svc-grid{ grid-template-columns:1fr }
  .svc-tile.hero-svc, .svc-tile.med, .svc-tile.small{ grid-column:span 1 }
}

/* ---------- INDUSTRIES ---------- */
.ind-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:12px;
}
.ind-tile{
  padding:20px;
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  display:flex; align-items:center; gap:12px;
  transition:transform .2s, border-color .2s;
}
.ind-tile:hover{ transform:translateY(-2px); border-color:var(--ink) }
.ind-tile .i-ico{ width:36px; height:36px; border-radius:9px; background:var(--orange-soft); color:var(--orange); display:inline-flex; align-items:center; justify-content:center; flex-shrink:0 }
.ind-tile .i-name{ font-weight:600; font-size:14.5px }
@media (max-width:900px){ .ind-grid{ grid-template-columns:repeat(2,1fr) } }
@media (max-width:520px){ .ind-grid{ grid-template-columns:1fr } }

/* ---------- PROCESS RAIL ---------- */
.rail{
  position:relative;
  padding:32px 0 8px;
}
.rail-line{
  position:absolute; top:52px; left:0; right:0; height:2px;
  background:linear-gradient(90deg, var(--line), var(--line));
}
.rail-line::after{
  content:""; position:absolute; top:-4px; left:0;
  width:12px; height:12px; border-radius:50%;
  background:var(--orange);
  box-shadow:0 0 0 5px rgba(255,122,0,.18);
  animation:railmove 6s linear infinite;
}
@keyframes railmove{ from{ left:0 } to{ left:100% } }
.rail-steps{
  display:grid; grid-template-columns:repeat(5,1fr); gap:24px;
  position:relative;
}
.rail-step{
  padding-top:88px;
}
.rail-step .rs-num{
  position:absolute; top:26px;
  font-family:var(--f-mono); font-size:11.5px; letter-spacing:.14em;
  color:var(--muted); text-transform:uppercase;
}
.rail-step h4{ font-family:var(--f-display); font-size:17px; font-weight:700; margin-bottom:8px }
.rail-step p{ font-size:13.5px; color:var(--muted); line-height:1.6 }
@media (max-width:900px){
  .rail-line{ display:none }
  .rail-steps{ grid-template-columns:1fr; gap:12px }
  .rail-step{
    padding:20px 20px 20px 60px;
    background:#fff; border:1px solid var(--line); border-radius:var(--radius);
    position:relative;
  }
  .rail-step::before{
    content:""; position:absolute; left:24px; top:26px; width:12px; height:12px; border-radius:50%;
    background:var(--orange); box-shadow:0 0 0 4px rgba(255,122,0,.18);
  }
  .rail-step .rs-num{ position:static; display:block; margin-bottom:8px }
}
.dark .rail-step p, .dark .rail-step .rs-num{ color:#9096A2 }
.dark .rail-line{ background:linear-gradient(90deg, var(--ink-line), var(--ink-line)) }

/* ---------- TECH STACK ---------- */
.tech-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
}
@media (max-width:900px){ .tech-grid{ grid-template-columns:1fr } }
.tech-col{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:26px;
}
.tech-col h4{
  display:flex; align-items:center; gap:10px;
  font-size:14px; font-family:var(--f-mono); letter-spacing:.08em; text-transform:uppercase; color:var(--muted);
  margin-bottom:20px;
}
.tech-col h4 .dot{ width:8px; height:8px; border-radius:2px; background:var(--orange) }
.tech-pills{ display:flex; flex-wrap:wrap; gap:8px }
.tech-pill{
  padding:8px 12px; border-radius:10px;
  background:var(--bg-2); border:1px solid var(--line);
  font-size:13.5px; font-weight:500;
  display:inline-flex; align-items:center; gap:8px;
}
.tech-pill .tp-dot{ width:6px; height:6px; border-radius:50%; background:var(--orange) }

/* ---------- TESTIMONIALS ---------- */
.testi-grid{
  display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:16px;
  align-items:stretch;
}
@media (max-width:900px){ .testi-grid{ grid-template-columns:1fr } }
.testi{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:32px; display:flex; flex-direction:column; gap:20px;
}
.testi.hero-testi{
  background:var(--ink-2); color:#fff; border-color:var(--ink-line-2);
  padding:40px;
}
.testi.hero-testi p{ color:#E5E7EE }
.testi blockquote{ margin:0; font-family:var(--f-display); font-weight:500; font-size:1.15rem; line-height:1.55; letter-spacing:-.01em }
.testi.hero-testi blockquote{ font-size:1.45rem; letter-spacing:-.02em }
.testi .quote-mark{ font-family:var(--f-serif); font-style:italic; font-size:52px; line-height:.8; color:var(--orange); height:20px }
.testi .t-author{ display:flex; align-items:center; gap:12px; margin-top:auto }
.testi .t-avatar{ width:40px; height:40px; border-radius:50%; background:var(--grad-orange); display:inline-flex; align-items:center; justify-content:center; color:#fff; font-weight:700; font-size:14px }
.testi .t-name{ font-weight:600; font-size:14.5px }
.testi .t-role{ font-size:12.5px; color:var(--muted) }
.testi.hero-testi .t-role{ color:#9096A2 }
.testi .t-stars{ color:var(--orange); font-size:14px; letter-spacing:2px }

/* ---------- ABOUT PREVIEW ---------- */
.about-prev{
  display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center;
}
@media (max-width:900px){ .about-prev{ grid-template-columns:1fr; gap:40px } }
.about-prev-visual{
  aspect-ratio:1/1;
  border-radius:var(--radius-2xl);
  background:var(--grad-ink);
  position:relative;
  overflow:hidden;
  padding:36px;
  color:#fff;
  display:flex; flex-direction:column; justify-content:space-between;
}
.about-prev-visual::before{
  content:""; position:absolute; inset:0;
  background:radial-gradient(circle at 80% 20%, rgba(255,122,0,.35), transparent 55%);
}
.about-prev-visual .apv-num{
  font-family:var(--f-display); font-size:clamp(4rem, 10vw, 8rem);
  font-weight:800; letter-spacing:-.05em; line-height:1;
  position:relative;
}
.about-prev-visual .apv-num .plus{ color:var(--orange-2); font-family:var(--f-serif); font-style:italic }
.about-prev-visual .apv-label{ font-family:var(--f-mono); font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:#B8BCC6; position:relative }
.about-prev-visual .apv-grid{ position:relative; display:grid; grid-template-columns:1fr 1fr; gap:14px }
.about-prev-visual .apv-mini{ padding:14px; background:rgba(255,255,255,.05); border-radius:14px; border:1px solid var(--ink-line-2) }
.about-prev-visual .apv-mini .m-num{ font-family:var(--f-display); font-size:24px; font-weight:700 }
.about-prev-visual .apv-mini .m-lbl{ font-size:12px; color:#9096A2; margin-top:2px }

/* ---------- CTA BLOCK ---------- */
.cta-block{
  position:relative;
  background:var(--ink-2);
  color:#fff;
  border-radius:var(--radius-2xl);
  padding:80px 56px;
  overflow:hidden;
  text-align:center;
}
.cta-block::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(circle at 15% 100%, rgba(255,122,0,.35), transparent 50%),
    radial-gradient(circle at 85% 0%, rgba(255,154,60,.20), transparent 50%);
}
.cta-block > *{ position:relative }
.cta-block h2{ max-width:800px; margin:0 auto 20px; font-size:clamp(2rem, 4.5vw, 3.4rem); line-height:1.05 }
.cta-block h2 .serif-i{ color:var(--orange-2) }
.cta-block p{ max-width:600px; margin:0 auto 32px; color:#B8BCC6 }
.cta-block .btn-row{ display:inline-flex; gap:12px; flex-wrap:wrap; justify-content:center }
.cta-block .btn-ghost{
  color:#fff;
  border-color:rgba(255,255,255,.26);
  background:rgba(255,255,255,.04);
}
.cta-block .btn-ghost:hover{
  background:rgba(255,255,255,.10);
  border-color:rgba(255,255,255,.48);
}
@media (max-width:640px){ .cta-block{ padding:56px 24px } }

/* ---------- FOOTER ---------- */
.site-footer{
  background:var(--ink-2);
  color:#B8BCC6;
  padding:80px 0 32px;
  position:relative;
  overflow:hidden;
}
.site-footer::before{
  content:""; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,122,0,.5), transparent);
}
.footer-grid{
  display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:40px;
  margin-bottom:56px;
}
@media (max-width:900px){ .footer-grid{ grid-template-columns:1fr 1fr; gap:32px } }
@media (max-width:560px){ .footer-grid{ grid-template-columns:1fr } }
.footer-brand p{ margin-top:16px; font-size:14px; color:#9096A2; max-width:340px; line-height:1.6 }
.footer-brand .social{ display:flex; gap:8px; margin-top:20px }
.footer-brand .social a{
  width:36px; height:36px; border-radius:9px;
  background:rgba(255,255,255,.05); border:1px solid var(--ink-line-2);
  display:inline-flex; align-items:center; justify-content:center;
  color:#B8BCC6; transition:background .2s, color .2s, border-color .2s;
}
.footer-brand .social a:hover{ background:var(--orange); color:#fff; border-color:var(--orange) }
.footer-col h5{ font-size:14px; color:#fff; font-family:var(--f-display); margin-bottom:16px; font-weight:600 }
.footer-col ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px }
.footer-col a{ font-size:13.5px; color:#9096A2; transition:color .2s }
.footer-col a:hover{ color:#fff }
.footer-col .contact-item{ font-size:13.5px; color:#9096A2; display:flex; gap:10px; align-items:flex-start }
.footer-col .contact-item svg{ color:var(--orange-2); flex-shrink:0; margin-top:2px }
.footer-bottom{
  border-top:1px solid var(--ink-line);
  padding-top:24px;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:16px;
  font-size:13px; color:#7A7F8A;
}
.footer-bottom .fb-right{ display:flex; gap:20px }
.footer-bottom a:hover{ color:#fff }

/* ---------- INNER PAGE HEROES ---------- */
.page-hero{
  position:relative;
  padding:120px 0 80px;
  overflow:hidden;
  background:var(--bg-2);
  border-bottom:1px solid var(--line);
}
.page-hero.dark{ background:var(--ink-2); color:#fff; border-color:var(--ink-line) }
.page-hero .container{ position:relative; z-index:2 }
.page-hero-eyebrow{ margin-bottom:20px }
.page-hero h1{ max-width:900px }
.page-hero .lead{ margin-top:20px; max-width:640px }
.page-hero .btn-row{ margin-top:32px; display:flex; gap:12px; flex-wrap:wrap }

.breadcrumb{
  display:flex; align-items:center; gap:8px;
  font-family:var(--f-mono); font-size:12px; color:var(--muted); letter-spacing:.06em;
  margin-bottom:20px;
}
.breadcrumb a:hover{ color:var(--ink) }
.dark .breadcrumb a:hover{ color:#fff }
.breadcrumb .sep{ opacity:.4 }

/* ---------- SPLIT SECTION ---------- */
.split{
  display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center;
}
@media (max-width:900px){ .split{ grid-template-columns:1fr; gap:40px } }
.split.reverse > *:first-child{ order:2 }
@media (max-width:900px){ .split.reverse > *:first-child{ order:0 } }

.split-visual{
  aspect-ratio:1/.9;
  border-radius:var(--radius-2xl);
  background:var(--bg-2);
  border:1px solid var(--line);
  padding:32px;
  position:relative;
  overflow:hidden;
}
.split-visual.dark-visual{ background:var(--ink-2); border-color:var(--ink-line-2); color:#fff }

/* Bullet list */
.check-list{ list-style:none; padding:0; margin:20px 0 0; display:flex; flex-direction:column; gap:12px }
.check-list li{
  padding-left:32px; position:relative; font-size:15px; line-height:1.55;
}
.check-list li::before{
  content:""; position:absolute; left:0; top:4px;
  width:20px; height:20px; border-radius:6px;
  background:var(--orange-soft) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23FF7A00' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") no-repeat center;
  background-size:12px;
}
.dark .check-list li::before{ background-color:rgba(255,122,0,.18) }

/* ---------- FAQ ---------- */
.faq-list{ display:flex; flex-direction:column; gap:12px; max-width:820px; margin:0 auto }
.faq-item{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden;
}
.faq-item summary{
  list-style:none; cursor:pointer;
  padding:22px 24px;
  display:flex; justify-content:space-between; align-items:center; gap:16px;
  font-weight:600; font-size:16px;
}
.faq-item summary::-webkit-details-marker{ display:none }
.faq-item .faq-plus{
  width:24px; height:24px; border-radius:8px;
  background:var(--bg-2); border:1px solid var(--line);
  display:inline-flex; align-items:center; justify-content:center;
  transition:background .2s, transform .2s;
  flex-shrink:0;
}
.faq-item[open] .faq-plus{ background:var(--orange); color:#fff; transform:rotate(45deg); border-color:var(--orange) }
.faq-item .faq-body{ padding:0 24px 22px; color:var(--muted); font-size:14.5px; line-height:1.65 }

/* ---------- ABOUT PAGE ---------- */
.story-grid{
  display:grid; grid-template-columns:1fr 2fr; gap:56px;
  align-items:start;
}
@media (max-width:900px){ .story-grid{ grid-template-columns:1fr; gap:32px } }
.story-grid .story-label{
  font-family:var(--f-mono); font-size:12px; color:var(--orange-text); letter-spacing:.14em; text-transform:uppercase;
  position:sticky; top:calc(var(--header-h) + 24px);
}
.story-grid p{ margin-bottom:20px; font-size:16.5px; line-height:1.7; color:var(--text-2) }

.values-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
}
@media (max-width:900px){ .values-grid{ grid-template-columns:1fr } }
.value{
  padding:32px; border-radius:var(--radius-lg);
  background:#fff; border:1px solid var(--line);
  position:relative;
}
.value .v-num{ font-family:var(--f-serif); font-style:italic; font-size:44px; color:var(--orange); line-height:1; margin-bottom:16px }
.value h3{ font-size:1.15rem; margin-bottom:10px }
.value p{ font-size:14.5px; color:var(--muted); line-height:1.6 }

.team-mosaic{
  display:grid; grid-template-columns:repeat(6,1fr); gap:12px;
}
.team-tile{
  aspect-ratio:1/1;
  border-radius:var(--radius);
  background:var(--grad-ink);
  position:relative; overflow:hidden;
  color:#fff;
  padding:16px;
  display:flex; flex-direction:column; justify-content:flex-end;
}
.team-tile::before{
  content:""; position:absolute; inset:0;
  background:radial-gradient(circle at 30% 30%, rgba(255,122,0,.4), transparent 60%);
}
.team-tile > *{ position:relative }
.team-tile.wide{ grid-column:span 2 }
.team-tile.tall{ grid-column:span 2; grid-row:span 2 }
.team-tile .t-role{ font-family:var(--f-mono); font-size:11px; color:var(--orange-2); letter-spacing:.1em; text-transform:uppercase }
.team-tile .t-name{ font-family:var(--f-display); font-size:16px; font-weight:600; margin-top:4px }
.team-tile .t-init{ position:absolute; top:16px; right:16px; width:32px; height:32px; border-radius:50%; background:rgba(255,255,255,.15); backdrop-filter:blur(4px); display:inline-flex; align-items:center; justify-content:center; font-size:12px; font-weight:700 }
@media (max-width:800px){ .team-mosaic{ grid-template-columns:repeat(3,1fr) } .team-tile.tall{ grid-row:span 1 } }
@media (max-width:500px){ .team-mosaic{ grid-template-columns:repeat(2,1fr) } }

/* ---------- PORTFOLIO ---------- */
.filter-row{
  display:flex; gap:8px; flex-wrap:wrap;
  margin-bottom:40px;
}
.filter-btn{
  padding:8px 16px; border-radius:999px;
  background:#fff; border:1px solid var(--line);
  font-size:13.5px; font-weight:500; color:var(--text-2);
  transition:all .2s;
}
.filter-btn:hover{ border-color:var(--ink) }
.filter-btn.active{ background:var(--ink); color:#fff; border-color:var(--ink) }

.portfolio-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:24px;
}
@media (max-width:900px){ .portfolio-grid{ grid-template-columns:repeat(2,1fr) } }
@media (max-width:600px){ .portfolio-grid{ grid-template-columns:1fr } }
.pf-card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg);
  overflow:hidden;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
  cursor:pointer;
}
.pf-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-lg) }
.pf-img{
  aspect-ratio:4/3;
  position:relative;
  overflow:hidden;
  background:var(--bg-3);
}
.pf-img .pf-cover{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  color:#fff; padding:24px;
  transition:transform .5s var(--ease);
}
.pf-card:hover .pf-cover{ transform:scale(1.05) }
.pf-cover .pf-mock{
  width:82%; height:70%;
  background:rgba(255,255,255,.12);
  border-radius:12px;
  border:1px solid rgba(255,255,255,.15);
  backdrop-filter:blur(4px);
  padding:14px;
  display:flex; flex-direction:column; gap:8px;
}
.pf-cover .pf-mock .pf-bar{ height:8px; background:rgba(255,255,255,.25); border-radius:4px; width:70% }
.pf-cover .pf-mock .pf-bar.a{ width:40% } .pf-cover .pf-mock .pf-bar.b{ width:85% }
.pf-cover .pf-mock .pf-stat{ margin-top:auto; font-family:var(--f-display); font-size:28px; font-weight:700; color:#fff }
.pf-body{ padding:22px }
.pf-cat{ font-family:var(--f-mono); font-size:11.5px; color:var(--orange-text); letter-spacing:.12em; text-transform:uppercase }
.pf-body h3{ font-size:1.15rem; margin-top:10px }
.pf-body p{ font-size:14px; color:var(--muted); margin-top:8px; line-height:1.6 }
.pf-tech{ display:flex; gap:6px; flex-wrap:wrap; margin-top:16px }
.pf-tech span{ font-family:var(--f-mono); font-size:11px; padding:3px 8px; border-radius:6px; background:var(--bg-2); color:var(--text-2) }

/* ---------- CONTACT ---------- */
.contact-grid{
  display:grid; grid-template-columns:1.2fr .8fr; gap:56px;
  align-items:start;
}
@media (max-width:900px){ .contact-grid{ grid-template-columns:1fr } }
.contact-form{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius-2xl);
  padding:40px;
}
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px }
@media (max-width:560px){ .form-row{ grid-template-columns:1fr } }
.form-group{ margin-bottom:16px }
.form-group label{ display:block; font-size:13px; font-weight:600; margin-bottom:8px; font-family:var(--f-mono); letter-spacing:.06em; text-transform:uppercase; color:var(--text-2) }
.form-input, .form-textarea{
  width:100%; padding:14px 16px;
  border:1px solid var(--line);
  border-radius:12px;
  font-family:var(--f-body); font-size:15px;
  background:var(--bg-2);
  color:var(--ink);
  transition:border-color .2s, background .2s, box-shadow .2s;
}
.form-input:focus, .form-textarea:focus{
  outline:none; border-color:var(--orange); background:#fff;
  box-shadow:0 0 0 4px rgba(255,122,0,.15);
}
.form-textarea{ min-height:130px; resize:vertical; font-family:var(--f-body) }
.contact-info-card{
  background:var(--ink-2); color:#fff;
  border-radius:var(--radius-2xl);
  padding:36px;
  border:1px solid var(--ink-line-2);
  position:relative;
  overflow:hidden;
}
.contact-info-card::before{
  content:""; position:absolute; top:-60px; right:-60px; width:220px; height:220px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,122,0,.35), transparent 60%);
}
.contact-info-card > *{ position:relative }
.contact-info-card h3{ color:#fff; margin-bottom:20px }
.contact-info-item{
  display:flex; gap:14px; padding:16px 0;
  border-bottom:1px solid var(--ink-line);
}
.contact-info-item:last-child{ border-bottom:0 }
.contact-info-item .ci-ico{
  width:38px; height:38px; border-radius:10px;
  background:rgba(255,122,0,.15); color:var(--orange-2);
  display:inline-flex; align-items:center; justify-content:center; flex-shrink:0;
}
.contact-info-item .ci-label{ font-family:var(--f-mono); font-size:11px; letter-spacing:.14em; color:#9096A2; text-transform:uppercase }
.contact-info-item .ci-value{ font-size:14.5px; color:#fff; margin-top:2px; word-break:break-word }

.map-block{
  margin-top:28px;
  aspect-ratio:16/8;
  border-radius:var(--radius-lg);
  overflow:hidden;
  border:1px solid var(--line);
  position:relative;
  background:
    radial-gradient(circle at 40% 60%, rgba(255,122,0,.15), transparent 30%),
    linear-gradient(180deg, #ECEEF3 0%, #DDE1EA 100%);
}
.map-block::before{
  content:""; position:absolute; inset:0;
  background-image:
    linear-gradient(to right, rgba(17,17,17,.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(17,17,17,.06) 1px, transparent 1px);
  background-size:40px 40px;
}
.map-pin{
  position:absolute; top:52%; left:40%; transform:translate(-50%,-50%);
  width:38px; height:38px; border-radius:50%;
  background:var(--orange); border:4px solid #fff;
  box-shadow:0 8px 20px -8px rgba(255,122,0,.6);
  display:inline-flex; align-items:center; justify-content:center;
  color:#fff;
}
.map-pin::after{
  content:""; position:absolute; inset:-8px; border-radius:50%;
  border:2px solid var(--orange); opacity:.4;
  animation:pulse 2.5s ease-out infinite;
}
@keyframes pulse{ 0%{ transform:scale(1); opacity:.6 } 100%{ transform:scale(2.5); opacity:0 } }

/* ---------- SERVICE PAGE FEATURE ROW ---------- */
.feat-row{
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
}
@media (max-width:900px){ .feat-row{ grid-template-columns:1fr } }
.feat-card{
  padding:32px; border-radius:var(--radius-lg);
  background:#fff; border:1px solid var(--line);
  transition:border-color .2s, transform .2s;
}
.feat-card:hover{ border-color:var(--ink); transform:translateY(-2px) }
.feat-card .f-ico{
  width:52px; height:52px; border-radius:14px;
  background:var(--grad-orange); color:#fff;
  display:inline-flex; align-items:center; justify-content:center;
  margin-bottom:22px; box-shadow:0 12px 26px -12px rgba(255,122,0,.6);
}
.feat-card h3{ font-size:1.2rem; margin-bottom:10px }
.feat-card p{ font-size:14.5px; color:var(--muted); line-height:1.6 }

/* Service feature large */
.svc-feature-grid{
  display:grid; grid-template-columns:repeat(6,1fr); gap:16px;
}
.svc-feature{
  padding:32px; border-radius:var(--radius-lg);
  background:#fff; border:1px solid var(--line);
  display:flex; flex-direction:column;
  min-height:260px;
  position:relative;
  overflow:hidden;
}
.svc-feature.wide{ grid-column:span 3 }
.svc-feature.med{ grid-column:span 3 }
.svc-feature.small{ grid-column:span 2 }
.svc-feature.full{ grid-column:span 6 }
.svc-feature.full p{ max-width:640px }
.svc-feature.full .sf-list{ margin-top:18px }
.svc-feature.hero{
  grid-column:span 4;
  background:var(--ink-2); color:#fff; border-color:var(--ink-line-2);
  padding:40px;
}
.svc-feature.hero .sf-visual{
  position:absolute; right:0; bottom:0;
  width:340px; height:340px;
  background:radial-gradient(circle at 30% 30%, rgba(255,122,0,.4), transparent 60%);
  transform:translate(30%, 30%);
}
.svc-feature.hero h3{ font-size:1.7rem }
.svc-feature.hero p{ color:#B8BCC6; max-width:380px; margin-top:12px }
.svc-feature .sf-num{ font-family:var(--f-mono); font-size:11.5px; letter-spacing:.14em; color:var(--muted); text-transform:uppercase }
.svc-feature.hero .sf-num{ color:var(--orange-2) }
.svc-feature h3{ margin-top:16px; font-size:1.3rem }
.svc-feature p{ margin-top:10px; color:var(--muted); font-size:14.5px; line-height:1.6; flex:1 }
.svc-feature .sf-list{
  list-style:none; padding:0; margin:16px 0 0;
  display:flex; flex-wrap:wrap; gap:6px;
}
.svc-feature .sf-list li{
  font-family:var(--f-mono); font-size:11.5px;
  padding:4px 10px; border-radius:999px;
  background:var(--bg-2); border:1px solid var(--line);
  color:var(--text-2);
}
.svc-feature.hero .sf-list li{ background:rgba(255,255,255,.06); color:#B8BCC6; border-color:var(--ink-line-2) }
@media (max-width:900px){
  .svc-feature-grid{ grid-template-columns:repeat(2,1fr) }
  .svc-feature.hero, .svc-feature.wide, .svc-feature.med, .svc-feature.small, .svc-feature.full{ grid-column:span 2 }
}
@media (max-width:560px){
  .svc-feature-grid{ grid-template-columns:1fr }
  .svc-feature.hero, .svc-feature.wide, .svc-feature.med, .svc-feature.small, .svc-feature.full{ grid-column:span 1 }
}

/* HERO STAT ROW */
.hero-stat-row{
  display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:40px;
}
@media (max-width:700px){ .hero-stat-row{ grid-template-columns:repeat(2,1fr) } }
.hero-stat{ padding:20px; background:#fff; border:1px solid var(--line); border-radius:var(--radius) }
.dark .hero-stat, .dark-hero .hero-stat{ background:rgba(255,255,255,.04); border-color:var(--ink-line-2) }
.hero-stat .hs-num{ font-family:var(--f-display); font-size:28px; font-weight:700; letter-spacing:-.02em }
.hero-stat .hs-num .plus{ color:var(--orange); font-family:var(--f-serif); font-style:italic; font-weight:400 }
.hero-stat .hs-lbl{ font-size:12.5px; color:var(--muted); font-family:var(--f-mono); text-transform:uppercase; letter-spacing:.05em; margin-top:4px }

/* ---------- REVEAL ---------- */
.reveal{ opacity:0; transform:translateY(16px); transition:opacity .7s var(--ease), transform .7s var(--ease) }
.reveal.on{ opacity:1; transform:none }

/* ---------- MISC ---------- */
::selection{ background:var(--orange); color:#fff }

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