/* ============================================================
   SALESPIRIT website
   Cream + dark mixed sections · Salespirit blue accent
   ============================================================ */
:root{
  --cream:#e9e5de;          /* warm cream canvas */
  --cream-2:#f2efee;        /* lighter card on cream */
  --cream-3:#e2ddd4;        /* slightly deeper cream */
  --dark:#090909;           /* near-black section */
  --dark-2:#141312;         /* dark card */
  --dark-3:#1c1a18;
  --ink:#101010;            /* primary text on cream */
  --ink-mut:#504d47;        /* muted text on cream — ≥4.5:1 on --cream */
  --line-d:#dcd6cb;         /* hairline on cream */
  --line-k:#262320;         /* hairline on dark */
  --white:#ffffff;
  --mut-d:#9a958c;          /* muted on dark */
  --mut-d2:#858178;
  /* Salespirit blue (replaces Ignitx orange) */
  --acc:#2b6fff;
  --acc-2:#1b7ef3;
  --acc-deep:#1b51d6;
  --acc-soft:#5b8cff;
  --on-acc:#ffffff;

  --maxw:1240px;
  --gut:clamp(20px,5vw,72px);
  --r:22px;
  --r-sm:14px;
  --ease:cubic-bezier(.22,1,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--cream);color:var(--ink);
  font-size:17px;line-height:1.6;font-weight:400;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
::selection{background:var(--acc);color:#fff;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
button{font-family:inherit;cursor:pointer;border:0;background:none;}

/* ---------- type ---------- */
h1,h2,h3{letter-spacing:-.03em;line-height:1.0;font-weight:500;}
.display{font-weight:500;letter-spacing:-.035em;line-height:.98;}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:13.5px;font-weight:500;color:var(--ink);}
.eyebrow .x{color:var(--acc);font-size:15px;line-height:1;}
.eyebrow.on-dark{color:#fff;}
.section .eyebrow{margin-bottom:22px;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);}
.section{padding:clamp(72px,9vw,140px) 0;position:relative;contain:layout style;}
.section.dark{background:var(--dark);color:#fff;}
.section.dark .eyebrow{color:#fff;}
.section.dark h1,.section.dark h2,.section.dark h3{color:#fff;}

/* reveal on scroll */
.rv{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease);will-change:opacity,transform;}
.rv.in{opacity:1;transform:none;will-change:auto;}
.rv.d1{transition-delay:.08s}.rv.d2{transition-delay:.16s}.rv.d3{transition-delay:.24s}.rv.d4{transition-delay:.32s}

.progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--acc);z-index:300;}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:12px;font-size:15px;font-weight:500;padding:9px 9px 9px 26px;border-radius:100px;transition:transform .25s var(--ease),background .25s,color .25s;}
.btn:not(:has(.ic)){padding:13px 26px;}
.btn .ic{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .3s var(--ease);}
.btn .ic svg{width:16px;height:16px;}
.btn:hover .ic{transform:rotate(45deg);}
.btn-acc{background:var(--acc);color:#fff;}
.btn-acc .ic{background:#fff;color:var(--acc);}
.btn-acc:hover{background:var(--acc-deep);transform:translateY(-2px);}
.btn-dark{background:var(--dark);color:#fff;}
.btn-dark .ic{background:var(--acc);color:#fff;}
.btn-dark:hover{transform:translateY(-2px);}
.btn-light{background:#fff;color:var(--ink);}
.btn-light .ic{background:var(--acc);color:#fff;}
.btn-light:hover{transform:translateY(-2px);}
/* text link with underline arrow */
.tlink{display:inline-flex;align-items:center;gap:12px;font-weight:500;color:var(--acc);border-bottom:1px solid var(--acc);padding-bottom:6px;transition:gap .25s var(--ease);}
.tlink:hover{gap:18px;}

/* ============================================================ NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;padding:0 var(--gut);transition:transform .4s var(--ease);}
.nav-inner{max-width:var(--maxw);margin:18px auto 0;display:flex;align-items:center;justify-content:space-between;
  padding:13px 13px 13px 28px;border-radius:100px;
  background:rgba(255,255,255,.1);-webkit-backdrop-filter:blur(16px) saturate(140%);backdrop-filter:blur(16px) saturate(140%);
  border:1px solid rgba(255,255,255,.14);transition:background .3s,border-color .3s;}
.nav.scrolled .nav-inner{background:rgba(20,19,18,.82);border-color:rgba(255,255,255,.08);}
.nav.up{transform:translateY(-160%);}
.nav-logo{font-weight:600;font-size:21px;letter-spacing:.02em;color:#fff;}
.nav-menu{display:flex;align-items:center;gap:4px;}
.nav-menu a{font-size:15px;font-weight:400;color:rgba(255,255,255,.85);padding:9px 16px;border-radius:100px;transition:color .2s,background .2s;cursor:pointer;}
.nav-menu a:hover{color:#fff;background:rgba(255,255,255,.1);}
.nav-menu a.on{color:#fff;background:rgba(255,255,255,.14);}
.nav-cta{display:inline-flex;align-items:center;gap:11px;background:var(--dark);color:#fff;font-size:14.5px;font-weight:500;padding:9px 9px 9px 20px;border-radius:100px;transition:transform .25s var(--ease),background .25s;}
.nav-cta .ic{width:30px;height:30px;border-radius:50%;background:var(--acc);display:flex;align-items:center;justify-content:center;}
.nav-cta .ic svg{width:14px;height:14px;}
.nav-cta:hover{background:#000;transform:translateY(-1px);}
.burger{display:none;width:46px;height:46px;border-radius:50%;border:1px solid rgba(255,255,255,.2);align-items:center;justify-content:center;color:#fff;background:rgba(255,255,255,.08);}
.burger svg{width:22px;height:22px;}
@media(max-width:960px){
  .nav-menu{display:none;}
  .nav.open .nav-menu{display:flex;flex-direction:column;align-items:stretch;position:absolute;top:calc(100% + 8px);left:var(--gut);right:var(--gut);background:var(--dark-2);border:1px solid var(--line-k);border-radius:22px;padding:10px;gap:2px;}
  .nav.open .nav-menu a{padding:14px 18px;color:#fff;}
  .burger{display:inline-flex;}
  .nav-cta{display:none;}
}

/* language switcher */
.lang-switch{display:inline-flex;align-items:center;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);border-radius:100px;padding:3px;}
.lang-switch button{font-size:13px;font-weight:600;letter-spacing:.03em;color:rgba(255,255,255,.7);background:none;border:none;cursor:pointer;padding:6px 12px;border-radius:100px;transition:color .2s,background .2s;}
.lang-switch button.on{color:#fff;background:var(--acc);}
.lang-switch button:not(.on):hover{color:#fff;}

/* mobile menu: contact link + lang switch in dropdown */
.menu-mobile-only{display:none;}
@media(max-width:960px){
  .lang-nav{display:none;}
  .nav.open .menu-mobile-only{display:flex;flex-direction:column;gap:2px;border-top:1px solid var(--line-k);padding-top:10px;margin-top:8px;}
  .nav.open .menu-mobile-only > a{padding:14px 18px;color:#fff;border-radius:14px;}
  .nav.open .menu-mobile-only > a.cta-row{background:var(--acc);font-weight:500;display:flex;align-items:center;justify-content:space-between;}
  .nav.open .lang-mobile{align-self:center;margin-top:4px;}
  .menu-mobile-only{display:flex;}
}

/* page system */
.page{display:none;}
.page.active{display:block;}
.page.active>*{animation:pin .6s var(--ease) both;}
@keyframes pin{from{opacity:0}to{opacity:1}}

/* ============================================================ HERO */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;}
.hero-bg{position:absolute;inset:0;z-index:0;background:#0a0a0b;}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center right;}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(8,8,9,.97) 0%,rgba(8,8,9,.92) 30%,rgba(8,8,9,.55) 55%,rgba(8,8,9,.15) 78%,rgba(8,8,9,.35) 100%);}
.hero .wrap{position:relative;z-index:2;width:100%;padding-top:120px;padding-bottom:60px;}
.hero h1{color:#fff;font-size:clamp(46px,8vw,104px);max-width:14ch;}
.hero-sub{color:rgba(255,255,255,.82);font-size:clamp(16px,1.4vw,19px);max-width:48ch;margin-top:28px;line-height:1.6;}
.hero-cta{margin-top:38px;}
.hero-follow{position:absolute;left:var(--gut);bottom:40px;z-index:2;font-size:13px;letter-spacing:.04em;color:rgba(255,255,255,.7);}
/* floating glass stat card */
.hero-card{position:absolute;right:var(--gut);bottom:48px;z-index:2;width:min(360px,42vw);background:rgba(255,255,255,.1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.18);border-radius:22px;overflow:hidden;}
.hero-card .top{padding:22px 24px;font-size:13px;font-weight:600;letter-spacing:.04em;color:rgba(255,255,255,.8);text-transform:uppercase;}
.hero-card .body{background:#fff;padding:22px 24px;}
.hero-card .lg-row{display:flex;justify-content:space-between;align-items:center;}
.hero-card .lg-row .lbl{font-weight:600;font-size:15px;color:var(--ink);}
.hero-card .avs{display:flex;}
.hero-card .avs span{width:26px;height:26px;border-radius:50%;border:2px solid #fff;margin-left:-8px;background:var(--cream-3);}
.hero-card .pct{font-size:clamp(34px,4vw,48px);font-weight:600;color:var(--ink);letter-spacing:-.03em;margin-top:8px;}
.hero-card .pct span{font-size:14px;font-weight:400;color:var(--ink-mut);letter-spacing:0;margin-left:8px;}
.hero-card .bars{display:flex;gap:4px;align-items:flex-end;height:54px;margin-top:14px;}
.hero-card .bars i{flex:1;background:var(--acc);border-radius:2px;opacity:.9;}
@media(max-width:860px){
  .hero-bg img{object-position:center 30%;}
  .hero-bg::after{background:linear-gradient(180deg,rgba(8,8,9,.55) 0%,rgba(8,8,9,.35) 35%,rgba(8,8,9,.85) 75%,rgba(8,8,9,.96) 100%);}
  .hero{flex-direction:column;align-items:stretch;justify-content:flex-end;padding-top:120px;padding-bottom:40px;min-height:100svh;gap:32px;}
  .hero .wrap{width:100%;}
  .hero-card{position:static;width:100%;max-width:none;}
  .hero-follow{display:none;}
}

/* ============================================================ INTRO / ABOUT split */
.intro h2{font-size:clamp(28px,3.6vw,52px);font-weight:500;max-width:24ch;letter-spacing:-.025em;line-height:1.12;}
.intro .top{display:grid;grid-template-columns:.5fr 1fr;gap:clamp(30px,5vw,70px);align-items:start;padding-bottom:clamp(40px,5vw,64px);border-bottom:1px solid var(--line-d);}
.intro .stat-big{font-size:clamp(44px,5vw,64px);font-weight:500;letter-spacing:-.03em;}
.intro .stat-lbl{color:var(--ink-mut);font-size:15px;margin-top:6px;}
.feature-row{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;margin-top:clamp(40px,5vw,64px);}
.feature-img{border-radius:var(--r);overflow:hidden;aspect-ratio:16/11;background:var(--cream-3);}
.feature-img img{width:100%;height:100%;object-fit:cover;}
.feature-panel{background:var(--cream-2);border-radius:var(--r);padding:clamp(28px,3vw,44px);display:flex;flex-direction:column;}
.feature-panel .pct{font-size:clamp(40px,4.6vw,64px);font-weight:500;letter-spacing:-.03em;}
.feature-panel .desc{color:var(--ink-mut);font-size:15px;margin-top:12px;max-width:36ch;}
.feature-panel .foot{margin-top:auto;padding-top:28px;font-size:clamp(16px,1.5vw,19px);font-weight:450;line-height:1.4;}
.feature-cta{display:flex;align-items:center;gap:18px;margin-top:24px;}
.feature-cta .sq{width:74px;height:74px;border-radius:16px;background:var(--acc);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .3s var(--ease);}
.feature-cta .sq:hover{transform:rotate(45deg);}
.feature-cta .sq svg{width:26px;height:26px;color:#fff;}
.feature-cta .lbl{font-size:16px;font-weight:450;line-height:1.3;}
@media(max-width:820px){.intro .top{grid-template-columns:1fr;}.feature-row{grid-template-columns:1fr;}}

/* stat trio cards */
.statband{display:grid;grid-template-columns:1.3fr 1fr;gap:24px;}
.stat-card{background:var(--cream-2);border-radius:var(--r);padding:clamp(26px,2.6vw,38px);display:flex;align-items:center;gap:40px;position:relative;overflow:hidden;}
.stat-card .col .n{font-size:clamp(34px,3.6vw,52px);font-weight:500;letter-spacing:-.03em;}
.stat-card .col .l{color:var(--ink-mut);font-size:14px;margin-top:4px;}
.stat-card.media{padding:0;}
.stat-card.media img{width:100%;height:100%;object-fit:cover;}
.stat-chart{background:var(--cream-2);border-radius:var(--r);padding:clamp(26px,2.6vw,38px);display:flex;flex-direction:column;justify-content:space-between;}
.stat-chart .bars{display:flex;gap:6px;align-items:flex-end;height:90px;margin-bottom:24px;}
.stat-chart .bars i{flex:1;background:linear-gradient(180deg,var(--acc),var(--acc-soft));border-radius:3px;}
.stat-chart p{font-size:16px;font-weight:450;line-height:1.4;}
@media(max-width:820px){.statband{grid-template-columns:1fr;}}

/* ============================================================ WHY CHOOSE bento grid */
.why-head{display:grid;grid-template-columns:.5fr 1fr;gap:clamp(30px,5vw,70px);align-items:start;margin-bottom:clamp(36px,4vw,56px);}
.why-head h2{font-size:clamp(28px,3.4vw,50px);font-weight:500;letter-spacing:-.025em;line-height:1.12;max-width:24ch;}
.why-head .eyebrow{margin-top:6px;}
@media(max-width:820px){.why-head{grid-template-columns:1fr;}}
.bento{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.bento .cell{background:var(--cream-2);border-radius:var(--r);padding:clamp(26px,2.4vw,38px);position:relative;overflow:hidden;display:flex;flex-direction:column;min-height:300px;}
.bento h3{font-size:clamp(20px,1.9vw,24px);font-weight:500;}
.bento .lead{color:var(--ink-mut);font-size:14.5px;margin-top:12px;max-width:30ch;line-height:1.55;}
.cell-trust{grid-column:span 1;background:#1a1a1c;color:#fff;justify-content:flex-end;}
.cell-trust::before{content:'';position:absolute;inset:0;background:url('../img/portrait-red.jpg') center/cover;opacity:1;}
.cell-trust::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.15) 0%,rgba(0,0,0,.45) 50%,rgba(0,0,0,.78) 100%);}
.cell-trust>*{position:relative;z-index:1;}
.cell-trust h3{color:#fff;}
.cell-trust .lead{color:rgba(255,255,255,.78);}
.cell-trust .big{font-size:clamp(48px,5vw,72px);font-weight:500;letter-spacing:-.03em;margin-top:auto;line-height:1;}
.cell-trust .cap{font-size:14.5px;color:rgba(255,255,255,.85);margin-top:8px;}
.cell-roi{grid-column:span 1;}
.roi-mock{margin-top:auto;background:#fff;border-radius:14px;padding:16px;position:relative;box-shadow:0 12px 30px rgba(16,16,16,.07);}
.roi-share{position:absolute;top:-16px;right:14px;display:flex;align-items:center;gap:6px;background:var(--dark);border-radius:100px;padding:6px 7px;box-shadow:0 8px 20px rgba(9,9,9,.28);}
.roi-share .s{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;}
.roi-share .s svg{width:15px;height:15px;}
.roi-share .lbl{color:#fff;font-size:12px;font-weight:500;padding:0 10px 0 4px;}
.roi-row{height:14px;border-radius:5px;background:var(--cream-3);margin-top:10px;}
.roi-row.w1{width:38px;height:38px;border-radius:9px;}
.roi-row.w2{width:100%;margin-top:18px;}
.roi-bars{display:flex;gap:8px;margin-top:10px;}
.roi-bars i{height:14px;border-radius:5px;background:var(--cream-3);}
.cell-ret{grid-column:span 1;}
.cell-ret .big{font-size:clamp(56px,6vw,92px);font-weight:500;letter-spacing:-.03em;line-height:.95;}
.cell-ret .lead{font-size:16px;color:var(--ink);max-width:26ch;margin-top:14px;}
.cell-ret .avs{display:flex;align-items:center;margin-top:auto;padding-top:26px;}
.cell-ret .avs .av{width:46px;height:46px;border-radius:50%;border:3px solid var(--cream-2);margin-left:-12px;overflow:hidden;background:var(--cream-3);}
.cell-ret .avs .av:first-child{margin-left:0;}
.cell-ret .avs .av img{width:100%;height:100%;object-fit:cover;}
.cell-ret .avs .more{width:46px;height:46px;border-radius:50%;background:var(--dark);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;margin-left:-12px;border:3px solid var(--cream-2);}
.cell-ret .trust-cap{font-size:14.5px;font-weight:500;margin-top:16px;}
.bento .cell-behav{grid-column:span 2;flex-direction:row;align-items:stretch;gap:clamp(20px,2vw,36px);}
.cell-behav .txt{flex:1;display:flex;flex-direction:column;}
.cell-behav .stat-pair{display:flex;gap:40px;margin-top:auto;padding-top:24px;}
.cell-behav .stat-pair .n{font-size:clamp(34px,3.4vw,48px);font-weight:500;letter-spacing:-.03em;}
.cell-behav .stat-pair .l{color:var(--ink-mut);font-size:13.5px;margin-top:2px;}
.cell-behav .phone{width:clamp(120px,12vw,168px);flex-shrink:0;border-radius:18px;overflow:hidden;background:var(--dark-3);align-self:stretch;}
.cell-behav .phone img{width:100%;height:100%;object-fit:cover;}
.cell-chart{grid-column:span 1;}
.cell-chart .tabs{display:flex;align-items:center;gap:14px;font-size:15px;color:var(--ink-mut);font-weight:450;}
.cell-chart .tabs b{color:var(--ink);font-weight:500;}
.cell-chart .tabs .dot{width:4px;height:4px;border-radius:50%;background:var(--ink-mut);}
.cell-chart .bars{display:flex;gap:7px;align-items:flex-end;height:clamp(120px,14vw,190px);margin-top:auto;}
.cell-chart .bars i{flex:1;background:linear-gradient(180deg,var(--acc-soft),var(--acc));border-radius:4px 4px 0 0;transform-origin:bottom;animation:growbar .9s var(--ease) both;}
@keyframes growbar{from{transform:scaleY(0)}to{transform:scaleY(1)}}
@media(max-width:980px){.bento{grid-template-columns:1fr 1fr;}.bento .cell-behav{grid-column:span 2;}.cell-chart{grid-column:span 2;}}
@media(max-width:680px){.bento{grid-template-columns:1fr;}.bento .cell,.bento .cell-behav,.cell-chart{grid-column:span 1;}.bento .cell-behav{flex-direction:column;}.cell-behav .phone{width:100%;height:200px;align-self:auto;}}

/* ============================================================ SERVICES (dark accordion) */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:clamp(36px,4vw,56px);}
.sec-head h2{font-size:clamp(40px,6vw,84px);font-weight:500;}
.svc-list{border-top:1px solid var(--line-k);}
.svc-item{border-bottom:1px solid var(--line-k);padding:clamp(26px,3vw,40px) 0;cursor:pointer;}
.svc-row{display:grid;grid-template-columns:40px 1fr auto;gap:24px;align-items:baseline;}
.svc-row .ar{font-size:22px;color:var(--mut-d);transition:transform .35s var(--ease);}
.svc-item.open .svc-row .ar{transform:rotate(90deg);color:var(--acc);}
.svc-name{font-size:clamp(26px,3.6vw,46px);font-weight:500;color:#fff;}
.svc-name .no{font-size:14px;color:var(--mut-d);vertical-align:super;margin-left:8px;}
.svc-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .55s var(--ease);}
.svc-body .svc-inner{overflow:hidden;}
.svc-item.open .svc-body{grid-template-rows:1fr;}
.svc-inner{padding-top:26px;display:grid;grid-template-columns:40px 1fr;gap:24px;}
.svc-detail p{color:var(--mut-d);font-size:16px;max-width:52ch;line-height:1.6;}
.svc-thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:24px;max-width:620px;}

/* ============================================================ SERVICES home (expanding columns, Option C) */
.svc-track{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:8px;margin-top:8px;height:clamp(340px,42vw,460px);transition:grid-template-columns .55s cubic-bezier(.4,0,.2,1);}
.svc-track:has(.svc-tile:nth-child(1):hover){grid-template-columns:2.5fr 1fr 1fr 1fr;}
.svc-track:has(.svc-tile:nth-child(2):hover){grid-template-columns:1fr 2.5fr 1fr 1fr;}
.svc-track:has(.svc-tile:nth-child(3):hover){grid-template-columns:1fr 1fr 2.5fr 1fr;}
.svc-track:has(.svc-tile:nth-child(4):hover){grid-template-columns:1fr 1fr 1fr 2.5fr;}
.svc-tile{position:relative;display:flex;flex-direction:column;justify-content:flex-end;background:var(--dark-2);border-radius:var(--r);padding:clamp(22px,2.4vw,32px);overflow:hidden;text-decoration:none;color:#fff;cursor:pointer;transition:background .4s var(--ease);}
.svc-tile:hover{background:#1c1c20;}
.svc-tile::after{content:'';position:absolute;top:clamp(20px,2vw,28px);right:clamp(20px,2vw,28px);width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.08);transition:background .35s var(--ease),transform .35s var(--ease);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2'%3E%3Cpath d='M5 12h14M13 6l6 6-6 6'/%3E%3C/svg%3E");background-position:center;background-repeat:no-repeat;background-size:14px;}
.svc-tile:hover::after{background-color:var(--acc);transform:rotate(-45deg);}
.svc-tile-no{position:absolute;top:clamp(22px,2.4vw,32px);left:clamp(22px,2.4vw,32px);font-size:13px;font-weight:600;letter-spacing:.08em;color:var(--acc);}
.svc-tile-name{display:block;writing-mode:vertical-rl;transform:rotate(180deg);font-size:clamp(20px,2.2vw,30px);font-weight:500;letter-spacing:-.01em;color:#fff;align-self:flex-start;margin-bottom:auto;margin-top:clamp(50px,5vw,70px);transition:writing-mode .35s ease,transform .35s ease,font-size .35s var(--ease);}
.svc-tile:hover .svc-tile-name{writing-mode:horizontal-tb;transform:none;font-size:clamp(26px,3vw,42px);margin-top:auto;}
.svc-tile-desc{color:rgba(255,255,255,.65);font-size:15px;line-height:1.55;max-height:0;opacity:0;overflow:hidden;margin-top:0;transition:max-height .45s var(--ease),opacity .35s var(--ease),margin-top .45s var(--ease);}
.svc-tile:hover .svc-tile-desc{max-height:140px;opacity:1;margin-top:12px;}
@media(max-width:760px){
  .svc-track{grid-template-columns:1fr !important;height:auto;gap:10px;}
  .svc-tile{min-height:130px;padding:24px;justify-content:flex-end;}
  .svc-tile-name{writing-mode:horizontal-tb;transform:none;font-size:24px;margin-top:30px;}
  .svc-tile-desc{max-height:200px;opacity:1;margin-top:10px;}
}
.svc-thumbs .t{aspect-ratio:1/1;border-radius:14px;overflow:hidden;background:var(--dark-3);}
.svc-thumbs .t img{width:100%;height:100%;object-fit:cover;}
@media(max-width:680px){.svc-thumbs{grid-template-columns:1fr 1fr;}.svc-inner{grid-template-columns:1fr;}.svc-row{grid-template-columns:1fr auto;}.svc-row .no-col{display:none;}}

/* ============================================================ TEAM */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,32px);}
.tm{display:flex;flex-direction:column;}
.tm-img{aspect-ratio:1/1;border-radius:18px;overflow:hidden;background:var(--dark-3);}
.tm-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(.15);transition:transform .7s var(--ease),filter .5s;}
.tm:hover .tm-img img{transform:scale(1.04);filter:none;}
.tm h3{font-size:clamp(18px,1.9vw,22px);font-weight:500;margin-top:20px;text-align:center;}
.tm .role{color:var(--mut-d);font-size:14px;margin-top:5px;text-align:center;}
.section:not(.dark) .tm .role{color:var(--ink-mut);}
@media(max-width:760px){.team-grid{grid-template-columns:1fr 1fr;gap:18px;}}

/* ============================================================ FAQ */
.faq-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(30px,4vw,56px);align-items:start;}
.faq-img{border-radius:var(--r);overflow:hidden;background:var(--cream-3);aspect-ratio:4/4.4;position:sticky;top:110px;}
.faq-img img{width:100%;height:100%;object-fit:cover;}
.faq-list{border-top:1px solid var(--line-d);}
.faq-item{border-bottom:1px solid var(--line-d);padding:clamp(22px,2.4vw,30px) 0;cursor:pointer;}
.faq-q{display:grid;grid-template-columns:1fr 38px;gap:24px;align-items:center;}
.faq-q h3{font-size:clamp(19px,1.8vw,23px);font-weight:500;letter-spacing:-.01em;line-height:1.25;}
.faq-tog{width:38px;height:38px;border-radius:50%;background:#fff;border:1px solid var(--line-d);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .3s var(--ease),border-color .3s,transform .3s var(--ease);}
.faq-tog svg{width:17px;height:17px;color:var(--ink);transition:transform .35s var(--ease),color .3s;}
.faq-item.open .faq-tog{background:var(--acc);border-color:var(--acc);}
.faq-item.open .faq-tog svg{transform:rotate(90deg);color:#fff;}
.faq-a{display:grid;grid-template-rows:0fr;transition:grid-template-rows .5s var(--ease),margin .5s var(--ease);}
.faq-a>*{overflow:hidden;}
.faq-item.open .faq-a{grid-template-rows:1fr;margin-top:16px;}
.faq-a p{color:var(--ink-mut);font-size:15.5px;line-height:1.6;max-width:60ch;padding-right:62px;}
@media(max-width:820px){.faq-grid{grid-template-columns:1fr;}.faq-img{position:relative;top:0;aspect-ratio:16/10;}}

/* ============================================================ PROJECT DETAIL */
.proj{cursor:pointer;}
.proj .scope{background:var(--acc);color:#fff;font-weight:500;}
.pdetail-hero{padding-top:clamp(140px,15vw,200px);padding-bottom:clamp(60px,8vw,110px);}
.pdetail-hero .phero-bg::after{background:linear-gradient(180deg,rgba(9,9,9,.62) 0%,rgba(9,9,9,.85) 100%);}
.back-link{display:inline-flex;align-items:center;gap:6px;color:rgba(255,255,255,.7);font-size:14.5px;font-weight:500;margin-bottom:24px;cursor:pointer;transition:color .2s;}
.back-link:hover{color:#fff;}
.pdetail-grid{display:grid;grid-template-columns:.7fr 1.3fr;gap:clamp(36px,6vw,80px);align-items:start;}
.pdetail-meta{position:sticky;top:110px;background:var(--cream-2);border-radius:var(--r);padding:clamp(24px,3vw,32px);}
.meta-row{display:flex;justify-content:space-between;gap:16px;padding:14px 0;border-bottom:1px solid var(--line-d);}
.meta-row:first-child{padding-top:0;}
.meta-l{color:var(--ink-mut);font-size:13.5px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;}
.meta-v{font-size:15px;font-weight:500;text-align:right;}
.pdetail-metrics{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:24px;}
.pdetail-metrics .n{font-size:clamp(30px,3vw,42px);font-weight:500;letter-spacing:-.03em;line-height:1;}
.pdetail-metrics .l{color:var(--ink-mut);font-size:12.5px;margin-top:6px;line-height:1.35;}
.pdetail-body h2{font-size:clamp(24px,2.6vw,34px);font-weight:500;letter-spacing:-.02em;margin:0 0 14px;}
.pdetail-body h2:not(:first-child){margin-top:36px;}
.pdetail-body p{color:var(--ink-mut);font-size:16.5px;line-height:1.65;max-width:62ch;}
@media(max-width:820px){.pdetail-grid{grid-template-columns:1fr;}.pdetail-meta{position:relative;top:0;}}

/* ============================================================ PRICING (dark) */
.price-card{display:grid;grid-template-columns:.85fr 1.15fr;gap:0;border:1px solid var(--line-k);border-radius:var(--r);overflow:hidden;}
.price-aside{position:relative;background:var(--dark-3);padding:clamp(28px,3vw,40px);min-height:340px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;}
.price-aside img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.42;}
.price-aside .pa-top,.price-aside .pa-bot{position:relative;z-index:1;}
.price-aside .pa-top{font-size:clamp(20px,2.2vw,26px);font-weight:500;color:#fff;}
.price-aside .pa-bot{color:var(--mut-d);font-size:14px;}
.price-main{padding:clamp(28px,3vw,44px);display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,3vw,48px);}
.price-main .amt{font-size:clamp(40px,4.6vw,60px);font-weight:500;letter-spacing:-.03em;color:#fff;}
.price-main .amt span{font-size:18px;color:var(--mut-d);font-weight:400;}
.price-main .pdesc{color:var(--mut-d);font-size:15px;margin-top:14px;line-height:1.6;}
.price-main .pbtn{margin-top:28px;}
.price-feats{list-style:none;display:flex;flex-direction:column;gap:0;}
.price-feats li{display:flex;align-items:center;gap:13px;padding:14px 0;border-bottom:1px solid var(--line-k);color:#fff;font-size:15.5px;}
.price-feats li:first-child{padding-top:0;}
.price-feats .ck{flex-shrink:0;width:18px;height:18px;color:var(--acc);}
@media(max-width:820px){.price-card{grid-template-columns:1fr;}.price-main{grid-template-columns:1fr;}.price-aside{min-height:200px;}}

/* compare table */
.ctable{width:100%;border-collapse:collapse;}
.ctable th,.ctable td{padding:22px 16px;text-align:center;border-bottom:1px solid var(--line-d);}
.ctable th:first-child,.ctable td:first-child{text-align:left;font-weight:450;}
.ctable thead th{font-weight:500;font-size:clamp(17px,1.8vw,22px);vertical-align:top;}
.ctable thead .per{display:block;font-size:13px;color:var(--ink-mut);font-weight:400;margin-top:4px;}
.ctable .yes{color:var(--acc);}
.ctable .no{color:#c9c3b8;}
.ctable .feat{color:var(--ink);}

/* ============================================================ TESTIMONIALS */
.tst-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.tst{background:var(--cream-2);border-radius:18px;padding:clamp(24px,2.4vw,32px);display:flex;flex-direction:column;}
.tst .q{font-size:34px;line-height:1;color:var(--acc);font-weight:600;margin-bottom:14px;}
.tst p{font-size:15.5px;line-height:1.6;color:var(--ink);}
.tst .who{display:flex;align-items:center;gap:13px;margin-top:24px;}
.tst .who .av{width:42px;height:42px;border-radius:50%;background:var(--cream-3);overflow:hidden;flex-shrink:0;}
.tst .who .av img{width:100%;height:100%;object-fit:cover;}
.tst .who h3,.tst .who h4{font-size:15px;font-weight:500;}
.tst .who .r{font-size:13px;color:var(--ink-mut);}
.tst.video{padding:0;overflow:hidden;position:relative;min-height:220px;}
.tst.video img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.6);}
.tst.video .play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:64px;height:64px;border-radius:50%;background:var(--acc);display:flex;align-items:center;justify-content:center;z-index:1;}
.tst.video .play svg{width:24px;height:24px;color:#fff;}
@media(max-width:860px){.tst-grid{grid-template-columns:1fr;}}

/* ============================================================ PAGE HERO (inner) */
.phero{position:relative;min-height:64vh;display:flex;align-items:flex-end;overflow:hidden;}
.phero-bg{position:absolute;inset:0;z-index:0;}
.phero-bg img{width:100%;height:100%;object-fit:cover;}
.phero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(9,9,9,.8),rgba(9,9,9,.35));}
#page-services .phero-bg::after{background:linear-gradient(90deg,rgba(9,9,9,.78) 0%,rgba(9,9,9,.55) 40%,rgba(9,9,9,.55) 60%,rgba(9,9,9,.78) 100%);}
#page-services .phero{min-height:94vh;align-items:stretch;padding-top:clamp(120px,12vw,180px);padding-bottom:clamp(50px,7vw,90px);}
#page-services .phero .wrap{display:flex;flex-direction:column;justify-content:space-between;width:100%;}
#page-services .phero .display{font-size:clamp(54px,9vw,150px);line-height:.95;letter-spacing:-.035em;font-weight:500;max-width:14ch;}
#page-services .phero .eyebrow{font-size:15px;}
#page-services .phero .sub{max-width:52ch;margin-top:clamp(20px,2vw,30px);}

/* services-page testimonials block (Ignitx style) */
.tst-block{background:var(--cream);}
.tst-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;padding-bottom:clamp(30px,4vw,50px);border-bottom:1px solid var(--line-d);}
.tst-head h2{font-size:clamp(40px,7vw,90px);font-weight:500;letter-spacing:-.03em;line-height:1;}
.tst-head .eyebrow{flex-shrink:0;padding-bottom:18px;}
.tst-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:clamp(40px,5vw,72px);}
.tst-card{background:var(--cream-2);border-radius:var(--r);padding:clamp(26px,2.6vw,38px);display:flex;flex-direction:column;min-height:340px;}
.tst-mark{font-family:Georgia,serif;font-size:80px;line-height:.65;color:var(--ink-mut);opacity:.18;margin-bottom:18px;height:42px;overflow:visible;}
.tst-quote{font-size:18px;line-height:1.55;color:var(--ink);font-weight:450;flex:1;}
.tst-author{display:flex;align-items:center;gap:14px;margin-top:clamp(28px,3vw,38px);padding-top:24px;border-top:1px solid var(--line-d);}
.tst-author .av{width:50px;height:50px;border-radius:50%;overflow:hidden;background:var(--cream-3);flex-shrink:0;}
.tst-author .av img{width:100%;height:100%;object-fit:cover;}
.tst-author .nm{font-size:17px;font-weight:500;}
.tst-author .rl{font-size:14px;color:var(--ink-mut);margin-top:2px;}
@media(max-width:960px){.tst-grid{grid-template-columns:1fr 1fr;}.tst-grid > :nth-child(3){grid-column:span 2;}.tst-head{flex-direction:column;align-items:flex-start;}.tst-head .eyebrow{padding-bottom:0;}}
@media(max-width:640px){.tst-grid{grid-template-columns:1fr;}.tst-grid > :nth-child(3){grid-column:auto;}}
.phero .wrap{position:relative;z-index:2;padding-bottom:clamp(44px,6vw,84px);padding-top:160px;}
.phero h1{color:#fff;font-size:clamp(48px,8.5vw,116px);max-width:13ch;font-weight:500;}
.phero .sub{color:rgba(255,255,255,.82);margin-top:24px;max-width:50ch;font-size:clamp(16px,1.4vw,19px);}
.phero .eyebrow{color:#fff;margin-bottom:22px;}

/* projects */
.proj-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.proj{border-radius:var(--r);overflow:hidden;background:var(--cream-2);transition:transform .4s var(--ease);}
.proj:hover{transform:translateY(-5px);}
.proj-img{aspect-ratio:4/3;overflow:hidden;background:var(--cream-3);}
.proj-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease);}
.proj:hover .proj-img img{transform:scale(1.05);}
.proj .pinfo{padding:clamp(22px,2.2vw,30px);}
.proj .pinfo h3{font-size:clamp(20px,2.2vw,28px);font-weight:500;}
.proj .pinfo p{color:var(--ink-mut);font-size:14.5px;margin-top:8px;}
.proj .tags{display:flex;gap:10px;margin-top:18px;}
.proj .tags span{font-size:13px;font-weight:450;background:#fff;border:1px solid var(--line-d);padding:7px 15px;border-radius:100px;}
@media(max-width:760px){.proj-grid{grid-template-columns:1fr;}}

/* ============================================================ CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(40px,6vw,80px);align-items:start;}
.contact-info h2{font-size:clamp(36px,5vw,64px);font-weight:500;}
.contact-info .lead{color:var(--ink-mut);margin-top:22px;max-width:34ch;font-size:16px;}
.contact-info .rows{margin-top:36px;display:flex;flex-direction:column;gap:18px;}
.contact-info .row{display:flex;align-items:center;gap:15px;font-size:16px;}
.contact-info .row .ic{width:44px;height:44px;border-radius:12px;background:var(--cream-2);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.contact-info .row .ic svg{width:19px;height:19px;color:var(--acc);}
.cform{background:var(--cream-2);border-radius:var(--r);padding:clamp(26px,3vw,42px);}
.field{margin-bottom:16px;}
.field label{display:block;font-size:13px;font-weight:500;color:var(--ink-mut);margin-bottom:8px;}
.field input,.field select,.field textarea{width:100%;font-family:inherit;font-size:15px;color:var(--ink);background:#fff;border:1px solid var(--line-d);border-radius:11px;padding:13px 15px;transition:border-color .2s;}
.field input::placeholder,.field textarea::placeholder{color:#b3ada2;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--acc);}
.field select{appearance:none;}
.field textarea{resize:vertical;min-height:96px;}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.cform .btn{width:100%;justify-content:center;padding:15px;margin-top:6px;}
.cform .note{margin-top:14px;text-align:center;font-size:12.5px;color:var(--ink-mut);display:flex;align-items:center;justify-content:center;gap:7px;}
.cform .note svg{width:15px;height:15px;flex-shrink:0;color:#25D366;}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr;gap:36px;}.field-row{grid-template-columns:1fr;}}

/* ============================================================ CTA band */
.ctaband{text-align:center;}
.ctaband h2{font-size:clamp(40px,7vw,104px);font-weight:500;max-width:16ch;margin:0 auto 30px;}
.ctaband .sub{color:var(--mut-d);max-width:46ch;margin:0 auto 36px;font-size:17px;}

/* ============================================================ FOOTER */
.footer{background:var(--dark);color:#fff;padding:clamp(60px,7vw,96px) 0 36px;overflow:hidden;}
.f-top{display:grid;grid-template-columns:1.3fr .6fr .6fr .8fr;gap:36px;}
.f-stay h3{font-size:clamp(30px,3.4vw,44px);font-weight:400;color:var(--mut-d);letter-spacing:-.02em;line-height:1.1;}
.f-stay h3 b{color:#fff;font-weight:500;display:block;}
.f-stay p{color:var(--mut-d);font-size:14.5px;margin-top:20px;max-width:34ch;line-height:1.6;}
.f-stay .btn{margin-top:26px;}
.f-col h4{font-size:13px;color:var(--mut-d);margin-bottom:18px;font-weight:500;}
.f-col ul{list-style:none;display:flex;flex-direction:column;gap:12px;}
.f-col a,.f-col li{font-size:14.5px;color:#cdc8c0;transition:color .2s;cursor:pointer;}
.f-col a:hover{color:#fff;}
.f-col .loc-h{margin-top:26px;}
.f-mid{margin-top:clamp(40px,5vw,64px);padding-top:30px;border-top:1px solid var(--line-k);display:grid;grid-template-columns:.7fr 1.3fr;gap:30px;align-items:center;}
.f-socials{display:flex;flex-direction:column;gap:2px;}
.f-socials a{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 0;border-bottom:1px solid var(--line-k);font-size:14.5px;color:#cdc8c0;transition:color .2s,padding-left .2s;}
.f-socials a:hover{color:#fff;padding-left:6px;}
.f-socials a .l{display:flex;align-items:center;gap:11px;}
.f-socials a svg{width:17px;height:17px;}
.f-word{font-size:clamp(80px,17vw,230px);font-weight:600;line-height:.8;letter-spacing:-.04em;background:linear-gradient(180deg,var(--acc-soft),var(--acc-deep));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;text-align:right;}
.f-bottom{margin-top:30px;padding-top:24px;border-top:1px solid var(--line-k);display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:13px;color:var(--mut-d2);}
@media(max-width:880px){.f-top{grid-template-columns:1fr 1fr;}.f-mid{grid-template-columns:1fr;}.f-word{text-align:left;}}
@media(max-width:520px){.f-top{grid-template-columns:1fr;}}

/* floating contact dot */
.float{position:fixed;bottom:24px;right:24px;z-index:150;display:inline-flex;align-items:center;gap:11px;background:var(--acc);color:#fff;padding:13px 22px;border-radius:100px;font-size:14px;font-weight:500;box-shadow:0 10px 30px rgba(43,111,255,.35);opacity:0;transform:translateY(18px);animation:fin .7s 1s var(--ease) forwards;transition:transform .25s var(--ease),background .25s;}
.float:hover{background:var(--acc-deep);transform:translateY(-2px);}
@keyframes fin{to{opacity:1;transform:none;}}
@media(max-width:520px){.float{bottom:18px;right:18px;padding:11px 18px;font-size:13.5px;}}

/* ============================================================ MODAL */
.modal{position:fixed;inset:0;z-index:400;display:none;align-items:center;justify-content:center;padding:20px;}
.modal.open{display:flex;animation:mf .25s ease both;}
@keyframes mf{from{opacity:0}to{opacity:1}}
.modal-bg{position:absolute;inset:0;background:rgba(9,9,9,.6);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);}
.modal-card{position:relative;width:100%;max-width:540px;max-height:92vh;overflow-y:auto;background:var(--cream);border-radius:22px;padding:clamp(28px,4vw,44px);animation:mp .35s var(--ease) both;}
@keyframes mp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.modal-close{position:absolute;top:18px;right:18px;width:40px;height:40px;border-radius:50%;border:1px solid var(--line-d);background:#fff;color:var(--ink-mut);display:flex;align-items:center;justify-content:center;font-size:19px;transition:color .2s,border-color .2s;}
.modal-close:hover{color:var(--ink);border-color:var(--ink);}
.modal .eyebrow{margin-bottom:14px;}
.modal h3{font-size:clamp(26px,4vw,36px);font-weight:500;margin-bottom:8px;}
.modal .sub{color:var(--ink-mut);font-size:14.5px;margin-bottom:24px;}
.modal-err{display:none;background:#fdecea;border:1px solid #f6c7be;border-radius:10px;padding:11px 14px;font-size:13px;font-weight:500;color:#c0341a;margin-bottom:16px;}
.modal-err.show{display:block;}
.modal .note{margin-top:14px;text-align:center;font-size:12.5px;color:var(--ink-mut);display:flex;gap:7px;align-items:center;justify-content:center;}
.modal .note svg{width:15px;height:15px;}
