:root{
  --orange:#ff9718;
  --blue:#0873b3;
  --green:#5b8052;
  --ink:#102033;
  --muted:#64748b;
  --cream:#fff8ed;
  --white:#ffffff;
  --line:rgba(16,32,51,.12);
  --shadow:0 24px 70px rgba(16,32,51,.14);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,sans-serif;color:var(--ink);background:linear-gradient(180deg,#fffaf2 0%,#fff 42%,#f6fbff 100%);overflow-x:hidden}
a{color:inherit;text-decoration:none}
.page-glow{position:fixed;width:360px;height:360px;border-radius:50%;filter:blur(80px);opacity:.28;z-index:-1;animation:floatGlow 10s ease-in-out infinite alternate}.glow-one{background:var(--orange);top:5%;left:-120px}.glow-two{background:var(--blue);right:-120px;bottom:12%;animation-delay:2s}
.site-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:18px clamp(22px,5vw,72px);background:rgba(255,255,255,.78);backdrop-filter:blur(18px);border-bottom:1px solid rgba(255,255,255,.5)}
.brand img{width:min(270px,52vw);display:block}.site-nav{display:flex;align-items:center;gap:28px;font-weight:700}.site-nav a{position:relative}.site-nav a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-7px;width:0;height:3px;background:var(--orange);border-radius:99px;transition:.25s}.site-nav a:hover::after{width:100%}.nav-cta{padding:12px 18px;border-radius:999px;background:var(--ink);color:#fff}.nav-toggle{display:none;border:0;background:var(--ink);color:#fff;border-radius:10px;padding:10px 12px;font-size:20px}
main{padding:0 clamp(22px,5vw,72px)}section{max-width:1180px;margin:0 auto}.section-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}.hero{min-height:78vh;padding:80px 0 50px}.eyebrow{color:var(--green);font-weight:800;text-transform:uppercase;letter-spacing:.14em;font-size:13px}h1,h2,h3,p{margin-top:0}h1{font-size:clamp(42px,6vw,78px);line-height:.98;letter-spacing:-.06em;margin-bottom:24px}h2{font-size:clamp(32px,4vw,52px);line-height:1.04;letter-spacing:-.045em}h3{font-size:24px}.hero-text,.intro p,.contact p{font-size:19px;line-height:1.7;color:var(--muted)}.hero-actions,.contact-actions{display:flex;gap:14px;flex-wrap:wrap}.button{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:15px 22px;font-weight:800;transition:.25s}.button:hover{transform:translateY(-3px)}.primary{background:var(--orange);color:#111;box-shadow:0 14px 30px rgba(255,151,24,.28)}.secondary{background:#fff;border:1px solid var(--line)}
.hero-visual{position:relative;min-height:440px}.river-shape{position:absolute;inset:36px;border-radius:44% 56% 48% 52%;background:linear-gradient(135deg,rgba(8,115,179,.95),rgba(91,128,82,.9));box-shadow:var(--shadow);animation:morph 9s ease-in-out infinite}.river-shape::after{content:"";position:absolute;inset:22px;border-radius:inherit;background:linear-gradient(135deg,rgba(255,255,255,.35),transparent);border:1px solid rgba(255,255,255,.45)}.orbit-card{position:absolute;z-index:2;left:50%;top:50%;transform:translate(-50%,-50%);width:min(350px,90%);background:rgba(255,255,255,.9);border:1px solid rgba(255,255,255,.65);box-shadow:var(--shadow);border-radius:28px;padding:30px;backdrop-filter:blur(12px);animation:cardFloat 5s ease-in-out infinite}.mini-label{display:inline-block;background:rgba(255,151,24,.14);color:#9a5300;padding:8px 12px;border-radius:999px;font-weight:800;font-size:13px;margin-bottom:16px}.orbit-card strong{display:block;font-size:30px;line-height:1.05}.orbit-card p{color:var(--muted);line-height:1.6}.floating-chip{position:absolute;z-index:3;background:#fff;border:1px solid var(--line);padding:12px 16px;border-radius:999px;font-weight:800;box-shadow:0 14px 30px rgba(16,32,51,.1);animation:chipFloat 4s ease-in-out infinite}.chip-one{top:48px;left:0}.chip-two{right:0;top:120px;animation-delay:1s}.chip-three{bottom:60px;left:48px;animation-delay:1.8s}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding:28px;background:#fff;border:1px solid var(--line);border-radius:28px;box-shadow:0 18px 50px rgba(16,32,51,.08)}.stats div{padding:10px}.stats strong{display:block;font-size:34px;color:var(--blue)}.stats span{color:var(--muted);font-weight:700}.intro{padding:90px 0}.services,.work,.process,.contact{padding:70px 0}.section-heading{max-width:760px;margin-bottom:30px}.service-grid,.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.service-card,.work-card{background:#fff;border:1px solid var(--line);border-radius:28px;padding:30px;box-shadow:0 18px 50px rgba(16,32,51,.07);transition:.25s}.service-card:hover,.work-card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}.service-card p,.work-card p{color:var(--muted);line-height:1.65}.service-card ul{padding-left:18px;color:var(--muted);line-height:1.9}.icon{width:58px;height:58px;border-radius:18px;margin-bottom:22px;position:relative}.web-icon{background:linear-gradient(135deg,var(--blue),#89cff0)}.video-icon{background:linear-gradient(135deg,var(--orange),#ffd08a)}.ops-icon{background:linear-gradient(135deg,var(--green),#b3cea9)}.icon::after{content:"";position:absolute;inset:14px;border:3px solid rgba(255,255,255,.8);border-radius:10px}.work-card span{color:var(--orange);font-weight:900}.steps{display:grid;gap:18px}.steps div{display:grid;grid-template-columns:54px 1fr;gap:18px;align-items:start;background:#fff;border:1px solid var(--line);border-radius:24px;padding:22px}.steps span{width:44px;height:44px;display:grid;place-items:center;border-radius:50%;background:var(--blue);color:#fff;font-weight:900}.steps p{margin:0;color:var(--muted);line-height:1.6}.contact{text-align:center;background:linear-gradient(135deg,rgba(255,151,24,.14),rgba(8,115,179,.12));border:1px solid rgba(255,255,255,.6);border-radius:34px;margin-bottom:60px;padding:70px 28px}.contact h2{max-width:760px;margin:0 auto 18px}.contact p{max-width:650px;margin:0 auto 26px}.contact-actions{justify-content:center}footer{text-align:center;padding:30px;color:var(--muted)}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:translateY(0)}.delay-1{transition-delay:.12s}.delay-2{transition-delay:.22s}
@keyframes morph{0%,100%{border-radius:44% 56% 48% 52%;transform:rotate(0deg)}50%{border-radius:58% 42% 56% 44%;transform:rotate(5deg)}}@keyframes cardFloat{50%{transform:translate(-50%,-55%)}}@keyframes chipFloat{50%{transform:translateY(-12px)}}@keyframes floatGlow{to{transform:translate(40px,30px) scale(1.08)}}
@media(max-width:860px){.nav-toggle{display:block}.site-nav{position:absolute;top:76px;left:22px;right:22px;display:none;flex-direction:column;align-items:flex-start;padding:20px;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow)}.site-nav.open{display:flex}.section-grid,.service-grid,.work-grid,.stats{grid-template-columns:1fr}.hero{padding-top:50px}.hero-visual{min-height:360px}.chip-two{right:10px}.stats{gap:0}.brand img{width:220px}}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}.reveal{opacity:1;transform:none}}

/* Horizontal sliding service cards */
.service-stack{display:grid;gap:24px}
.service-row{position:relative;display:grid;grid-template-columns:230px minmax(0,1fr) 72px;gap:34px;align-items:center;min-height:190px;padding:34px 42px;border-radius:28px;background:rgba(255,255,255,.86);border:1px solid rgba(16,32,51,.08);box-shadow:0 18px 45px rgba(16,32,51,.07);overflow:hidden;transition:transform .35s ease,box-shadow .35s ease,background .35s ease;color:var(--ink)}
.service-row::before{content:"";position:absolute;inset:0;z-index:0;background:linear-gradient(90deg,rgba(255,151,24,.12),rgba(8,115,179,.12));transform:translateX(-101%);transition:transform .45s ease}
.service-row>*{position:relative;z-index:1}.service-row:hover{transform:translateX(18px);box-shadow:var(--shadow)}.service-row:hover::before{transform:translateX(0)}
.service-main{display:flex;align-items:center;gap:18px;transition:transform .35s ease}.service-row:hover .service-main{transform:translateX(8px)}.service-main h3{font-size:34px;line-height:1.02;margin:0 0 8px}.service-main p{font-size:16px;line-height:1.25;font-weight:800;margin:0;color:rgba(16,32,51,.78)}
.service-details{display:grid;grid-template-columns:1fr 1fr;gap:26px;opacity:.78;transform:translateX(-10px);transition:opacity .35s ease,transform .35s ease}.service-row:hover .service-details{opacity:1;transform:translateX(0)}.service-details ul{margin:0;padding-left:18px;line-height:2;color:inherit}.service-details li{padding-left:4px}.service-arrow{justify-self:end;display:grid;place-items:center;width:64px;height:46px;border-radius:13px;background:#f3f4f6;font-size:26px;font-weight:900;transition:transform .35s ease,background .35s ease,color .35s ease}.service-row:hover .service-arrow{transform:translateX(8px);background:var(--orange);color:#111}.graphic-icon{background:linear-gradient(135deg,var(--green),#b8d0ad)}.service-graphic{background:var(--green);color:#fff}.service-graphic .service-main p,.service-graphic .service-details{color:rgba(255,255,255,.86)}.service-graphic::before{background:linear-gradient(90deg,rgba(255,255,255,.11),rgba(255,151,24,.18))}.service-graphic .service-arrow{background:#050505;color:#fff}.service-ops{background:var(--blue);color:#fff}.service-ops .service-main p,.service-ops .service-details{color:rgba(255,255,255,.88)}.service-ops::before{background:linear-gradient(90deg,rgba(255,255,255,.10),rgba(255,151,24,.24))}.service-ops .service-arrow{background:var(--orange);color:#fff}

/* Video success stories slider */
.success-stories{padding:80px 0;border-radius:36px;background:var(--blue);color:#fff;box-shadow:var(--shadow);overflow:hidden}.centered{text-align:center;margin-left:auto;margin-right:auto}.success-stories .eyebrow{color:#ffd08a}.video-slider{display:grid;grid-template-columns:repeat(3,minmax(240px,1fr));gap:22px;max-width:980px;margin:28px auto 42px;padding:0 28px}.video-card{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:24px;overflow:hidden;backdrop-filter:blur(8px);transition:transform .3s ease,background .3s ease}.video-card:hover{transform:translateY(-8px) rotate(-.5deg);background:rgba(255,255,255,.18)}.video-card h3{font-size:18px;margin:18px 18px 6px}.video-card p{font-size:14px;line-height:1.55;color:rgba(255,255,255,.75);margin:0 18px 20px}.video-thumb{position:relative;aspect-ratio:9/14;min-height:320px;background-size:cover;background-position:center;overflow:hidden}.video-thumb::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.22),rgba(0,0,0,.08) 40%,rgba(0,0,0,.35))}.thumb-one{background:linear-gradient(160deg,#8fd2ff 0%,#eef8ff 40%,#90b96d 100%)}.thumb-two{background:linear-gradient(160deg,#f2dfc4 0%,#b98266 50%,#648054 100%)}.thumb-three{background:linear-gradient(160deg,#2d2530 0%,#b73b2f 55%,#181818 100%)}.play-button{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:grid;place-items:center;width:74px;height:52px;border-radius:15px;background:#ff1f1f;color:#fff;font-size:24px;box-shadow:0 18px 30px rgba(0,0,0,.22);transition:transform .25s ease}.video-card:hover .play-button{transform:translate(-50%,-50%) scale(1.08)}.success-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:980px;margin:0 auto;padding:0 28px;text-align:center}.success-stats strong{display:block;font-size:clamp(38px,5vw,62px);font-weight:300;letter-spacing:-.06em;color:rgba(255,255,255,.85)}.success-stats span{font-size:18px;font-weight:800;color:#fff}

@media(max-width:900px){.service-row{grid-template-columns:1fr;gap:22px;min-height:auto;padding:28px}.service-row:hover{transform:translateY(-6px)}.service-main,.service-row:hover .service-main{transform:none}.service-details{grid-template-columns:1fr;transform:none;opacity:1}.service-arrow{justify-self:start}.video-slider{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:8px}.video-card{min-width:74vw;scroll-snap-align:center}.success-stats{grid-template-columns:1fr}}

/* One-row expandable service accordion */
.services-accordion-section{position:relative;padding:90px 0 100px}.services-accordion-section .section-heading{max-width:820px;margin-left:auto;margin-right:auto;text-align:center}.services-accordion-section .section-heading p:not(.eyebrow){color:var(--muted);font-size:18px;margin-top:-8px}.services-accordion{display:flex;align-items:stretch;gap:0;min-height:520px;border-radius:30px;overflow:hidden;background:#fff;box-shadow:var(--shadow);border:1px solid rgba(16,32,51,.08)}.accordion-card{position:relative;isolation:isolate;display:flex;min-width:0;flex:1 1 0;background:linear-gradient(160deg,#102033,#071727);color:#fff;overflow:hidden;transition:flex .55s cubic-bezier(.22,1,.36,1),background .35s ease,box-shadow .35s ease}.accordion-card::before{content:"";position:absolute;inset:0;z-index:-1;background:radial-gradient(circle at 24% 18%,rgba(255,255,255,.18),transparent 26%),linear-gradient(145deg,rgba(255,255,255,.07),transparent 45%);opacity:.9}.accordion-card::after{content:"";position:absolute;right:-70px;bottom:-90px;width:190px;height:190px;border-radius:999px;background:rgba(255,255,255,.08);transition:.45s ease}.accordion-card:hover,.accordion-card:focus-within,.accordion-card.is-active{flex:2.85 1 0}.accordion-card:hover::after,.accordion-card:focus-within::after,.accordion-card.is-active::after{transform:scale(1.25);background:rgba(255,151,24,.13)}.accordion-summary{width:100%;max-width:300px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:18px;padding:34px 26px;transition:max-width .45s ease,align-items .45s ease,text-align .45s ease}.accordion-card:hover .accordion-summary,.accordion-card:focus-within .accordion-summary,.accordion-card.is-active .accordion-summary{max-width:330px;align-items:flex-start;text-align:left}.accordion-summary .icon{margin:0;background:transparent;border:1px solid rgba(255,255,255,.28);border-radius:999px;width:74px;height:74px}.accordion-summary .icon::before{content:"";position:absolute;inset:22px;border:2px solid rgba(255,255,255,.8);border-radius:7px}.accordion-summary .icon::after{inset:0;border:0}.accordion-summary h3{font-size:clamp(28px,2.2vw,40px);line-height:1.05;text-transform:uppercase;letter-spacing:-.04em;margin:0}.accordion-summary span{width:46px;height:2px;background:rgba(255,255,255,.75);display:block}.accordion-summary p{font-size:16px;line-height:1.45;margin:0;color:rgba(255,255,255,.9);max-width:220px}.service-number{position:absolute;left:34px;bottom:30px;font-size:52px;line-height:1;font-weight:900;letter-spacing:-.08em;color:rgba(255,255,255,.12)}.accordion-details{width:0;opacity:0;transform:translateX(28px);padding:46px 0;display:grid;grid-template-columns:minmax(230px,.82fr) minmax(280px,1fr);gap:34px;pointer-events:none;transition:width .55s cubic-bezier(.22,1,.36,1),opacity .25s ease,transform .45s ease,padding .45s ease;background:rgba(255,255,255,.98);color:var(--ink);border-radius:28px 0 0 28px;margin:0 0 0 auto;box-shadow:-20px 0 44px rgba(16,32,51,.12)}.accordion-card:hover .accordion-details,.accordion-card:focus-within .accordion-details,.accordion-card.is-active .accordion-details{width:min(680px,62vw);opacity:1;transform:translateX(0);padding:46px 42px;pointer-events:auto}.details-intro{align-self:center}.details-intro h4{font-size:28px;line-height:1.12;margin:0 0 14px;color:var(--green)}.details-intro p{line-height:1.65;color:var(--muted);margin:0 0 22px}.small-button{font-size:14px;padding:13px 18px}.accordion-details ul{list-style:none;margin:0;padding:0;display:grid;gap:16px;border-left:1px solid rgba(16,32,51,.1);padding-left:32px}.accordion-details li{line-height:1.45;color:var(--muted);position:relative}.accordion-details li::before{content:"✓";position:absolute;left:-32px;top:0;width:20px;height:20px;border-radius:50%;display:grid;place-items:center;border:1px solid var(--green);color:var(--green);font-size:12px;font-weight:900}.accordion-details strong{color:var(--ink)}.accordion-summary .service-arrow{margin-top:4px;display:grid;place-items:center;width:50px;height:50px;border-radius:999px;background:#fff;color:var(--green);font-size:24px;text-decoration:none;box-shadow:0 12px 24px rgba(16,32,51,.15);transition:transform .25s ease,background .25s ease,color .25s ease}.accordion-card:hover .service-arrow,.accordion-card:focus-within .service-arrow,.accordion-card.is-active .service-arrow{transform:translateX(8px);background:var(--orange);color:#111}.accordion-card.service-web{background:linear-gradient(150deg,var(--blue),#183b75)}.accordion-card.service-video{background:linear-gradient(150deg,var(--green),#486e43)}.accordion-card.service-graphic{background:linear-gradient(150deg,#102033,#071727);color:#fff}.accordion-card.service-ops{background:linear-gradient(150deg,#fff,#f9fbf8);color:var(--ink)}.accordion-card.service-ops::before{background:radial-gradient(circle at 20% 20%,rgba(255,151,24,.16),transparent 26%),linear-gradient(145deg,rgba(91,128,82,.08),transparent 50%)}.accordion-card.service-ops .accordion-summary p{color:var(--muted)}.accordion-card.service-ops .accordion-summary span{background:var(--green)}.accordion-card.service-ops .service-number{color:rgba(16,32,51,.08)}.accordion-card.service-ops .icon{border-color:rgba(91,128,82,.28)}.accordion-card.service-ops .icon::before{border-color:var(--green)}.accordion-card.service-ops .accordion-details{box-shadow:-20px 0 44px rgba(16,32,51,.07)}.services-note{text-align:center;margin:34px 0 0;font-weight:900;font-size:18px;color:var(--ink)}

@media(max-width:1100px){.services-accordion{min-height:470px}.accordion-card:hover .accordion-details,.accordion-card:focus-within .accordion-details,.accordion-card.is-active .accordion-details{width:min(590px,58vw);padding:38px 30px}.accordion-details{grid-template-columns:1fr}.accordion-details ul{border-left:0;padding-left:0}.accordion-details li::before{position:static;display:inline-grid;margin-right:8px}.details-intro h4{font-size:24px}.accordion-summary{max-width:230px}.accordion-card:hover,.accordion-card:focus-within,.accordion-card.is-active{flex:3.2 1 0}}
@media(max-width:820px){.services-accordion{display:grid;min-height:auto;gap:16px;overflow:visible;background:transparent;box-shadow:none;border:0}.accordion-card{display:block;border-radius:28px;min-height:unset;box-shadow:0 18px 45px rgba(16,32,51,.08)}.accordion-card,.accordion-card:hover,.accordion-card:focus-within,.accordion-card.is-active{flex:auto}.accordion-summary,.accordion-card:hover .accordion-summary,.accordion-card:focus-within .accordion-summary,.accordion-card.is-active .accordion-summary{max-width:none;align-items:flex-start;text-align:left;padding:28px}.accordion-summary .icon{width:58px;height:58px}.accordion-summary .icon::before{inset:17px}.service-number{right:26px;left:auto;bottom:24px}.accordion-details,.accordion-card:hover .accordion-details,.accordion-card:focus-within .accordion-details,.accordion-card.is-active .accordion-details{width:auto;opacity:1;transform:none;display:block;padding:28px;margin:0;border-radius:24px;background:rgba(255,255,255,.96);pointer-events:auto}.accordion-details ul{margin-top:20px}.accordion-card.service-ops .accordion-details{margin:0 16px 16px}.accordion-card:not(.service-ops) .accordion-details{margin:0 16px 16px}.services-note{margin-top:26px}}


/* Services accordion v3: full-width hover reveal */
.services-accordion{
  min-height:520px;
  overflow:hidden;
}
.accordion-card{
  flex:1 1 0;
  min-width:0;
  transition:flex .65s cubic-bezier(.22,1,.36,1), filter .35s ease, box-shadow .35s ease;
}
.services-accordion.is-interacting .accordion-card{
  flex:.38 1 0;
  filter:saturate(.88) brightness(.96);
}
.services-accordion.is-interacting .accordion-card.is-active{
  flex:8.8 1 0;
  filter:none;
  z-index:3;
}
.accordion-summary{
  flex:0 0 clamp(145px, 15vw, 240px);
  max-width:none;
  width:clamp(145px, 15vw, 240px);
  padding:34px 24px;
}
.services-accordion.is-interacting .accordion-card:not(.is-active) .accordion-summary{
  width:clamp(110px, 8vw, 150px);
  flex-basis:clamp(110px, 8vw, 150px);
  padding-left:16px;
  padding-right:16px;
}
.services-accordion.is-interacting .accordion-card:not(.is-active) .accordion-summary p,
.services-accordion.is-interacting .accordion-card:not(.is-active) .accordion-summary .service-arrow,
.services-accordion.is-interacting .accordion-card:not(.is-active) .accordion-summary span,
.services-accordion.is-interacting .accordion-card:not(.is-active) .service-number{
  opacity:0;
  transform:translateY(8px);
  pointer-events:none;
}
.services-accordion.is-interacting .accordion-card:not(.is-active) .accordion-summary .icon{
  width:54px;
  height:54px;
  opacity:.75;
}
.services-accordion.is-interacting .accordion-card:not(.is-active) .accordion-summary h3{
  writing-mode:vertical-rl;
  transform:rotate(180deg);
  font-size:clamp(21px,2vw,30px);
  letter-spacing:.02em;
}
.accordion-card:hover .accordion-summary,
.accordion-card:focus-within .accordion-summary,
.accordion-card.is-active .accordion-summary{
  align-items:center;
  text-align:center;
}
.accordion-details{
  flex:1 1 auto;
  width:auto;
  min-width:0;
  max-width:none;
  opacity:0;
  transform:translateX(40px);
  padding:50px 0;
  margin:0;
  border-radius:30px 0 0 30px;
  overflow:hidden;
  transition:opacity .25s ease, transform .55s cubic-bezier(.22,1,.36,1), padding .45s ease;
}
.accordion-card:hover .accordion-details,
.accordion-card:focus-within .accordion-details,
.accordion-card.is-active .accordion-details{
  width:auto;
  opacity:1;
  transform:translateX(0);
  padding:50px clamp(28px,4vw,58px);
}
.services-accordion.is-interacting .accordion-card:not(.is-active) .accordion-details{
  opacity:0;
  padding-left:0;
  padding-right:0;
  pointer-events:none;
}
.accordion-details ul{
  grid-template-columns:1fr;
}
.service-web .details-intro h4,
.service-video .details-intro h4,
.service-graphic .details-intro h4,
.service-ops .details-intro h4{color:var(--green)}
@media(max-width:1100px){
  .services-accordion.is-interacting .accordion-card{flex:.45 1 0}
  .services-accordion.is-interacting .accordion-card.is-active{flex:7 1 0}
  .accordion-summary{width:155px;flex-basis:155px}
  .services-accordion.is-interacting .accordion-card:not(.is-active) .accordion-summary{width:92px;flex-basis:92px}
  .accordion-card:hover .accordion-details,.accordion-card:focus-within .accordion-details,.accordion-card.is-active .accordion-details{padding:36px 28px}
}
@media(max-width:820px){
  .services-accordion.is-interacting .accordion-card,
  .services-accordion.is-interacting .accordion-card.is-active{flex:auto;filter:none}
  .services-accordion.is-interacting .accordion-card:not(.is-active) .accordion-summary h3{writing-mode:initial;transform:none}
  .services-accordion.is-interacting .accordion-card:not(.is-active) .accordion-summary p,
  .services-accordion.is-interacting .accordion-card:not(.is-active) .accordion-summary .service-arrow,
  .services-accordion.is-interacting .accordion-card:not(.is-active) .accordion-summary span,
  .services-accordion.is-interacting .accordion-card:not(.is-active) .service-number{opacity:1;transform:none;pointer-events:auto}
  .accordion-summary,.services-accordion.is-interacting .accordion-card:not(.is-active) .accordion-summary{width:auto;flex-basis:auto}
}


/* v4 refinements: cleaner full-width hover accordion and consistent service title sizing */
.accordion-summary h3{
  font-size:clamp(24px,1.85vw,34px);
  line-height:.92;
  font-weight:900;
  letter-spacing:-.045em;
  text-transform:uppercase;
  max-width:100%;
  overflow:visible;
  overflow-wrap:normal;
}
.accordion-card.service-ops .accordion-summary h3{
  font-size:clamp(23px,1.75vw,32px);
  line-height:.9;
}
.services-accordion.is-interacting .accordion-card{
  flex:.16 1 0;
  filter:saturate(.8) brightness(.92);
}
.services-accordion.is-interacting .accordion-card.is-active{
  flex:14 1 0;
  filter:none;
  z-index:5;
}
.services-accordion.is-interacting .accordion-card.is-active .accordion-summary{
  flex-basis:clamp(150px,13vw,220px);
  width:clamp(150px,13vw,220px);
  padding-left:22px;
  padding-right:22px;
}
.services-accordion.is-interacting .accordion-card:not(.is-active) .accordion-summary{
  width:clamp(58px,5vw,78px);
  flex-basis:clamp(58px,5vw,78px);
  padding-left:10px;
  padding-right:10px;
}
.services-accordion.is-interacting .accordion-card:not(.is-active) .accordion-summary h3{
  font-size:clamp(17px,1.45vw,24px);
  line-height:.95;
  letter-spacing:-.02em;
}
.services-accordion.is-interacting .accordion-card.is-active .accordion-details{
  opacity:1;
  transform:translateX(0);
  padding:50px clamp(34px,5vw,70px);
}
.accordion-card:hover .accordion-details,
.accordion-card:focus-within .accordion-details,
.accordion-card.is-active .accordion-details{
  width:auto;
}
@media(max-width:1100px){
  .accordion-summary h3{font-size:clamp(22px,2.2vw,30px)}
  .accordion-card.service-ops .accordion-summary h3{font-size:clamp(20px,2vw,28px)}
  .services-accordion.is-interacting .accordion-card{flex:.12 1 0}
  .services-accordion.is-interacting .accordion-card.is-active{flex:12 1 0}
  .services-accordion.is-interacting .accordion-card:not(.is-active) .accordion-summary{width:60px;flex-basis:60px}
}
@media(max-width:820px){
  .accordion-summary h3,
  .accordion-card.service-ops .accordion-summary h3{font-size:clamp(28px,8vw,40px);line-height:.95}
}


/* v5 updates: full-width auto-sliding client work + stats moved to featured work */
.success-stories{
  max-width:none;
  width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  border-radius:0;
  padding:88px clamp(22px,5vw,72px) 96px;
}
.success-stories .section-heading{
  max-width:760px;
}
.video-slider{
  display:block;
  max-width:1280px;
  margin:34px auto 0;
  padding:0;
  overflow:hidden;
}
.video-track{
  display:flex;
  gap:22px;
  will-change:transform;
  transition:transform .75s cubic-bezier(.22,1,.36,1);
}
.video-card{
  flex:0 0 calc((100% - 66px) / 4);
  min-width:0;
}
.thumb-four{background:linear-gradient(160deg,#e6f5ff 0%,#0873b3 55%,#102033 100%)}
.thumb-five{background:linear-gradient(160deg,#fff0d7 0%,#ff9718 52%,#5b8052 100%)}
.thumb-six{background:linear-gradient(160deg,#edf7ec 0%,#5b8052 48%,#102033 100%)}
.work .section-heading{
  margin-bottom:28px;
}
.showcase-stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
  margin:0 0 34px;
}
.showcase-stats div{
  border:1px solid rgba(16,32,51,.1);
  border-radius:28px;
  background:rgba(255,255,255,.82);
  box-shadow:0 18px 42px rgba(16,32,51,.06);
  padding:28px 24px;
  text-align:center;
}
.showcase-stats strong{
  display:block;
  font-size:clamp(38px,5vw,64px);
  line-height:1;
  font-weight:300;
  letter-spacing:-.06em;
  color:var(--blue);
}
.showcase-stats span{
  display:block;
  margin-top:8px;
  font-size:18px;
  font-weight:900;
  color:var(--ink);
}
@media(max-width:1000px){
  .video-card{flex-basis:calc((100% - 44px) / 3)}
}
@media(max-width:760px){
  .success-stories{padding:70px 22px 78px}
  .video-slider{overflow-x:auto;scroll-snap-type:x mandatory}
  .video-track{transform:none!important}
  .video-card{flex-basis:78vw;scroll-snap-align:center}
  .showcase-stats{grid-template-columns:1fr}
}


/* v6 pages: Start a Project + FAQ */
.inner-page{padding-top:34px}.page-hero{max-width:940px;text-align:center;padding:78px 0 42px}.page-hero h1{margin-bottom:18px}.page-hero p:not(.eyebrow){max-width:720px;margin:0 auto;color:var(--muted);font-size:20px;line-height:1.7}.project-form-section{display:grid;grid-template-columns:.85fr 1.15fr;gap:44px;align-items:start;max-width:1100px;margin:0 auto 80px;padding:46px;border-radius:34px;background:rgba(255,255,255,.82);border:1px solid var(--line);box-shadow:var(--shadow);backdrop-filter:blur(16px)}.form-intro h2{margin-bottom:16px}.form-intro p{color:var(--muted);font-size:18px;line-height:1.7}.contact-mini-card{margin-top:28px;padding:22px;border-radius:22px;background:linear-gradient(135deg,rgba(8,115,179,.11),rgba(255,151,24,.13));border:1px solid rgba(255,255,255,.75)}.contact-mini-card strong{display:block;margin-bottom:8px}.contact-mini-card a{font-weight:800;color:var(--blue)}.project-form{display:grid;gap:26px}.project-form label{display:grid;gap:10px}.project-form span{font-size:18px;font-weight:800;color:#111}.project-form input,.project-form select,.project-form textarea{width:100%;border:0;border-bottom:4px solid #111;background:transparent;border-radius:0;padding:10px 0 16px;font:inherit;font-size:18px;color:var(--ink);outline:0;transition:border-color .25s ease, transform .25s ease}.project-form textarea{resize:vertical;min-height:180px}.project-form input:focus,.project-form select:focus,.project-form textarea:focus{border-color:var(--orange);transform:translateY(-2px)}.form-submit{justify-self:end;border:0;font-size:22px;padding:17px 30px;background:#050505;color:#fff;box-shadow:none;cursor:pointer}.form-submit:hover{background:var(--orange);color:#111}.faq-section{max-width:980px;margin:0 auto 70px}.faq-item{border-bottom:1px solid var(--line);padding:0}.faq-question{width:100%;border:0;background:transparent;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:28px 0;cursor:pointer;text-align:left;color:var(--ink);font:inherit}.faq-question span{font-size:clamp(24px,3vw,38px);line-height:1.18;font-weight:900;letter-spacing:-.04em;color:rgba(16,32,51,.72)}.faq-question strong{flex:0 0 auto;width:34px;height:34px;display:grid;place-items:center;border-radius:50%;background:#050505;color:#fff;font-size:28px;line-height:1;transition:transform .25s ease,background .25s ease}.faq-item.open .faq-question strong{transform:rotate(45deg);background:var(--orange);color:#111}.faq-answer{max-height:0;overflow:hidden;transition:max-height .35s ease}.faq-answer p{max-width:760px;margin:0 0 28px;color:var(--muted);font-size:18px;line-height:1.7}.faq-cta{max-width:900px;margin:0 auto 80px;text-align:center;padding:54px 26px;border-radius:32px;background:linear-gradient(135deg,rgba(91,128,82,.12),rgba(8,115,179,.12));border:1px solid var(--line)}.faq-cta p{color:var(--muted);font-size:18px;line-height:1.6;margin-bottom:22px}@media(max-width:860px){.project-form-section{grid-template-columns:1fr;padding:28px}.page-hero{padding-top:48px}.faq-question span{font-size:25px}.form-submit{justify-self:stretch}.project-form input,.project-form select,.project-form textarea{font-size:16px}}

/* v9 MP4 video popup modal */
.video-card{
  cursor:pointer;
}
.video-card:focus-visible{
  outline:4px solid rgba(255,151,24,.85);
  outline-offset:5px;
}
.video-modal{
  position:fixed;
  inset:0;
  z-index:9999;
  display:grid;
  place-items:center;
  padding:24px;
  opacity:0;
  pointer-events:none;
  transition:opacity .28s ease;
}
.video-modal.is-open{
  opacity:1;
  pointer-events:auto;
}
.video-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(5,12,22,.78);
  backdrop-filter:blur(10px);
}
.video-modal-dialog{
  position:relative;
  width:min(440px,92vw);
  transform:translateY(16px) scale(.96);
  transition:transform .32s cubic-bezier(.22,1,.36,1);
}
.video-modal.is-open .video-modal-dialog{
  transform:translateY(0) scale(1);
}
.video-modal-frame{
  position:relative;
  width:100%;
  aspect-ratio:9 / 16;
  border-radius:28px;
  overflow:hidden;
  background:#050505;
  box-shadow:0 30px 90px rgba(0,0,0,.45);
}
.video-modal-player{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
  object-fit:cover;
  background:#050505;
}
.video-modal-caption{
  color:#fff;
  text-align:center;
  margin:14px 0 0;
  font-weight:800;
  letter-spacing:-.02em;
}
.video-modal-close{
  position:absolute;
  top:-18px;
  right:-18px;
  z-index:2;
  width:46px;
  height:46px;
  border:0;
  border-radius:50%;
  background:var(--orange);
  color:#111;
  font-size:30px;
  line-height:1;
  cursor:pointer;
  box-shadow:0 14px 30px rgba(0,0,0,.22);
}
body.modal-open{
  overflow:hidden;
}
@media(max-width:540px){
  .video-modal-dialog{width:min(360px,92vw)}
  .video-modal-close{top:-12px;right:-8px}
}

.video-slider{position:relative;display:flex;align-items:center;justify-content:center;gap:20px;overflow:hidden}
.video-track{display:flex;gap:20px;transition:transform .6s cubic-bezier(.22,1,.36,1)}
.slider-nav{position:absolute;top:50%;transform:translateY(-50%);width:64px;height:64px;border-radius:50%;border:1px solid rgba(255,255,255,.35);background:rgba(255,255,255,.08);color:#fff;font-size:32px;cursor:pointer;z-index:5}
.slider-prev{left:-30px}
.slider-next{right:-30px}
.slider-nav:hover{background:rgba(255,255,255,.18);transform:translateY(-50%) scale(1.05)}
.slider-dots{display:flex;justify-content:center;gap:10px;margin-top:25px;width:100%}
.slider-dots span{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.4);display:block}
.slider-dots span.active{background:#f59a23}

/* v11 fixes: clean carousel arrows + animated stats */
.success-stories .video-slider{
  position:relative;
  display:block;
  max-width:1420px;
  margin:34px auto 0;
  padding:0 92px 48px;
  overflow:visible;
}
.video-viewport{
  overflow:hidden;
  width:100%;
}
.success-stories .video-track{
  display:flex;
  gap:22px;
  transition:transform .65s cubic-bezier(.22,1,.36,1);
  will-change:transform;
}
.success-stories .video-card{
  flex:0 0 calc((100% - 66px) / 4);
  min-width:0;
}
.success-stories .slider-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:62px;
  height:62px;
  display:grid;
  place-items:center;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.42);
  background:rgba(255,255,255,.08);
  color:#fff;
  font-size:34px;
  line-height:1;
  cursor:pointer;
  z-index:10;
  box-shadow:0 18px 38px rgba(0,0,0,.12);
  backdrop-filter:blur(8px);
  transition:background .25s ease, transform .25s ease, border-color .25s ease;
}
.success-stories .slider-prev{left:14px;}
.success-stories .slider-next{right:14px;}
.success-stories .slider-nav:hover{
  background:rgba(255,255,255,.18);
  border-color:rgba(255,255,255,.72);
  transform:translateY(-50%) scale(1.06);
}
.success-stories .slider-dots{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  display:flex;
  justify-content:center;
  gap:10px;
  margin:0;
  width:100%;
}
.success-stories .slider-dots span{
  width:10px;
  height:10px;
  border-radius:999px;
  display:block;
  background:rgba(255,255,255,.42);
  transition:width .25s ease, background .25s ease, transform .25s ease;
}
.success-stories .slider-dots span.active{
  width:26px;
  background:var(--orange);
}
.showcase-stats strong,
.stats strong{
  transition:transform .45s cubic-bezier(.22,1,.36,1), opacity .35s ease;
}
.showcase-stats strong.counting,
.stats strong.counting{
  transform:translateY(-3px);
}
@media(max-width:1000px){
  .success-stories .video-card{flex-basis:calc((100% - 44px) / 3);}
}
@media(max-width:760px){
  .success-stories .video-slider{padding:0 0 42px;overflow:hidden;}
  .video-viewport{overflow-x:auto;scroll-snap-type:x mandatory;padding:0 22px;}
  .success-stories .video-track{transform:none!important;}
  .success-stories .video-card{flex-basis:78vw;scroll-snap-align:center;}
  .success-stories .slider-nav{display:none;}
}

.nav-cta{position:relative;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;min-width:170px}
.nav-cta .hover-text{position:absolute;opacity:0;transform:translateY(14px);transition:all .35s ease}
.nav-cta .default-text{transition:all .35s ease}
.nav-cta:hover .default-text{opacity:0;transform:translateY(-14px)}
.nav-cta:hover .hover-text{opacity:1;transform:translateY(0)}
.slider-nav{width:auto!important;height:auto!important;border:none!important;background:transparent!important;box-shadow:none!important;padding:0 8px;font-size:56px!important;font-weight:300}
.slider-prev{left:-55px!important}
.slider-next{right:-55px!important}
.slider-nav:hover{background:transparent!important;color:#fff;transform:translateY(-50%) scale(1.15)!important}

.thumb-video{
position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
}
.video-card:hover .thumb-video{transform:scale(1.03);transition:transform .4s ease;}

/* v14 mobile service accordion fix: remove tall empty space and expand only on interaction */
@media (max-width: 820px){
  .services-accordion-section{
    padding:64px 0 72px;
  }
  .services-accordion{
    min-height:0!important;
    display:grid!important;
    gap:16px;
    overflow:visible;
  }
  .accordion-card,
  .accordion-card:hover,
  .accordion-card:focus-within,
  .accordion-card.is-active{
    min-height:0!important;
    height:auto!important;
    display:block!important;
    overflow:hidden;
    border-radius:24px;
  }
  .accordion-summary,
  .accordion-card:hover .accordion-summary,
  .accordion-card:focus-within .accordion-summary,
  .accordion-card.is-active .accordion-summary,
  .services-accordion.is-interacting .accordion-card:not(.is-active) .accordion-summary{
    min-height:0!important;
    height:auto!important;
    width:auto!important;
    flex-basis:auto!important;
    max-width:none!important;
    padding:24px!important;
    align-items:flex-start!important;
    justify-content:flex-start!important;
    text-align:left!important;
    gap:13px;
  }
  .accordion-summary .icon{
    width:50px!important;
    height:50px!important;
  }
  .accordion-summary .icon::before{
    inset:15px!important;
  }
  .accordion-summary h3,
  .accordion-card.service-ops .accordion-summary h3,
  .services-accordion.is-interacting .accordion-card:not(.is-active) .accordion-summary h3{
    font-size:clamp(28px,8vw,38px)!important;
    line-height:.96!important;
    writing-mode:initial!important;
    transform:none!important;
  }
  .accordion-summary p,
  .accordion-summary span,
  .accordion-summary .service-arrow,
  .service-number,
  .services-accordion.is-interacting .accordion-card:not(.is-active) .accordion-summary p,
  .services-accordion.is-interacting .accordion-card:not(.is-active) .accordion-summary .service-arrow,
  .services-accordion.is-interacting .accordion-card:not(.is-active) .accordion-summary span,
  .services-accordion.is-interacting .accordion-card:not(.is-active) .service-number{
    opacity:1!important;
    transform:none!important;
    pointer-events:auto!important;
  }
  .service-number{
    right:24px!important;
    left:auto!important;
    bottom:18px!important;
    font-size:42px!important;
  }
  .accordion-details,
  .accordion-card:not(.service-ops) .accordion-details,
  .accordion-card.service-ops .accordion-details{
    display:block!important;
    width:auto!important;
    max-height:0;
    opacity:0;
    overflow:hidden;
    transform:none!important;
    padding:0 24px!important;
    margin:0 16px!important;
    border-radius:20px;
    pointer-events:none;
    transition:max-height .45s cubic-bezier(.22,1,.36,1), opacity .25s ease, padding .25s ease, margin .25s ease;
  }
  .accordion-card:hover .accordion-details,
  .accordion-card:focus-within .accordion-details,
  .accordion-card.is-active .accordion-details{
    max-height:760px;
    opacity:1;
    padding:22px 24px!important;
    margin:0 16px 16px!important;
    pointer-events:auto;
  }
  .accordion-details ul{
    margin-top:18px;
  }
}


/* v15 mobile carousel and stats polish */
@media(max-width:760px){
  .success-stories .video-slider{
    padding:0 46px 48px;
    overflow:visible;
  }
  .video-viewport{
    overflow:hidden;
    padding:0;
    scroll-snap-type:none;
  }
  .success-stories .video-track{
    transform:translateX(0);
  }
  .success-stories .video-card{
    flex:0 0 100%;
    scroll-snap-align:none;
  }
  .success-stories .slider-nav{
    display:grid;
    top:44%;
    font-size:42px!important;
    padding:0!important;
    z-index:20;
  }
  .success-stories .slider-prev{
    left:4px!important;
  }
  .success-stories .slider-next{
    right:4px!important;
  }
  .video-viewport::-webkit-scrollbar,
  .video-slider::-webkit-scrollbar{
    display:none;
  }
  .video-viewport,
  .video-slider{
    scrollbar-width:none;
    -ms-overflow-style:none;
  }
  .showcase-stats{
    display:grid;
    grid-template-columns:1fr;
    gap:22px;
    background:transparent!important;
    border:0!important;
    box-shadow:none!important;
    padding:0!important;
    margin:0 0 34px;
  }
  .showcase-stats div{
    width:100%;
    padding:28px 22px;
    border-radius:26px;
    text-align:center;
    background:rgba(255,255,255,.92);
    border:1px solid rgba(16,32,51,.1);
    box-shadow:0 18px 42px rgba(16,32,51,.06);
  }
  .showcase-stats strong{
    font-size:clamp(36px,10vw,48px);
    font-weight:400;
  }
  .showcase-stats span{
    font-size:17px;
  }
}


@media (max-width: 768px){
  .stats{
    display:grid !important;
    grid-template-columns:1fr !important;
    background:transparent !important;
    border:none !important;
    box-shadow:none !important;
    padding:0 !important;
    gap:16px !important;
  }
  .stats > div{
    background:#fff;
    border:1px solid var(--line);
    border-radius:28px;
    box-shadow:0 18px 50px rgba(16,32,51,.08);
    padding:28px;
    text-align:center;
  }
}

.form-honey {
  position: absolute !important;
  left: -9999px !important;
  opacity: 0 !important;
  height: 0 !important;
  width: 0 !important;
  pointer-events: none !important;
}


/* v17: adaptive video modal. Keeps square, landscape, and vertical videos from cropping */
.video-modal-dialog{
  width:min(440px,92vw);
  max-width:92vw;
}
.video-modal-frame{
  aspect-ratio:var(--video-modal-ratio, 9 / 16);
  max-height:78vh;
}
.video-modal-player{
  object-fit:contain;
}
@media(max-width:540px){
  .video-modal-dialog{width:min(92vw, var(--video-modal-width, 360px));}
  .video-modal-frame{max-height:76vh;}
}


/* Contact form - FormSubmit */
.contact-form{
  max-width:720px;
  margin:40px auto 0;
  display:flex;
  flex-direction:column;
  gap:18px;
  text-align:left;
}
.contact-form label{
  display:flex;
  flex-direction:column;
  gap:8px;
  color:var(--ink);
  font-weight:700;
}
.contact-form input,
.contact-form select,
.contact-form textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius:18px;
  padding:16px 18px;
  background:#fff;
  color:var(--ink);
  font:inherit;
  box-shadow:0 14px 36px rgba(16,32,51,.06);
  outline:none;
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{
  border-color:rgba(8,115,179,.5);
  box-shadow:0 0 0 4px rgba(8,115,179,.09);
}
.contact-form textarea{
  min-height:180px;
  resize:vertical;
}
.contact-form .form-submit{
  border:0;
  cursor:pointer;
  align-self:flex-start;
}


/* Graphics and Website Showcase */
.portfolio-showcase{padding:80px 0}
.showcase-section{margin:60px 0}
.showcase-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}
.showcase-head h3{font-size:1rem;letter-spacing:.12em;text-transform:uppercase}
.graphics-grid{display:grid;grid-template-columns:1fr 1.6fr 1fr 1fr;gap:18px}
.graphic-item,.website-item{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 10px 30px rgba(0,0,0,.08)}
.graphic-item img,.website-item img{width:100%;height:100%;object-fit:cover;display:block}
.graphic-tall{grid-row:span 2;min-height:500px}
.graphic-square{min-height:240px}
.websites-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.website-info{padding:18px}
.tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.tags span{background:#eef2f6;padding:4px 8px;border-radius:8px;font-size:.75rem}
@media(max-width:900px){
.graphics-grid,.websites-grid{grid-template-columns:1fr 1fr}
.graphic-tall{grid-row:auto;min-height:300px}
}
@media(max-width:640px){
.graphics-grid,.websites-grid{grid-template-columns:1fr}
}

/* v21 sample work updates */
.portfolio-showcase{
  padding:86px 0 80px;
}
.showcase-head{
  gap:24px;
}
.showcase-head > div .eyebrow{
  margin-bottom:8px;
}
.showcase-head h3{
  font-size:clamp(1.35rem,2.4vw,2.25rem);
  letter-spacing:-.03em;
  text-transform:none;
  color:var(--navy);
}
.showcase-head a{
  color:var(--navy);
  font-weight:800;
  text-decoration:none;
}
.graphics-grid{
  display:grid;
  grid-template-columns:1fr 1.35fr 1fr 1fr;
  grid-auto-rows:220px;
  gap:18px;
}
.graphic-item{
  position:relative;
  margin:0;
  border:1px solid rgba(8,29,52,.08);
  transition:transform .35s ease, box-shadow .35s ease;
}
.graphic-item:hover,
.website-item:hover{
  transform:translateY(-6px);
  box-shadow:0 20px 50px rgba(8,29,52,.16);
}
.graphic-item img{
  transition:transform .55s cubic-bezier(.22,1,.36,1);
}
.graphic-item:hover img{
  transform:scale(1.04);
}
.graphic-item figcaption{
  position:absolute;
  left:14px;
  right:14px;
  bottom:14px;
  padding:10px 12px;
  border-radius:14px;
  background:rgba(8,29,52,.72);
  color:#fff;
  font-weight:800;
  font-size:.88rem;
  backdrop-filter:blur(10px);
}
.graphic-tall{
  grid-row:span 2;
  min-height:auto;
}
.graphic-wide{
  grid-column:span 2;
}
.websites-grid{
  grid-template-columns:repeat(3,1fr);
}
.website-item{
  position:relative;
  border:1px solid rgba(8,29,52,.08);
  transition:transform .35s ease, box-shadow .35s ease;
}
.browser-frame{
  height:34px;
  background:#f3f5f7;
  display:flex;
  align-items:center;
  gap:7px;
  padding:0 14px;
  border-bottom:1px solid rgba(8,29,52,.08);
}
.browser-frame span{
  width:9px;
  height:9px;
  border-radius:50%;
  background:#c9d2dd;
  display:block;
}
.website-item img{
  height:210px;
  object-fit:cover;
  object-position:top center;
  border-bottom:1px solid rgba(8,29,52,.08);
}
.website-info p{
  margin:6px 0 0;
  color:var(--muted);
  font-weight:600;
}
@media(max-width:1050px){
  .graphics-grid{
    grid-template-columns:repeat(2,1fr);
    grid-auto-rows:260px;
  }
  .graphic-tall,
  .graphic-wide{
    grid-row:auto;
    grid-column:auto;
  }
  .websites-grid{
    grid-template-columns:repeat(2,1fr);
  }
}
@media(max-width:640px){
  .portfolio-showcase{
    padding:60px 0;
  }
  .showcase-head{
    align-items:flex-start;
    flex-direction:column;
  }
  .graphics-grid,
  .websites-grid{
    grid-template-columns:1fr;
  }
  .graphics-grid{
    grid-auto-rows:auto;
  }
  .graphic-item{
    min-height:auto;
  }
  .graphic-item img{
    aspect-ratio:1 / 1;
  }
  .website-item img{
    height:230px;
  }
}

.graphics-category-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:30px}
.category-card{background:#fff;border-radius:24px;overflow:hidden;box-shadow:0 10px 30px rgba(0,0,0,.08)}
.category-card h4{padding:20px;font-size:1.5rem;margin:0}
.category-card img{width:100%;height:280px;object-fit:cover;display:block}
.section-copy{max-width:700px}
@media(max-width:900px){.graphics-category-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.graphics-category-grid{grid-template-columns:1fr}}


/* v23 Graphic category gallery */
.graphics-premium{
  padding:72px 0 84px;
}
.graphics-head{
  align-items:flex-start;
}
.graphics-head h3{
  font-size:clamp(34px,4vw,58px);
  letter-spacing:-.05em;
  margin-bottom:12px;
}
.premium-category-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:22px;
  margin-top:34px;
}
.graphic-category-card{
  position:relative;
  border-radius:24px;
  overflow:hidden;
  background:linear-gradient(160deg,rgba(16,32,51,.98),rgba(6,15,27,.98));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 24px 60px rgba(16,32,51,.16);
  transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}
.graphic-category-card:hover{
  transform:translateY(-8px);
  box-shadow:0 34px 80px rgba(16,32,51,.22);
  border-color:rgba(255,151,24,.35);
}
.graphic-category-button{
  width:100%;
  height:100%;
  border:0;
  background:transparent;
  color:#fff;
  text-align:left;
  padding:22px;
  cursor:pointer;
  font-family:inherit;
  display:flex;
  flex-direction:column;
  gap:20px;
}
.graphic-category-top{
  display:grid;
  grid-template-columns:56px 1fr;
  gap:16px;
  align-items:start;
}
.graphic-category-icon{
  width:56px;
  height:56px;
  display:grid;
  place-items:center;
  border-radius:16px;
  background:rgba(255,255,255,.1);
  color:#fff;
  font-size:26px;
  font-weight:900;
}
.graphic-category-card h4{
  margin:2px 0 8px;
  color:#fff;
  font-size:22px;
  line-height:1.05;
  letter-spacing:-.03em;
}
.graphic-category-card p{
  color:rgba(255,255,255,.74);
  margin:0;
  line-height:1.45;
  font-size:14px;
}
.graphic-category-preview{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:6px;
  border-radius:16px;
  overflow:hidden;
  background:rgba(255,255,255,.06);
  min-height:310px;
}
.graphic-category-preview img{
  width:100%;
  height:100%;
  min-height:150px;
  object-fit:cover;
  display:block;
  filter:saturate(.95) contrast(1.04);
  transition:transform .35s ease, opacity .35s ease;
}
.graphic-category-card:hover .graphic-category-preview img{
  transform:scale(1.04);
}
.graphic-view-link{
  color:var(--orange);
  font-weight:800;
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin-top:auto;
  transition:gap .25s ease;
}
.graphic-category-card:hover .graphic-view-link{
  gap:16px;
}
.graphic-ecommerce{background:linear-gradient(160deg,#142f25,#071727)}
.graphic-logos{background:linear-gradient(160deg,#102033,#071727)}
.graphic-print{background:linear-gradient(160deg,#351717,#071727)}
.graphic-youtube{background:linear-gradient(160deg,#211532,#071727)}
.graphic-modal{
  position:fixed;
  inset:0;
  z-index:1000;
  display:none;
  align-items:center;
  justify-content:center;
  padding:26px;
}
.graphic-modal.is-open{display:flex}
.graphic-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(6,12,18,.72);
  backdrop-filter:blur(12px);
}
.graphic-modal-dialog{
  position:relative;
  width:min(980px,94vw);
  background:linear-gradient(145deg,#101821,#060b10);
  border:1px solid rgba(255,255,255,.12);
  border-radius:24px;
  box-shadow:0 30px 90px rgba(0,0,0,.42);
  padding:26px 58px 38px;
  color:#fff;
  overflow:hidden;
}
.graphic-modal-close{
  position:absolute;
  top:18px;
  right:18px;
  width:42px;
  height:42px;
  border:0;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  color:#fff;
  font-size:28px;
  cursor:pointer;
}
.graphic-modal-head{
  display:flex;
  gap:16px;
  align-items:center;
  margin-bottom:22px;
}
.graphic-modal-icon{
  width:56px;
  height:56px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:var(--green);
  color:#fff;
  font-size:26px;
}
.graphic-modal-head h3{
  margin:0;
  font-size:28px;
  letter-spacing:-.04em;
}
.graphic-modal-head p{
  margin:4px 0 0;
  color:var(--orange);
  font-weight:800;
}
.graphic-gallery-window{
  overflow:hidden;
  width:100%;
}
.graphic-gallery-track{
  display:flex;
  gap:14px;
  transition:transform .45s cubic-bezier(.22,1,.36,1);
}
.graphic-gallery-item{
  flex:0 0 calc((100% - 56px)/5);
  aspect-ratio:3/4;
  border-radius:16px;
  overflow:hidden;
  background:#142033;
  border:1px solid rgba(255,255,255,.12);
}
.graphic-gallery-item img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.graphic-gallery-nav{
  position:absolute;
  top:56%;
  transform:translateY(-50%);
  width:48px;
  height:48px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.08);
  color:#fff;
  font-size:28px;
  cursor:pointer;
  z-index:2;
}
.graphic-gallery-prev{left:12px}
.graphic-gallery-next{right:12px}
.graphic-gallery-dots{
  display:flex;
  justify-content:center;
  gap:10px;
  margin-top:24px;
}
.graphic-gallery-dots span{
  width:10px;
  height:10px;
  border-radius:999px;
  background:rgba(255,255,255,.28);
}
.graphic-gallery-dots span.active{background:var(--orange);width:24px}
@media(max-width:1100px){
  .premium-category-grid{grid-template-columns:1fr 1fr}
  .graphic-gallery-item{flex-basis:calc((100% - 28px)/3)}
}
@media(max-width:700px){
  .premium-category-grid{grid-template-columns:1fr}
  .graphic-category-preview{min-height:260px}
  .graphic-modal-dialog{padding:24px 20px 34px;width:96vw}
  .graphic-gallery-item{flex-basis:74%;}
  .graphic-gallery-nav{display:none}
}


/* v24 portfolio showcase refresh */
.portfolio-showcase{
  max-width:none;
  width:100vw;
  margin-left:calc(50% - 50vw);
  padding:86px clamp(22px,5vw,72px) 92px;
  background:
    radial-gradient(circle at 18% 0%, rgba(255,151,24,.12), transparent 28%),
    radial-gradient(circle at 88% 36%, rgba(8,115,179,.12), transparent 26%),
    linear-gradient(180deg,#05090d 0%,#07111a 100%);
  color:#fff;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,151,24,.18);
}
.portfolio-showcase .showcase-section{
  max-width:1180px;
  margin:0 auto 74px;
}
.portfolio-showcase .showcase-head{
  align-items:flex-start;
  margin-bottom:30px;
}
.portfolio-showcase .showcase-head h3{
  color:#fff;
  font-size:clamp(32px,3.6vw,50px);
  letter-spacing:-.055em;
  line-height:1;
  margin-bottom:14px;
}
.portfolio-showcase .showcase-head .eyebrow{
  color:#ffbd5c;
}
.portfolio-showcase .section-copy{
  color:rgba(255,255,255,.74);
  max-width:520px;
  line-height:1.6;
}
.portfolio-showcase .showcase-head a{
  color:#ffbd5c;
  font-weight:850;
  margin-top:34px;
  transition:transform .25s ease, color .25s ease;
}
.portfolio-showcase .showcase-head a:hover{
  color:#fff;
  transform:translateX(6px);
}

.portfolio-showcase .premium-category-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
  margin-top:0;
}
.portfolio-showcase .graphic-category-card{
  padding:18px;
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.11);
  box-shadow:0 24px 64px rgba(0,0,0,.22);
  min-height:0;
  cursor:default;
}
.portfolio-showcase .graphic-category-card:hover{
  transform:translateY(-5px);
}
.portfolio-showcase .graphic-category-top{
  display:grid;
  grid-template-columns:52px 1fr;
  gap:14px;
  align-items:start;
  margin-bottom:16px;
}
.portfolio-showcase .graphic-category-icon{
  width:52px;
  height:52px;
  border-radius:16px;
  font-size:24px;
  background:rgba(255,255,255,.1);
}
.portfolio-showcase .graphic-category-card h4{
  color:#fff;
  margin:2px 0 7px;
  font-size:18px;
  line-height:1.15;
}
.portfolio-showcase .graphic-category-card p{
  color:rgba(255,255,255,.72);
  font-size:13px;
  line-height:1.35;
}
.portfolio-showcase .graphic-category-preview{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:6px;
  min-height:0;
  background:rgba(255,255,255,.05);
  border-radius:12px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
}
.portfolio-showcase .graphic-category-preview img{
  width:100%;
  height:112px;
  min-height:0;
  object-fit:cover;
  display:block;
  filter:saturate(.96) contrast(1.04);
}
.portfolio-showcase .graphic-category-preview img:first-child{
  grid-row:span 2;
  height:230px;
}
.portfolio-showcase .logo-preview img,
.portfolio-showcase .youtube-preview img{
  height:105px;
}
.portfolio-showcase .logo-preview img:first-child,
.portfolio-showcase .youtube-preview img:first-child{
  grid-row:auto;
  height:105px;
}
.portfolio-showcase .print-preview img:first-child{
  height:230px;
}
.portfolio-showcase .graphic-view-link{
  display:inline-flex;
  margin-top:16px;
  font-size:14px;
  color:#8dcc72;
}
.portfolio-showcase .graphic-logos .graphic-view-link{color:#5fb2ff}
.portfolio-showcase .graphic-print .graphic-view-link{color:#ff6f61}
.portfolio-showcase .graphic-youtube .graphic-view-link{color:#b58cff}

.portfolio-showcase .websites-premium{
  padding-top:28px;
  border-top:1px solid rgba(255,255,255,.1);
}
.portfolio-showcase .websites-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:20px;
}
.portfolio-showcase .website-item{
  background:linear-gradient(160deg,rgba(16,32,51,.8),rgba(6,15,27,.92));
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 22px 62px rgba(0,0,0,.24);
  color:#fff;
}
.portfolio-showcase .website-item:hover{
  transform:translateY(-5px);
  box-shadow:0 28px 72px rgba(0,0,0,.32);
}
.portfolio-showcase .browser-frame{
  height:26px;
  background:rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.08);
  padding:0 12px;
}
.portfolio-showcase .browser-frame span{
  width:8px;
  height:8px;
  background:rgba(255,255,255,.38);
}
.portfolio-showcase .website-item img{
  height:205px;
  width:100%;
  object-fit:cover;
  object-position:top center;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.portfolio-showcase .website-info{
  padding:18px;
}
.portfolio-showcase .website-info h4{
  margin:0 0 8px;
  color:#fff;
  font-size:20px;
}
.portfolio-showcase .website-info p{
  color:rgba(255,255,255,.72);
  margin:0;
}
.portfolio-showcase .tags span{
  background:rgba(255,255,255,.08);
  color:#fff;
  border:1px solid rgba(255,255,255,.08);
}

.portfolio-cta{
  max-width:1180px;
  margin:18px auto 0;
  padding:28px clamp(20px,4vw,44px);
  border-radius:18px;
  border:1px solid rgba(255,151,24,.24);
  background:linear-gradient(90deg,rgba(255,151,24,.08),rgba(255,255,255,.03));
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:22px;
  align-items:center;
}
.portfolio-cta-icon{
  width:58px;
  height:58px;
  display:grid;
  place-items:center;
  border-radius:16px;
  background:rgba(255,151,24,.12);
  color:#ffbd5c;
  border:1px solid rgba(255,151,24,.25);
  font-size:26px;
}
.portfolio-cta strong{
  color:#fff;
  font-size:18px;
}
.portfolio-cta p{
  color:rgba(255,255,255,.72);
  margin:5px 0 0;
}

@media(max-width:1100px){
  .portfolio-showcase .premium-category-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .portfolio-showcase .websites-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media(max-width:700px){
  .portfolio-showcase{
    padding:64px 18px 72px;
  }
  .portfolio-showcase .showcase-head{
    flex-direction:column;
    gap:10px;
  }
  .portfolio-showcase .showcase-head a{
    margin-top:0;
  }
  .portfolio-showcase .premium-category-grid,
  .portfolio-showcase .websites-grid{
    grid-template-columns:1fr;
  }
  .portfolio-showcase .graphic-category-preview img,
  .portfolio-showcase .logo-preview img,
  .portfolio-showcase .youtube-preview img{
    height:120px;
  }
  .portfolio-showcase .graphic-category-preview img:first-child,
  .portfolio-showcase .print-preview img:first-child{
    height:246px;
  }
  .portfolio-showcase .website-item img{
    height:210px;
  }
  .portfolio-cta{
    grid-template-columns:1fr;
    text-align:left;
  }
  .portfolio-cta .button{
    width:100%;
    justify-content:center;
  }
}



/* v25 service icon fix */
.accordion-summary .icon{
  display:grid;
  place-items:center;
  color:rgba(255,255,255,.92);
  font-weight:900;
  font-size:22px;
  line-height:1;
}
.accordion-summary .icon::before{
  position:static;
  inset:auto;
  border:0;
  border-radius:0;
}
.accordion-summary .web-icon::before{content:"</>";font-size:19px;letter-spacing:-.08em;}
.accordion-summary .video-icon::before{content:"▶";font-size:24px;transform:translateX(2px);}
.accordion-summary .graphic-icon::before{content:"✦";font-size:26px;}
.accordion-summary .ops-icon::before{content:"⚙";font-size:25px;}
.accordion-summary .icon::after{display:none;}
.accordion-card.service-ops .accordion-summary .icon{color:var(--green);}

/* v25 website mockup refresh */
.websites-grid .website-item img{
  aspect-ratio:16/9;
  object-fit:cover;
  object-position:top center;
}
.websites-grid .website-item{
  overflow:hidden;
}

/* v26 service accordion alignment fix: center collapsed card content */
@media (min-width:821px){
  .services-accordion:not(.is-interacting) .accordion-card:not(:hover):not(:focus-within):not(.is-active) .accordion-details{
    flex:0 0 0!important;
    width:0!important;
    min-width:0!important;
    max-width:0!important;
    padding:0!important;
    margin:0!important;
    opacity:0!important;
    pointer-events:none!important;
    overflow:hidden!important;
  }

  .services-accordion:not(.is-interacting) .accordion-card:not(:hover):not(:focus-within):not(.is-active) .accordion-summary{
    width:100%!important;
    flex:1 1 100%!important;
    max-width:none!important;
    padding-left:30px!important;
    padding-right:30px!important;
    align-items:center!important;
    text-align:center!important;
    transform:translateX(0)!important;
  }

  .services-accordion:not(.is-interacting) .accordion-card:not(:hover):not(:focus-within):not(.is-active) .accordion-summary .icon,
  .services-accordion:not(.is-interacting) .accordion-card:not(:hover):not(:focus-within):not(.is-active) .accordion-summary h3,
  .services-accordion:not(.is-interacting) .accordion-card:not(:hover):not(:focus-within):not(.is-active) .accordion-summary span,
  .services-accordion:not(.is-interacting) .accordion-card:not(:hover):not(:focus-within):not(.is-active) .accordion-summary p,
  .services-accordion:not(.is-interacting) .accordion-card:not(:hover):not(:focus-within):not(.is-active) .accordion-summary .service-arrow{
    margin-left:auto!important;
    margin-right:auto!important;
  }
}
