
:root {
  --bg: #EEEEF0;
  --card: #FFFFFF;
  --border: #DDDDE0;
  --border2: #C8C8CC;
  --text: #0D0D0F;
  --text2: #3A3A40;
  --text3: #71717A;
  --text4: #A1A1AA;
  --accent: #800000;
  --accent2: #A52040;
  --accent-bg: rgba(128,0,0,0.08);
  --accent-border: rgba(128,0,0,0.2);
  --green: #16A34A;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.06);
  --shadow-md: 0 4px 20px rgba(0,0,0,0.08), 0 1px 4px rgba(0,0,0,0.04);
  --shadow-lg: 0 20px 60px rgba(0,0,0,0.1), 0 4px 16px rgba(0,0,0,0.06);
  --shadow-xl: 0 40px 80px rgba(0,0,0,0.14), 0 8px 24px rgba(0,0,0,0.07);
  --r: 10px;
  --r-lg: 16px;
  --r-xl: 20px;
  --r-2xl: 28px;
  --grid-line: #9898A0;
}
/* DARK MODE */
:root[data-theme="dark"] {
  --bg: #0A0A0C;
  --grid-line: #26262E;
  --card: #1A1A1C;
  --border: #2A2A2E;
  --border2: #3A3A3E;
  --text: #F0F0F2;
  --text2: #C8C8CC;
  --text3: #8A8A92;
  --text4: #5A5A62;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.4);
  --shadow-md: 0 4px 20px rgba(0,0,0,0.5), 0 1px 4px rgba(0,0,0,0.3);
  --shadow-lg: 0 20px 60px rgba(0,0,0,0.6), 0 4px 16px rgba(0,0,0,0.4);
  --shadow-xl: 0 40px 80px rgba(0,0,0,0.7), 0 8px 24px rgba(0,0,0,0.5);
}
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; scroll-padding-top:100px; -webkit-text-size-adjust:100%; text-size-adjust:100%; overflow-x:clip; }
body{ -webkit-tap-highlight-color:rgba(128,0,0,0.15); }
body {
  font-family:'Inter',sans-serif;
  background-color:transparent;
  color:var(--text);
  overflow-x:clip;
  -webkit-font-smoothing:antialiased;
  transition:color .25s;
}
html { background-color:var(--bg); transition:background-color .25s; }
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--accent);border-radius:3px}

/* NAV */
nav {
  position:fixed;top:14px;left:50%;transform:translateX(-50%);z-index:200;
  width:calc(100% - 36px);max-width:1180px;
  background:rgba(248,248,250,0.96);
  backdrop-filter:blur(28px) saturate(180%);
  -webkit-backdrop-filter:blur(28px) saturate(180%);
  border:1px solid rgba(0,0,0,0.06);
  border-radius:100px;
  box-shadow:0 10px 34px rgba(0,0,0,0.14), inset 0 1px 0 rgba(255,255,255,0.9);
  height:64px;display:flex;align-items:center;
  padding:0 14px 0 22px;gap:24px;
  transition:box-shadow .2s,background .25s;
}
.nav-logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0}
.nav-logo img{height:45px;width:auto}
.nav-brand{margin-left:10px;font-size:20px;font-weight:800;letter-spacing:-0.5px;color:var(--text);white-space:nowrap}
@media(max-width:480px){.nav-brand{font-size:17px;margin-left:8px}}
.nav-links{display:flex;gap:2px;flex:1;justify-content:center;position:relative;align-items:center}
.nav-links a{font-size:14px;font-weight:600;color:var(--text3);text-decoration:none;padding:7px 18px;border-radius:100px;transition:color .2s;position:relative;z-index:1}
.nav-links a:hover{color:var(--text)}
.nav-links a.active{color:var(--accent)}
/* DROPDOWN */
.nav-drop{position:relative;display:flex;align-items:center}
.nav-drop-btn{font-size:14px;font-weight:600;color:var(--text3);background:none;border:none;cursor:pointer;padding:7px 18px;border-radius:100px;display:flex;align-items:center;gap:5px;transition:color .2s;font-family:inherit;position:relative;z-index:1}
.nav-drop-btn:hover{color:var(--text)}
.nav-drop-btn.active{color:var(--accent)}
.nav-drop-arrow{width:10px;height:6px;flex-shrink:0;transition:transform .22s;stroke-linecap:round;stroke-linejoin:round}
.nav-drop:hover .nav-drop-arrow,.nav-drop.open .nav-drop-arrow{transform:rotate(180deg)}
/* desktop: clip-path extend animation — menu grows downward out of the button */
.nav-drop-menu{
  display:flex;flex-direction:column;gap:2px;
  position:absolute;top:100%;left:50%;
  transform:translateX(-50%) translateY(-6px);
  background:var(--card);border:1px solid var(--border);border-radius:16px;
  padding:12px 8px 8px;min-width:220px;
  box-shadow:0 16px 44px rgba(0,0,0,.26);
  -webkit-backdrop-filter:blur(20px) saturate(160%);backdrop-filter:blur(20px) saturate(160%);
  z-index:210;
  /* hidden — collapsed to button width at top */
  opacity:0;visibility:hidden;pointer-events:none;
  clip-path:inset(0 8% 100% 8% round 16px);
  transition:
    clip-path .32s cubic-bezier(.16,1,.3,1),
    transform .32s cubic-bezier(.16,1,.3,1),
    opacity .2s ease,
    visibility 0s linear .32s;
}
.nav-drop:hover .nav-drop-menu,
.nav-drop.open .nav-drop-menu{
  opacity:1;visibility:visible;pointer-events:auto;
  clip-path:inset(0 0% 0% 0% round 16px);
  transform:translateX(-50%) translateY(0);
  transition:
    clip-path .32s cubic-bezier(.16,1,.3,1),
    transform .32s cubic-bezier(.16,1,.3,1),
    opacity .2s ease,
    visibility 0s linear 0s;
}
.drop-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:10px;font-size:13.5px;font-weight:500;color:var(--text2);text-decoration:none;transition:all .15s;white-space:nowrap}
.drop-item:hover{background:var(--accent-bg);color:var(--text)}
.drop-item svg{width:15px;height:15px;flex-shrink:0;opacity:.75}
.drop-item.drop-active{color:var(--accent)}
/* nav link icons — hidden on desktop, shown inside mobile open menu */
.nav-links a .nav-ico,.nav-drop-btn .nav-ico{display:none;width:18px;height:18px;flex-shrink:0}
/* TUBELIGHT sliding pill (liquid glass, maroon glow) */
.nav-lamp{
  position:absolute;top:50%;left:0;width:0;height:34px;
  transform:translateY(-50%);z-index:0;opacity:0;pointer-events:none;border-radius:100px;
  background:rgba(128,0,0,0.10);
  -webkit-backdrop-filter:blur(10px) saturate(170%);backdrop-filter:blur(10px) saturate(170%);
  border:1px solid rgba(128,0,0,0.18);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.55), 0 2px 12px rgba(128,0,0,0.18);
  transition:left .38s cubic-bezier(.34,1.56,.64,1), width .38s cubic-bezier(.34,1.56,.64,1), opacity .22s;
}
.nav-lamp::before{content:'';position:absolute;top:-7px;left:50%;transform:translateX(-50%);width:30px;height:4px;background:var(--accent);border-radius:0 0 6px 6px}
.nav-lamp::after{content:'';position:absolute;top:-11px;left:50%;transform:translateX(-50%);width:50px;height:18px;background:var(--accent);opacity:.45;filter:blur(9px);border-radius:50%}
[data-theme="dark"] .nav-lamp{
  background:rgba(200,60,90,0.15);
  border-color:rgba(200,60,90,0.32);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.12), 0 2px 16px rgba(128,0,0,0.42);
}
[data-theme="dark"] nav{
  background:rgba(16,16,20,0.96);
  border-color:rgba(255,255,255,0.12);
  box-shadow:0 10px 34px rgba(0,0,0,0.6), inset 0 1px 0 rgba(255,255,255,0.08);
}
[data-theme="dark"] .nav-links a:hover{color:var(--text)}
[data-theme="dark"] .nav-ghost:hover{background:rgba(255,255,255,0.06)}
/* THEME TOGGLE */
.theme-toggle{
  width:34px;height:34px;
  border-radius:9px;
  background:var(--bg);
  border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--text3);
  transition:background .18s,border-color .18s,color .18s;
  flex-shrink:0;
}
.theme-toggle:hover{background:var(--border2);color:var(--text)}
.theme-toggle svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;transition:opacity .2s}
.icon-sun{display:block}
.icon-moon{display:none}
[data-theme="dark"] .icon-sun{display:none}
[data-theme="dark"] .icon-moon{display:block}
.nav-right{display:flex;align-items:center;gap:8px;flex-shrink:0;margin-left:auto}
.nav-ghost{font-size:14px;font-weight:500;color:var(--text2);background:transparent;border:none;cursor:pointer;padding:8px 14px;border-radius:8px;text-decoration:none;transition:all .16s}
.nav-ghost:hover{background:rgba(0,0,0,0.06)}
.nav-cta{font-size:14px;font-weight:600;color:#fff;background:var(--text);border:none;cursor:pointer;padding:9px 22px;border-radius:100px;text-decoration:none;transition:all .2s;display:inline-flex;align-items:center;gap:6px}
.nav-cta:hover{background:var(--accent);transform:translateY(-1px)}
.ham-btn{display:none;background:none;border:none;cursor:pointer;color:var(--text);padding:4px}

/* PILL LABEL */
.pill-lbl {
  display:inline-flex;align-items:center;gap:6px;
  background:var(--card);border:1px solid var(--border);
  padding:5px 16px;border-radius:100px;
  font-size:12.5px;font-weight:500;color:var(--text3);
  margin-bottom:18px;box-shadow:var(--shadow-sm);
}

/* HERO */
.hero-scroll{position:relative;min-height:88vh;display:flex;align-items:center;justify-content:center;padding:96px 40px 70px;overflow:hidden}
.hero-title{text-align:center;max-width:720px;margin:0 auto;position:relative;z-index:5}
.hero-scroll h1{font-size:76px;font-weight:800;line-height:1.04;letter-spacing:-3.5px;color:var(--text);margin-bottom:20px}
.hero-scroll h1 .gray{color:var(--text3)}
/* ANIMATED GRADIENT WORD ROTATOR (hero headline) */
.hero-rotate{position:relative;display:inline-block;text-align:center;line-height:1.04}
.hero-rotate .rot-sizer{visibility:hidden}
.rot-word{
  position:absolute;left:50%;top:0;transform:translateX(-50%);
  white-space:nowrap;opacity:0;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  background-size:220% auto;
  animation:rotWord 9s infinite, rotShimmer 3.2s linear infinite;
  will-change:opacity,transform;
}
.rot-word.g1{background-image:linear-gradient(90deg,#800000,#e0566e,#A52040,#800000)}
.rot-word.g2{background-image:linear-gradient(90deg,#b8862f,#f0c14b,#C9A84C,#b8862f)}
.rot-word.g3{background-image:linear-gradient(90deg,#e0708a,#A52040,#800000,#e0708a)}
.rot-word.w2{animation-delay:-3s,0s}
.rot-word.w3{animation-delay:-6s,0s}
@keyframes rotWord{
  0%{opacity:0;transform:translateX(-50%) translateY(12px)}
  4%,28%{opacity:1;transform:translateX(-50%) translateY(0)}
  33%,100%{opacity:0;transform:translateX(-50%) translateY(-12px)}
}
@keyframes rotShimmer{to{background-position:220% center}}
@media(prefers-reduced-motion:reduce){
  .rot-word{animation:none}
  .rot-word.w1{opacity:1;position:relative;transform:none}
  .rot-word.w2,.rot-word.w3{display:none}
}

/* FLOATING ICONS */
.hero-icons{position:absolute;inset:0;z-index:2;pointer-events:none}
.float-icon{position:absolute;will-change:transform}
.fi-enter{opacity:0;animation:fiIn .65s cubic-bezier(.22,1,.36,1) forwards}
@keyframes fiIn{from{opacity:0;transform:scale(.4)}to{opacity:1;transform:scale(1)}}
.fi-float{
  display:flex;align-items:center;justify-content:center;
  width:60px;height:60px;border-radius:18px;
  background:var(--card);
  border:1px solid var(--border);
  box-shadow:var(--shadow-md);
  animation:fiFloat ease-in-out infinite;
}
.fi-float svg{width:30px;height:30px}
@keyframes fiFloat{
  0%{transform:translate(0,0) rotate(0)}
  25%{transform:translate(6px,-8px) rotate(5deg)}
  50%{transform:translate(0,0) rotate(0)}
  75%{transform:translate(-6px,8px) rotate(-5deg)}
  100%{transform:translate(0,0) rotate(0)}
}
[data-theme="dark"] .fi-float{background:rgba(28,28,34,0.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.fi-float.fi-line{color:#9e2440}
[data-theme="dark"] .fi-float.fi-line{color:#e0738b}
@media(min-width:769px){
  .fi-float{width:74px;height:74px;border-radius:22px}
  .fi-float svg{width:36px;height:36px}
}
@media(max-width:1200px){.hero-icons{display:none}}

.hero h1{font-size:76px;font-weight:800;line-height:1.04;letter-spacing:-3.5px;color:var(--text);margin-bottom:20px}
.hero h1 .gray{color:#ADADB3}
.hero-sub{font-size:16.5px;color:var(--text3);line-height:1.65;max-width:480px;margin:0 auto 34px}
.hero-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--accent);color:#fff;
  font-size:15px;font-weight:600;
  padding:14px 30px;border-radius:100px;
  text-decoration:none;border:none;cursor:pointer;
  transition:background .2s,box-shadow .2s;
  box-shadow:0 4px 18px rgba(128,0,0,0.32);
}
.hero-cta:hover{background:var(--accent2);box-shadow:0 8px 28px rgba(128,0,0,0.38)}
.hero-trust{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:28px}
.trust-faces{display:flex}
.trust-face{width:30px;height:30px;border-radius:50%;border:2px solid var(--card);margin-left:-8px;font-size:10px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.trust-face:first-child{margin-left:0}
.trust-txt{font-size:13px;color:var(--text3)}
.trust-txt strong{color:var(--text2)}

@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* TRUSTED BY — infinite marquee */
.trusted-band{
  position:relative;overflow:hidden;
  max-width:1160px;margin:10px auto;
  border-radius:26px;
  background:rgba(255,255,255,0.55);
  backdrop-filter:blur(30px) saturate(190%);
  -webkit-backdrop-filter:blur(30px) saturate(190%);
  border:1px solid rgba(255,255,255,0.6);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.9),
    inset 0 -1px 0 rgba(0,0,0,0.04),
    0 18px 44px rgba(0,0,0,0.10),
    0 2px 6px rgba(0,0,0,0.05);
  padding:26px 0;
  text-align:center;
}
.trusted-band::after{
  content:'';position:absolute;left:0;right:0;top:0;height:46%;pointer-events:none;
  background:linear-gradient(180deg, rgba(255,255,255,0.55), rgba(255,255,255,0));
  opacity:.5;mix-blend-mode:screen;border-radius:26px 26px 0 0;
}
[data-theme="dark"] .trusted-band{
  background:rgba(24,24,30,0.5);
  border:1px solid rgba(255,255,255,0.1);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.1),
    inset 0 -1px 0 rgba(0,0,0,0.3),
    0 18px 50px rgba(0,0,0,0.5),
    0 0 0 1px rgba(255,255,255,0.02);
}
[data-theme="dark"] .trusted-band::after{
  background:linear-gradient(180deg, rgba(255,255,255,0.12), rgba(255,255,255,0));
  opacity:.6;
}
.trusted-band > *{position:relative;z-index:1}
.trusted-head{margin-bottom:16px;padding:0 24px}
.trusted-eyebrow{font-size:14px;color:var(--text3);font-weight:400}
.trusted-eyebrow strong{font-weight:700;color:var(--text)}
.trusted-rule{height:1px;background:linear-gradient(to right,transparent,var(--border),transparent);margin:0 auto;max-width:480px}
.marquee-wrap{
  overflow:hidden;
  padding:14px 0;
  -webkit-mask-image:linear-gradient(to right,transparent,black 12%,black 88%,transparent);
  mask-image:linear-gradient(to right,transparent,black 12%,black 88%,transparent);
}
.marquee-track{
  display:flex;
  width:max-content;
  gap:0;
  animation:marquee-scroll 22s linear infinite;
}
.marquee-track:hover{animation-play-state:paused}
@keyframes marquee-scroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.marquee-item{
  display:inline-flex;
  align-items:center;
  gap:0;
  white-space:nowrap;
  padding:0 28px;
  font-size:14px;
  font-weight:600;
  color:var(--text3);
  letter-spacing:-0.01em;
  transition:color .18s;
}
.marquee-item:hover{color:var(--text)}
.marquee-dot{
  display:inline-block;
  width:4px;height:4px;
  border-radius:50%;
  background:var(--border2);
  margin:0 28px;
  flex-shrink:0;
  vertical-align:middle;
}

/* SECTIONS */
.sec{padding:96px 48px}
.sec-inner{max-width:1160px;margin:0 auto}
.sec-hd{text-align:center;margin-bottom:56px}
.sec-hd h2{font-size:44px;font-weight:800;letter-spacing:-1.8px;line-height:1.12;color:var(--text);margin-bottom:14px}
.sec-hd p{font-size:16px;color:var(--text3);line-height:1.65;max-width:520px;margin:0 auto}
.card-bg{background:var(--card)}
/* portfolio section grid bg */
#portfolio.sec{
  position:relative;
  background:transparent;
}
.port-grid-hi{
  display:none;
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(var(--accent) 1.2px, transparent 1.2px),
    linear-gradient(90deg, var(--accent) 1.2px, transparent 1.2px);
  background-size:12px 12px;
  opacity:0.6;
  -webkit-mask-image:radial-gradient(circle 0px at -9999px -9999px,black 0%,transparent 100%);
  mask-image:radial-gradient(circle 0px at -9999px -9999px,black 0%,transparent 100%);
  -webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;
}
#portfolio .sec-inner{position:relative;z-index:1}

/* SERVICES */
.svc-band{
  padding:80px 48px;
  background:transparent;
  position:relative;
}
.svc-band-hi{
  display:none;
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(var(--accent) 1.2px, transparent 1.2px),
    linear-gradient(90deg, var(--accent) 1.2px, transparent 1.2px);
  background-size:12px 12px;
  opacity:0.6;
  -webkit-mask-image:radial-gradient(circle 0px at -9999px -9999px,black 0%,transparent 100%);
  mask-image:radial-gradient(circle 0px at -9999px -9999px,black 0%,transparent 100%);
  -webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;
}
.svc-band-inner{position:relative;z-index:1;max-width:1160px;margin:0 auto}
.svc-band-hd{margin-bottom:48px}
.svc-band-eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.svc-band-eyebrow span{font-size:11px;font-weight:500;color:var(--text4);text-transform:uppercase;letter-spacing:.12em;white-space:nowrap}
.svc-band-eyebrow-line{height:1px;flex:1;background:var(--border)}
.svc-band-hd h2{font-size:38px;font-weight:700;letter-spacing:-1.5px;color:var(--text);margin-bottom:12px;line-height:1.1}
.svc-band-hd p{font-size:15px;color:var(--text3);line-height:1.7;max-width:540px}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:20px;
  overflow:hidden;
  transition:box-shadow .3s,border-color .3s;
}
.svc-card:hover{box-shadow:var(--shadow-md);border-color:var(--border2)}
/* preview canvas — frosted glass */
.svc-preview{
  position:relative;overflow:hidden;
  background:rgba(255,255,255,0.55);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  height:200px;
  border-bottom:1px solid var(--border);
}
[data-theme="dark"] .svc-preview{
  background:rgba(0,0,0,0.35);
}
.svc-win{
  position:relative;z-index:1;
  width:88%;height:82%;
  margin:14px auto 0;
  background:#0a0a0b;
  border:1px solid rgba(255,255,255,0.1);
  border-radius:12px;
  box-shadow:0 24px 60px rgba(0,0,0,0.6);
  overflow:hidden;
}
.svc-win-bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;
  border-bottom:1px solid rgba(255,255,255,0.05);
}
.svc-dots{display:flex;gap:5px}
.svc-dot{width:9px;height:9px;border-radius:50%}
.svc-win-label{font-size:10px;color:rgba(255,255,255,0.35);font-family:'Inter',sans-serif}
.svc-win-body{padding:12px 14px}
/* mock UI elements */
.m-bar{height:6px;border-radius:4px;margin-bottom:6px}
.m-row{display:flex;gap:6px;margin-bottom:6px}
.m-cell{border-radius:7px;border:1px solid rgba(255,255,255,0.08)}
.m-pill{height:5px;border-radius:4px}
.m-status{display:inline-flex;align-items:center;gap:6px;margin-top:8px;padding:5px 9px;border-radius:7px;background:rgba(52,211,153,0.1);border:1px solid rgba(52,211,153,0.2)}
.m-dot-green{width:6px;height:6px;border-radius:50%;background:#34d399}
.m-status span{font-size:9px;color:#34d399;font-family:'Inter',sans-serif}
/* card text */
.svc-body{padding:22px 22px 24px}
.svc-num{font-size:13px;font-weight:600;font-family:'Inter',sans-serif;margin-bottom:10px}
.svc-title{font-size:19px;font-weight:700;color:var(--text);letter-spacing:-.4px;margin-bottom:8px}
.svc-desc{font-size:13px;color:var(--text3);line-height:1.7;font-family:'Inter',sans-serif}


/* PORTFOLIO */
.port-filters{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:40px}
.port-filter-btn{font-size:13px;font-weight:500;color:var(--text3);background:var(--card);border:1.5px solid var(--border);padding:7px 18px;border-radius:100px;cursor:pointer;transition:all .18s;font-family:'Inter',sans-serif}
.port-filter-btn:hover{border-color:var(--accent);color:var(--accent)}
.port-filter-btn.active{background:var(--text);color:#fff;border-color:var(--text)}
.port-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.port-item{border-radius:var(--r-xl);overflow:hidden;cursor:pointer;position:relative;aspect-ratio:4/3;background:var(--border);transition:transform .22s,box-shadow .22s}
.port-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.port-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .38s ease}
.port-item:hover img{transform:scale(1.07)}
.port-overlay{position:absolute;inset:0;background:rgba(13,13,15,0.72);backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;transition:opacity .22s;padding:20px}
.port-item:hover .port-overlay{opacity:1}
.port-ov-icon{font-size:26px;margin-bottom:10px}
.port-ov-title{font-size:15px;font-weight:700;color:#fff;margin-bottom:6px;text-align:center}
.port-ov-client{font-size:11.5px;color:rgba(255,255,255,.6);margin-bottom:8px}
.port-ov-cat{font-size:10.5px;font-weight:600;color:rgba(255,255,255,.5);letter-spacing:.08em;text-transform:uppercase;background:rgba(255,255,255,.1);padding:3px 12px;border-radius:100px}
.port-item.port-hidden{display:none}
.port-item.port-cap{display:none}
/* show-more dropdown (portfolio iPad) */
.port-more{display:flex;width:-moz-fit-content;width:fit-content;align-items:center;gap:8px;margin:26px auto 0;padding:10px 22px;border-radius:100px;font-size:13.5px;font-weight:600;font-family:'Inter',sans-serif;cursor:pointer;color:var(--accent);background:rgba(128,0,0,0.07);border:1px solid var(--accent-border);-webkit-backdrop-filter:blur(10px) saturate(160%);backdrop-filter:blur(10px) saturate(160%);transition:background .2s,color .2s,border-color .2s}
.port-more:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.port-more svg{width:16px;height:16px;transition:transform .25s}
.port-more.open svg{transform:rotate(180deg)}
[data-theme="dark"] .port-more{background:rgba(200,60,90,0.12);color:#e0738b;border-color:rgba(200,60,90,0.3)}
[data-theme="dark"] .port-more:hover{background:var(--accent);color:#fff}
/* branded placeholder slot (shown until a real image is dropped in) */
.port-slot{position:absolute;inset:0;z-index:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:18px;color:#fff}
.port-slot-icon{font-size:30px;margin-bottom:10px;filter:drop-shadow(0 2px 6px rgba(0,0,0,0.3))}
.port-slot-title{font-size:14px;font-weight:700;color:#fff;margin-bottom:4px;text-shadow:0 1px 4px rgba(0,0,0,0.3)}
.port-slot-client{font-size:11px;font-weight:500;color:rgba(255,255,255,0.8);text-shadow:0 1px 4px rgba(0,0,0,0.3)}
.port-item img{position:relative;z-index:1}

/* Lightbox */
.port-lb{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);backdrop-filter:blur(18px);z-index:500;align-items:center;justify-content:center}
.port-lb.open{display:flex}
.port-lb-wrap{position:relative;max-width:900px;width:90vw;text-align:center}
.port-lb-img{max-height:75vh;width:auto;max-width:100%;border-radius:var(--r-xl);box-shadow:0 40px 80px rgba(0,0,0,.6);display:block;margin:0 auto}
.port-lb-info{margin-top:20px}
.port-lb-name{font-size:18px;font-weight:700;color:#fff;margin-bottom:6px}
.port-lb-tag{display:inline-block;font-size:11px;font-weight:600;color:rgba(255,255,255,.5);letter-spacing:.08em;text-transform:uppercase;background:rgba(255,255,255,.08);padding:4px 14px;border-radius:100px}
.port-lb-x{position:fixed;top:22px;right:24px;background:rgba(255,255,255,.1);border:none;color:#fff;font-size:18px;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .18s;z-index:10;line-height:1}
.port-lb-x:hover{background:rgba(255,255,255,.22)}
.port-lb-arr{position:fixed;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.1);border:none;color:#fff;font-size:28px;width:48px;height:48px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .18s;z-index:10}
.port-lb-arr:hover{background:rgba(255,255,255,.22)}
.port-lb-prev{left:18px}
.port-lb-next{right:18px}

/* TESTIMONIALS STACK */
.testi-section{position:relative;min-height:300vh}
.testi-sticky{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;padding:0 24px}
.testi-stack{position:relative;width:350px;height:450px;margin:0 auto;perspective:1000px}
.testi-card-item{
  position:absolute;left:0;top:0;width:100%;height:100%;
  background:var(--card);border:1px solid var(--border);border-radius:20px;
  padding:32px 28px;
  display:flex;flex-direction:column;justify-content:space-between;
  box-shadow:0 8px 32px rgba(0,0,0,0.08),0 2px 8px rgba(0,0,0,0.04);
  will-change:transform,opacity;
  backface-visibility:hidden;
}
.tci-stars{color:#FBBF24;font-size:16px;letter-spacing:3px;margin-bottom:16px}
.tci-quote{font-size:15px;color:var(--text2);line-height:1.75;flex:1}
.tci-profile{display:flex;align-items:center;gap:13px;padding-top:20px;border-top:1px solid var(--border);margin-top:20px}
.tci-av{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;color:#fff;flex-shrink:0}
.tci-name{font-size:14.5px;font-weight:700;color:var(--text)}
.tci-role{font-size:12px;color:var(--text3);margin-top:2px}
.tci-stat{background:linear-gradient(135deg,var(--accent),var(--accent2));border:none;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px}
.tcis-n{font-size:56px;font-weight:800;color:#fff;letter-spacing:-2.5px;line-height:1}
.tcis-l{font-size:14px;color:rgba(255,255,255,.8);text-align:center}
.testi-counter{margin-top:24px;font-size:13px;color:var(--text4);text-align:center;letter-spacing:.02em}
.testi-hint{margin-top:8px;font-size:12px;color:var(--text4);text-align:center;opacity:.6}

/* STATS */
.stats-sec{padding:0 48px 72px}
.stats-inner{max-width:1160px;margin:0 auto}
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:12px;
  border-radius:var(--r-xl);overflow:visible;
}
.stat{
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(20px) saturate(160%);
  -webkit-backdrop-filter:blur(20px) saturate(160%);
  border:1px solid rgba(255,255,255,0.75);
  border-radius:var(--r-xl);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.9),
    inset 0 -1px 0 rgba(0,0,0,0.04),
    0 4px 24px rgba(0,0,0,0.07),
    0 1px 2px rgba(0,0,0,0.04);
  padding:28px 20px;text-align:center;
  transition:box-shadow .2s,transform .2s;
}
.stat:hover{
  transform:translateY(-2px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.95),
    0 8px 32px rgba(0,0,0,0.1),
    0 2px 4px rgba(0,0,0,0.06);
}
[data-theme="dark"] .stat{
  background:rgba(28,28,36,0.92);
  border-color:rgba(255,255,255,0.1);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    inset 0 -1px 0 rgba(0,0,0,0.3),
    0 4px 24px rgba(0,0,0,0.4);
}
.stat-n{font-size:48px;font-weight:800;color:var(--text);letter-spacing:-2px;margin-bottom:6px;line-height:1}
.stat-n .acc{color:var(--accent)}
.stat-l{font-size:13.5px;color:var(--text3)}


/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:60px;align-items:start}
.contact-info h3{font-size:26px;font-weight:800;letter-spacing:-.5px;margin-bottom:12px}
.contact-info p{font-size:15px;color:var(--text3);line-height:1.65;margin-bottom:28px}
.channels{display:flex;flex-direction:column;gap:10px}
.chan{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);text-decoration:none;transition:all .18s}
.chan:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}
.chan-ico{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;background:var(--bg);flex-shrink:0;box-shadow:var(--shadow-sm)}
.chan-name{font-size:14px;font-weight:600;color:var(--text)}
.chan-sub{font-size:12px;color:var(--text3);margin-top:1px}
.form-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-2xl);padding:32px;box-shadow:var(--shadow-sm)}
.form-ttl{font-size:18px;font-weight:700;color:var(--text);margin-bottom:24px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fg{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}
.fl{font-size:13px;font-weight:500;color:var(--text2)}
.fi{padding:11px 14px;border:1.5px solid var(--border);border-radius:var(--r);font-size:14px;color:var(--text);font-family:'Inter',sans-serif;background:#fff;outline:none;transition:all .18s}
.fi:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}
.fi::placeholder{color:var(--text4)}
select.fi{cursor:pointer}
textarea.fi{resize:vertical;min-height:80px}
.form-sub{width:100%;padding:13px;background:var(--accent);color:#fff;border:none;border-radius:100px;font-size:15px;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif;transition:all .2s;margin-top:4px}
.form-sub:hover{background:var(--accent2);transform:translateY(-1px);box-shadow:0 6px 20px rgba(128,0,0,0.28)}
.form-note{font-size:12px;color:var(--text4);text-align:center;margin-top:10px}

/* FOOTER */
footer{padding:40px 24px 56px;position:relative}
.foot-shell{
  max-width:1160px;margin:0 auto;
  background:var(--card);
  border-radius:20px;
  border:1px solid var(--border);
  padding:32px;
  box-shadow:var(--shadow-md);
}
.foot-grid{display:grid;grid-template-columns:1fr 2fr 1fr;gap:28px}
/* brand col */
.foot-brand-mark{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.foot-monogram{width:36px;height:36px;border-radius:10px;background:var(--text);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;letter-spacing:-.5px;flex-shrink:0}
.foot-logo-img{height:42px;width:auto;flex-shrink:0}
.foot-brand-name{font-size:14px;font-weight:600;color:var(--text);line-height:1.2}
.foot-brand-sub{font-size:11px;color:var(--text4);line-height:1.3}
.foot-desc{font-size:12px;color:var(--text3);line-height:1.7;margin-bottom:16px}
.foot-socials{display:flex;gap:8px}
.foot-soc{
  width:34px;height:34px;border-radius:9px;
  background:var(--bg);
  border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  color:var(--text3);
  text-decoration:none;transition:background .18s,color .18s,border-color .18s;
}
.foot-soc:hover{background:var(--text);color:#fff;border-color:var(--text)}
.foot-soc svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
/* nav cols */
.foot-nav-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.foot-col h4{font-size:12px;font-weight:600;color:var(--text);margin-bottom:12px}
.foot-col ul{list-style:none}
.foot-col li{margin-bottom:8px}
.foot-col a{font-size:12.5px;color:var(--text3);text-decoration:none;transition:color .16s}
.foot-col a:hover{color:var(--text)}
/* newsletter col */
.foot-nl h4{font-size:12px;font-weight:600;color:var(--text);margin-bottom:6px}
.foot-nl p{font-size:11.5px;color:var(--text3);line-height:1.6;margin-bottom:14px}
.foot-nl-form{display:flex;gap:6px}
.foot-nl-input{
  flex:1;min-width:0;
  padding:8px 12px;border-radius:9px;
  background:var(--bg);
  border:1px solid var(--border);
  font-size:12.5px;color:var(--text);outline:none;
  font-family:inherit;
}
.foot-nl-input::placeholder{color:var(--text4)}
.foot-nl-input:focus{border-color:var(--border2)}
.foot-nl-btn{
  padding:8px 14px;border-radius:9px;
  background:var(--text);color:#fff;
  font-size:12.5px;font-weight:600;
  border:none;cursor:pointer;
  white-space:nowrap;
  transition:background .18s;
  font-family:inherit;
  display:flex;align-items:center;gap:6px;
}
.foot-nl-btn:hover{background:var(--accent)}
.foot-nl-btn svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
/* bottom bar */
.foot-bar{
  margin-top:24px;
  padding-top:20px;
  border-top:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;gap:16px;
}
.foot-copy{font-size:11.5px;color:var(--text4)}
.foot-bar-links{display:flex;gap:18px}
.foot-bar-links a{font-size:11.5px;color:var(--text4);text-decoration:none;transition:color .16s}
.foot-bar-links a:hover{color:var(--text)}

/* WHO WE WORK WITH */
.niche-band{padding:64px 48px;position:relative}
.niche-inner{max-width:1160px;margin:0 auto}
.niche-eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:28px;justify-content:center}
.niche-eyebrow span{font-size:11px;font-weight:500;color:var(--text4);text-transform:uppercase;letter-spacing:.12em;white-space:nowrap}
.niche-eyebrow-line{height:1px;width:60px;background:var(--border)}
.niche-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.niche-card{display:flex;align-items:center;gap:13px;background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 18px;transition:border-color .2s,box-shadow .2s,transform .2s}
.niche-card:hover{border-color:var(--accent-border);box-shadow:var(--shadow-sm);transform:translateY(-2px)}
.niche-ico{width:40px;height:40px;border-radius:11px;background:var(--accent-bg);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.niche-name{font-size:14px;font-weight:600;color:var(--text);line-height:1.3}

/* SHOWREEL */
.reel-sec{padding:96px 48px;position:relative}
.reel-inner{max-width:1000px;margin:0 auto}
.reel-frame{position:relative;width:100%;aspect-ratio:16/9;border-radius:var(--r-2xl);overflow:hidden;background:linear-gradient(135deg,#0d0d12,#1a1a1c);border:1px solid var(--border);box-shadow:var(--shadow-xl);cursor:pointer}
.reel-frame video{width:100%;height:100%;object-fit:cover;display:block}
.reel-poster{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;background:radial-gradient(circle at 50% 40%,rgba(128,0,0,0.18),transparent 60%),linear-gradient(135deg,#0d0d12,#1a1a1c);transition:opacity .35s}
.reel-poster.hide{opacity:0;pointer-events:none}
.reel-play{width:80px;height:80px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;box-shadow:0 12px 40px rgba(128,0,0,0.5);transition:transform .2s,box-shadow .2s;margin-bottom:20px}
.reel-frame:hover .reel-play{transform:scale(1.08);box-shadow:0 16px 50px rgba(128,0,0,0.6)}
.reel-play svg{width:30px;height:30px;fill:#fff;margin-left:4px}
.reel-ptitle{font-size:22px;font-weight:700;color:#fff;letter-spacing:-.5px;margin-bottom:6px}
.reel-psub{font-size:13.5px;color:rgba(255,255,255,0.55)}
.reel-pulse{position:absolute;width:80px;height:80px;border-radius:50%;border:2px solid var(--accent);top:calc(50% - 50px);left:50%;transform:translate(-50%,-50%);animation:reelpulse 2.2s ease-out infinite;opacity:0;pointer-events:none}
@keyframes reelpulse{0%{transform:translate(-50%,-50%) scale(1);opacity:.6}100%{transform:translate(-50%,-50%) scale(2.2);opacity:0}}

@media(max-width:768px){
  .niche-band{padding:48px 20px}
  .niche-grid{grid-template-columns:1fr 1fr}
  .reel-sec{padding:56px 20px}
  .reel-play{width:62px;height:62px}
  .reel-pulse{width:62px;height:62px;top:calc(50% - 41px)}
  .reel-ptitle{font-size:18px}
}

/* PROCESS */
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;counter-reset:proc}
.proc-step{position:relative;background:var(--card);border:1px solid var(--border);border-radius:var(--r-xl);padding:30px 24px;transition:box-shadow .25s,border-color .25s,transform .25s}
.proc-step:hover{box-shadow:var(--shadow-md);border-color:var(--accent-border);transform:translateY(-3px)}
.proc-num{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:12px;background:var(--accent-bg);color:var(--accent);font-size:17px;font-weight:800;margin-bottom:18px;border:1px solid var(--accent-border)}
.proc-step h3{font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.3px;margin-bottom:8px}
.proc-step p{font-size:13.5px;color:var(--text3);line-height:1.65}
.proc-arrow{position:absolute;top:48px;right:-13px;color:var(--border2);z-index:2}
.proc-step:last-child .proc-arrow{display:none}

/* CASE STUDIES */
.cs-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.cs-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-2xl);overflow:hidden;transition:box-shadow .3s,transform .3s}
.cs-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.cs-head{padding:28px 28px 0;display:flex;align-items:center;gap:14px}
.cs-badge{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:800;color:#fff;flex-shrink:0;letter-spacing:-.5px}
.cs-client{font-size:16px;font-weight:700;color:var(--text)}
.cs-tag{font-size:12px;color:var(--text3);margin-top:2px}
.cs-body{padding:20px 28px 8px}
.cs-row{margin-bottom:14px}
.cs-label{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text4);margin-bottom:4px}
.cs-text{font-size:13.5px;color:var(--text2);line-height:1.6}
.cs-metrics{display:flex;gap:10px;padding:14px 28px 28px;flex-wrap:wrap}
.cs-metric{flex:1;min-width:90px;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px;text-align:center}
.cs-metric-n{font-size:24px;font-weight:800;color:var(--accent);letter-spacing:-1px;line-height:1}
.cs-metric-l{font-size:11px;color:var(--text3);margin-top:5px}

/* PRICING */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
.price-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-2xl);padding:32px 28px;display:flex;flex-direction:column;transition:box-shadow .3s,transform .3s,border-color .3s;position:relative}
.price-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.price-card.featured{border-color:var(--accent);box-shadow:0 12px 40px rgba(128,0,0,0.15)}
.price-flag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;font-size:11px;font-weight:700;padding:5px 16px;border-radius:100px;letter-spacing:.03em;white-space:nowrap}
.price-name{font-size:17px;font-weight:700;color:var(--text);margin-bottom:6px}
.price-desc{font-size:13px;color:var(--text3);line-height:1.5;margin-bottom:20px;min-height:38px}
.price-amt{font-size:38px;font-weight:800;color:var(--text);letter-spacing:-1.5px;line-height:1}
.price-amt span{font-size:14px;font-weight:500;color:var(--text3);letter-spacing:0}
.price-per{font-size:12px;color:var(--text4);margin-top:4px;margin-bottom:22px}
.price-feat{list-style:none;margin-bottom:26px;flex:1}
.price-feat li{font-size:13.5px;color:var(--text2);line-height:1.5;padding:8px 0 8px 26px;position:relative;border-bottom:1px solid var(--border)}
.price-feat li:last-child{border-bottom:none}
.price-feat li::before{content:'✓';position:absolute;left:0;top:8px;color:var(--accent);font-weight:800}
.price-btn{display:block;text-align:center;padding:13px;border-radius:100px;font-size:14.5px;font-weight:600;text-decoration:none;cursor:pointer;transition:all .2s;border:1.5px solid var(--border2);color:var(--text);background:transparent}
.price-btn:hover{border-color:var(--text);background:var(--text);color:#fff}
.price-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.price-btn.primary:hover{background:var(--accent2);border-color:var(--accent2);transform:translateY(-1px);box-shadow:0 6px 20px rgba(128,0,0,0.3)}
.price-note{text-align:center;font-size:13px;color:var(--text3);margin-top:32px}

@media(max-width:768px){
  .proc-grid{grid-template-columns:1fr 1fr}
  .proc-arrow{display:none!important}
  .cs-grid{grid-template-columns:1fr}
}

/* FAQ */
.faq-list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:var(--card)}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 22px;font-size:15.5px;font-weight:600;color:var(--text)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';font-size:22px;font-weight:400;color:var(--accent);transition:transform .2s;line-height:1}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-a{padding:0 22px 20px;font-size:14px;color:var(--text3);line-height:1.7}

/* ============================================================
   LIQUID GLASS — applied to cards & buttons (light + dark)
   Translucent material, background blur, layered light edges,
   specular highlight, interactive depth.
   ============================================================ */
.svc-card, .niche-card, .proc-step, .cs-card, .price-card,
.form-card, .testi-card-item, .chan, .reel-frame, .foot-shell{
  background:rgba(255,255,255,0.92);
  -webkit-backdrop-filter:blur(22px) saturate(180%);
  backdrop-filter:blur(22px) saturate(180%);
  border:1px solid rgba(255,255,255,0.65);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.9),
    inset 0 -1px 0 rgba(0,0,0,0.04),
    0 8px 32px rgba(0,0,0,0.08),
    0 1px 3px rgba(0,0,0,0.04);
  position:relative;
}
/* specular top sheen */
.svc-card::after, .proc-step::after, .cs-card::after, .price-card::after,
.form-card::after, .niche-card::after{
  content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(180deg, rgba(255,255,255,0.5) 0%, rgba(255,255,255,0) 38%);
  opacity:.6;mix-blend-mode:screen;
}
[data-theme="dark"] .svc-card, [data-theme="dark"] .niche-card,
[data-theme="dark"] .proc-step, [data-theme="dark"] .cs-card,
[data-theme="dark"] .price-card, [data-theme="dark"] .form-card,
[data-theme="dark"] .testi-card-item, [data-theme="dark"] .chan,
[data-theme="dark"] .reel-frame, [data-theme="dark"] .foot-shell{
  background:rgba(22,22,28,0.92);
  border:1px solid rgba(255,255,255,0.09);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.10),
    inset 0 -1px 0 rgba(0,0,0,0.35),
    0 8px 32px rgba(0,0,0,0.45),
    0 1px 3px rgba(0,0,0,0.3);
}
[data-theme="dark"] .svc-card::after, [data-theme="dark"] .proc-step::after,
[data-theme="dark"] .cs-card::after, [data-theme="dark"] .price-card::after,
[data-theme="dark"] .form-card::after, [data-theme="dark"] .niche-card::after{
  background:linear-gradient(180deg, rgba(255,255,255,0.14) 0%, rgba(255,255,255,0) 40%);
  opacity:.5;
}
/* keep card inner content above the sheen */
.svc-card > *, .proc-step > *, .cs-card > *, .price-card > *,
.form-card > *, .niche-card > *{position:relative;z-index:1}
/* hover lift */
.svc-card:hover, .proc-step:hover, .cs-card:hover, .price-card:hover, .niche-card:hover{
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.95),
    0 16px 48px rgba(0,0,0,0.12),
    0 2px 6px rgba(0,0,0,0.06);
}
[data-theme="dark"] .svc-card:hover, [data-theme="dark"] .proc-step:hover,
[data-theme="dark"] .cs-card:hover, [data-theme="dark"] .price-card:hover,
[data-theme="dark"] .niche-card:hover{
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.14),
    0 18px 52px rgba(0,0,0,0.6),
    0 0 0 1px rgba(128,0,0,0.25);
}

/* featured pricing card keeps its maroon emphasis over the glass */
.price-card.featured{
  border:1px solid rgba(128,0,0,0.45);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.9),
    0 14px 44px rgba(128,0,0,0.18),
    0 2px 6px rgba(0,0,0,0.06);
}
[data-theme="dark"] .price-card.featured{
  border:1px solid rgba(200,60,90,0.5);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.12),
    0 16px 50px rgba(128,0,0,0.4),
    0 0 0 1px rgba(200,60,90,0.3);
}

/* GLASS BUTTONS — maroon fill with glassy sheen + edge light */
.hero-cta, .nav-cta, .form-sub, .price-btn.primary{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg, var(--accent) 0%, var(--accent2) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.30),
    inset 0 -2px 6px rgba(0,0,0,0.18),
    0 6px 22px rgba(128,0,0,0.38);
}
.hero-cta::before, .nav-cta::before, .form-sub::before, .price-btn.primary::before{
  content:'';position:absolute;left:0;right:0;top:0;height:48%;
  background:linear-gradient(180deg, rgba(255,255,255,0.35), rgba(255,255,255,0));
  pointer-events:none;border-radius:inherit;
}
.hero-cta:hover, .nav-cta:hover, .form-sub:hover, .price-btn.primary:hover{
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.4),
    0 10px 30px rgba(128,0,0,0.5);
}
/* secondary / ghost buttons → translucent glass */
.price-btn:not(.primary), .nav-ghost{
  -webkit-backdrop-filter:blur(14px) saturate(160%);
  backdrop-filter:blur(14px) saturate(160%);
  background:rgba(255,255,255,0.35);
  border:1px solid rgba(255,255,255,0.5);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.7), 0 2px 8px rgba(0,0,0,0.05);
}
[data-theme="dark"] .price-btn:not(.primary), [data-theme="dark"] .nav-ghost{
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.12);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.1), 0 2px 8px rgba(0,0,0,0.3);
  color:var(--text);
}

/* service card thumbnail (covers the mockup when an image is present) */
.svc-thumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:3;display:block}

/* IPAD / DEVICE SCROLL MOCKUP (Services) */
.device-stage{perspective:1300px;max-width:1080px;margin:6px auto 0;padding:0 8px}
.device-frame{
  transform-style:preserve-3d;
  transform:rotateX(24deg) scale(1.04);
  will-change:transform;
  background:#101014;
  border:1px solid rgba(255,255,255,0.08);
  border-radius:40px;
  padding:18px;
  position:relative;
  box-shadow:0 9px 20px #0000004a,0 37px 37px #00000042,0 84px 50px #00000026,0 60px 90px rgba(128,0,0,0.14);
}
.device-cam{position:absolute;top:9px;left:50%;transform:translateX(-50%);width:7px;height:7px;border-radius:50%;background:#2a2a30;box-shadow:inset 0 0 0 1.5px #08080a;z-index:2}
.device-screen{border-radius:26px;overflow:hidden;background:var(--bg);padding:30px 26px}
[data-theme="dark"] .device-frame{background:#08080a;border-color:rgba(255,255,255,0.06)}
[data-theme="dark"] .device-screen{background:#0d0d11}
@media(max-width:768px){
  .device-stage{perspective:800px;padding:0}
  .device-frame{border-radius:26px;padding:10px}
  .device-screen{border-radius:18px;padding:18px 12px}
}

/* FLOATING WIDGETS */
#fab-stack{position:fixed;right:22px;bottom:22px;z-index:900;display:flex;flex-direction:column;gap:14px;align-items:center}
.fab{width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;position:relative;box-shadow:0 10px 30px rgba(0,0,0,0.3);transition:transform .2s,box-shadow .2s;text-decoration:none}
.fab:hover{transform:translateY(-3px) scale(1.06);box-shadow:0 14px 38px rgba(0,0,0,0.38)}
.fab svg{width:30px;height:30px;position:relative;z-index:1}
.fab-wa{background:#25D366}
.fab-ai{background:linear-gradient(135deg,var(--accent),var(--accent2));overflow:hidden}
.fab-ai::before{content:'';position:absolute;inset:0;border-radius:50%;background:linear-gradient(180deg,rgba(255,255,255,.4),transparent 55%)}
.fab-pulse{position:absolute;inset:0;border-radius:50%;animation:fabpulse 2.6s ease-out infinite;pointer-events:none}
@keyframes fabpulse{0%{box-shadow:0 0 0 0 rgba(128,0,0,.5)}100%{box-shadow:0 0 0 18px rgba(128,0,0,0)}}

/* AI CHAT PANEL — iMessage + liquid glass */
#ai-panel{position:fixed;right:22px;bottom:94px;z-index:901;width:372px;max-width:calc(100vw - 32px);height:548px;max-height:calc(100vh - 140px);border-radius:24px;overflow:hidden;display:none;flex-direction:column;
  background:rgba(255,255,255,0.72);-webkit-backdrop-filter:blur(30px) saturate(180%);backdrop-filter:blur(30px) saturate(180%);
  border:1px solid rgba(255,255,255,0.6);box-shadow:0 26px 72px rgba(0,0,0,0.32)}
#ai-panel.open{display:flex;animation:aiIn .28s cubic-bezier(.22,1,.36,1)}
@keyframes aiIn{from{opacity:0;transform:translateY(18px) scale(.96)}to{opacity:1;transform:none}}
[data-theme="dark"] #ai-panel{background:rgba(22,22,28,0.74);border-color:rgba(255,255,255,0.1)}
.ai-head{display:flex;align-items:center;gap:11px;padding:14px 16px;border-bottom:1px solid var(--border);background:rgba(255,255,255,0.45)}
[data-theme="dark"] .ai-head{background:rgba(255,255,255,0.04)}
.ai-ava{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:13px;flex-shrink:0}
.ai-h-name{font-size:14.5px;font-weight:700;color:var(--text)}
.ai-h-status{font-size:11.5px;color:#16A34A;display:flex;align-items:center;gap:5px;margin-top:1px}
.ai-h-status::before{content:'';width:7px;height:7px;border-radius:50%;background:#16A34A}
.ai-close{margin-left:auto;background:none;border:none;cursor:pointer;color:var(--text3);font-size:22px;line-height:1;width:30px;height:30px;border-radius:50%}
.ai-close:hover{background:rgba(0,0,0,.07);color:var(--text)}
.ai-msgs{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px}
.ai-row{display:flex;max-width:84%}
.ai-row.in{align-self:flex-start}
.ai-row.out{align-self:flex-end}
.ai-bub{padding:9px 14px;font-size:14px;line-height:1.45;border-radius:18px;word-wrap:break-word}
.ai-row.in .ai-bub{background:rgba(120,120,128,0.16);color:var(--text);border-bottom-left-radius:5px}
[data-theme="dark"] .ai-row.in .ai-bub{background:rgba(140,140,150,0.22)}
.ai-row.out .ai-bub{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border-bottom-right-radius:5px}
.ai-bub a{color:inherit;font-weight:600;text-decoration:underline}
.ai-typing{display:flex;gap:4px;padding:12px 14px;background:rgba(120,120,128,0.16);border-radius:18px;border-bottom-left-radius:5px;width:fit-content}
[data-theme="dark"] .ai-typing{background:rgba(140,140,150,0.22)}
.ai-typing span{width:7px;height:7px;border-radius:50%;background:var(--text3);animation:aitype 1.2s infinite}
.ai-typing span:nth-child(2){animation-delay:.2s}
.ai-typing span:nth-child(3){animation-delay:.4s}
@keyframes aitype{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-5px);opacity:1}}
.ai-chips{display:flex;flex-wrap:wrap;gap:7px;padding:0 16px 10px}
.ai-chip{font-size:12.5px;padding:7px 13px;border-radius:100px;border:1px solid var(--accent-border);background:var(--accent-bg);color:var(--accent);cursor:pointer;white-space:nowrap;transition:all .15s}
.ai-chip:hover{background:var(--accent);color:#fff}
.ai-input{display:flex;align-items:center;gap:8px;padding:12px 14px;border-top:1px solid var(--border);background:rgba(255,255,255,0.45)}
[data-theme="dark"] .ai-input{background:rgba(255,255,255,0.04)}
.ai-input input{flex:1;border:1px solid var(--border);border-radius:100px;padding:10px 16px;font-size:14px;font-family:inherit;background:var(--card);color:var(--text);outline:none}
.ai-input input:focus{border-color:var(--accent)}
.ai-send{width:38px;height:38px;border-radius:50%;border:none;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ai-send svg{width:18px;height:18px}
.nav-phone{display:inline-flex;align-items:center;gap:7px}
.nav-phone svg{width:15px;height:15px}
@media(max-width:480px){
  #ai-panel{right:10px;left:10px;width:auto;bottom:88px;height:72vh}
  #fab-stack{right:16px;bottom:16px}
  .fab{width:52px;height:52px}
  .fab svg{width:27px;height:27px}
}

/* MODALS */
#loginPage{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(12px);z-index:1000;align-items:center;justify-content:center}
.login-card{background:var(--card);border-radius:var(--r-2xl);box-shadow:var(--shadow-xl);padding:40px;width:380px;max-width:92vw}
.login-logo{margin-bottom:22px}
.login-logo img{height:32px}
.login-ttl{font-size:22px;font-weight:700;color:var(--text);margin-bottom:4px}
.login-sub{font-size:14px;color:var(--text3);margin-bottom:24px}
.lerr{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;font-size:13px;padding:10px 13px;border-radius:var(--r);margin-bottom:14px;display:none}
#adminPage{display:none;position:fixed;inset:0;background:#fff;z-index:999;flex-direction:column}
.admin-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 22px;background:var(--text)}
.admin-bar span{color:rgba(255,255,255,.6);font-size:13px}
.admin-close{background:rgba(255,255,255,.1);border:none;cursor:pointer;color:#fff;font-size:13px;font-weight:600;padding:6px 14px;border-radius:8px;transition:background .18s}
.admin-close:hover{background:rgba(255,255,255,.2)}
#adminFrame{flex:1;border:none;width:100%}

/* TOAST */
#toasts{position:fixed;bottom:22px;left:22px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{background:var(--text);color:#fff;padding:13px 18px;border-radius:var(--r-lg);font-size:14px;box-shadow:var(--shadow-md);animation:slideUp .3s ease}
@keyframes slideUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}

/* CINEMATIC SECTIONS — hidden until GSAP reveals */
.cin-sec{opacity:0;will-change:transform,opacity,filter}

/* RESPONSIVE */
@media(max-width:1100px){
  .hero-scroll h1{font-size:58px;letter-spacing:-2px}
}
@media(max-width:768px){
  .nav-links{display:none}
  .nav-links.open{
    display:flex;flex-direction:column;
    position:fixed;top:88px;left:14px;right:14px;
    background:var(--card);
    border:1px solid var(--border);
    border-radius:18px;
    padding:10px;gap:2px;z-index:199;
    box-shadow:0 18px 44px rgba(0,0,0,0.28);
    -webkit-backdrop-filter:blur(20px) saturate(160%);backdrop-filter:blur(20px) saturate(160%);
    overflow-y:auto;max-height:calc(100dvh - 108px);
  }
  .nav-links.open a{padding:13px 16px;border-radius:12px;font-size:15px;width:100%;display:flex;align-items:center;gap:12px;white-space:nowrap;box-sizing:border-box}
  .nav-links.open a .nav-ico{display:block}
  .nav-links.open a.active,.nav-links.open a:hover{background:var(--accent-bg)}
  /* dropdown inside mobile menu */
  .nav-drop{position:static;width:100%;flex-direction:column}
  .nav-drop-btn{width:100%;padding:13px 16px;border-radius:12px;font-size:15px;justify-content:flex-start;gap:12px}
  .nav-drop-btn .nav-ico{display:block}
  /* mobile dropdown: inline max-height slide, no clip-path */
  .nav-drop-menu{
    position:static;transform:none!important;clip-path:none!important;
    visibility:visible;opacity:1;pointer-events:none;
    max-height:0;overflow:hidden;
    box-shadow:none;border:none;
    background:rgba(0,0,0,.04);backdrop-filter:none;-webkit-backdrop-filter:none;
    padding:0;margin-top:0;min-width:unset;
    transition:max-height .32s cubic-bezier(.16,1,.3,1);
  }
  [data-theme="dark"] .nav-drop-menu{background:rgba(255,255,255,.03)}
  .nav-drop:hover .nav-drop-menu{max-height:0;pointer-events:none}
  .nav-drop.open .nav-drop-menu{max-height:400px;pointer-events:auto;border:1px solid var(--border);padding:6px;margin-top:4px}
  .nav-lamp{display:none}
  .ham-btn{display:block;margin-left:6px;flex-shrink:0}
  nav{padding:0 12px 0 16px;gap:10px}
  .hero-scroll{padding:100px 20px 50px;min-height:auto}
  .hero-scroll h1{font-size:38px;letter-spacing:-1.5px}
  .trusted-band{padding:20px 0;margin:10px 16px;border-radius:20px}
  .trusted-band::after{border-radius:20px 20px 0 0}
  .trusted-head{margin-bottom:12px}
  .sec{padding:60px 24px}
  .svc-grid{grid-template-columns:1fr}
  .svc-band{padding:56px 20px}
  .svc-band-hd h2{font-size:28px}
  .port-grid{grid-template-columns:1fr 1fr}
  .port-lb-arr{display:none}
  .testi-stack{width:92vw;max-width:360px}
  .stats-grid{grid-template-columns:1fr 1fr}
  .price-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .foot-nav-grid{grid-template-columns:repeat(2,1fr)}
  .foot-bar{flex-direction:column;gap:10px;text-align:center}
  .frow{grid-template-columns:1fr}
  footer{padding:24px 16px 40px}
  .sec-hd h2{font-size:30px;letter-spacing:-1px}
  .stats-sec{padding:0 24px 60px}
  /* perf: lighter glass blur on phones */
  .svc-card,.niche-card,.proc-step,.cs-card,.price-card,.form-card,
  .testi-card-item,.chan,.reel-frame,.foot-shell{
    -webkit-backdrop-filter:blur(14px) saturate(160%);backdrop-filter:blur(14px) saturate(160%);
  }
  .hero-sub{font-size:15px}
  .sec-hd{margin-bottom:36px}
  .reel-sec{padding:48px 16px}
  .niche-band{padding:40px 16px}
  /* comfortable tap targets */
  .nav-cta,.hero-cta,.form-sub,.price-btn{min-height:46px}
  .nav-links a{padding:12px 14px}
  /* declutter nav on mobile: hide Email, collapse phone to icon */
  .nav-ghost{display:none}
  .nav-phone-num{display:none}
  .nav-cta.nav-phone{width:34px;height:34px;min-height:unset;padding:0;border-radius:9px;background:var(--bg);border:1px solid var(--border);color:var(--text3);justify-content:center}
  .nav-cta.nav-phone svg{width:15px;height:15px}
  .nav-cta.nav-phone:hover{background:var(--border2);transform:none}
}
@media(max-width:480px){
  nav{padding:0 14px;height:58px}
  .nav-logo img{height:40px}
  .nav-brand{display:none}
  .hero-scroll{padding:48px 16px 40px}
  .hero-scroll h1{font-size:30px;letter-spacing:-1px}
  .hero-sub{font-size:14.5px}
  .hero-trust{flex-direction:column;gap:8px}
  .trust-txt{font-size:12px}
  .sec{padding:46px 16px}
  .sec-hd h2{font-size:24px;letter-spacing:-.6px}
  .pill-lbl{font-size:11.5px}
  .port-grid{grid-template-columns:1fr;gap:12px}
  .niche-grid{grid-template-columns:1fr}
  .proc-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr;gap:8px}
  .stat{padding:22px 14px}
  .stat-n{font-size:36px}
  .cs-metric{min-width:calc(50% - 5px)}
  .foot-nav-grid{grid-template-columns:1fr 1fr}
  .price-card{padding:26px 22px}
}

/* MAROON TOP-CENTER GLOW (trainly-style) — dark mode only */
#bg-glow{
  position:fixed;
  top:0; left:0; right:0;
  height:95vh;
  z-index:0;
  pointer-events:none;
  transition:opacity .3s;
  /* LIGHT MODE: soft maroon haze over the white background */
  background:
    radial-gradient(ellipse 60% 55% at 50% -8%, rgba(150,20,50,0.22), transparent 62%),
    radial-gradient(ellipse 34% 40% at 50% -2%, rgba(190,40,75,0.16), transparent 56%),
    radial-gradient(ellipse 95% 65% at 50% -12%, rgba(128,0,0,0.13), transparent 72%);
  mix-blend-mode:multiply;
}
/* DARK MODE: bright crimson→maroon glow over near-black */
[data-theme="dark"] #bg-glow{
  background:
    radial-gradient(ellipse 60% 55% at 50% -8%, rgba(214,72,104,0.40), transparent 62%),
    radial-gradient(ellipse 34% 40% at 50% -2%, rgba(235,96,128,0.30), transparent 56%),
    radial-gradient(ellipse 90% 65% at 50% -12%, rgba(128,0,0,0.30), transparent 70%);
  mix-blend-mode:screen;
}

/* INTERACTIVE GRID BACKGROUND */
#grid-bg {
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  overflow:hidden;
}
#grid-base, #grid-highlight {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
}
#grid-base { opacity:0.35; }
#grid-highlight {
  opacity:1;
  -webkit-mask-image: radial-gradient(circle 0px at -9999px -9999px, black 0%, transparent 100%);
  mask-image: radial-gradient(circle 0px at -9999px -9999px, black 0%, transparent 100%);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
}
body > *:not(#grid-bg):not(#bg-glow):not(#fab-stack):not(#ai-panel):not(#toasts):not(#loginPage):not(#adminPage):not(#navbar):not(#nav-backdrop):not(#indCart) { position:relative; z-index:1; }

/* ============ SHARED PAGE STYLES (About / Blog) ============ */
.page-hero{padding:120px 48px 36px;text-align:center;position:relative}
.page-hero .pill-lbl{margin-bottom:16px}
.page-hero h1{font-size:54px;font-weight:800;letter-spacing:-2px;color:var(--text);line-height:1.08;margin-bottom:16px}
.page-hero p{font-size:17px;color:var(--text3);max-width:640px;margin:0 auto;line-height:1.6}
/* === Animated service-page hero: floating icon tiles + shimmer keyword === */
.page-hero.ph-animated{overflow:hidden}
.page-hero.ph-animated > .pill-lbl,
.page-hero.ph-animated > h1,
.page-hero.ph-animated > p,
.page-hero.ph-animated > div:not(.ph-icons){position:relative;z-index:3}
.ph-icons{position:absolute;inset:0;z-index:1;pointer-events:none}
.ph-ico{position:absolute;left:var(--x);top:var(--y);width:58px;height:58px;border-radius:17px;
  display:flex;align-items:center;justify-content:center;font-size:27px;line-height:1;
  background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow-md);
  transform:translate(-50%,-50%) scale(.4);opacity:0;
  animation:phIn .7s cubic-bezier(.22,1,.36,1) forwards, phFloat var(--d,7s) ease-in-out infinite;
  animation-delay:var(--delay,0s), calc(var(--delay,0s) + .7s)}
[data-theme="dark"] .ph-ico{background:rgba(28,28,34,0.9);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
@keyframes phIn{to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
@keyframes phFloat{
  0%{transform:translate(-50%,-50%) translateY(0) rotate(0)}
  25%{transform:translate(-50%,-50%) translateY(-9px) rotate(5deg)}
  50%{transform:translate(-50%,-50%) translateY(0) rotate(0)}
  75%{transform:translate(-50%,-50%) translateY(9px) rotate(-5deg)}
  100%{transform:translate(-50%,-50%) translateY(0) rotate(0)}
}
.ph-grad{
  -webkit-background-clip:text;background-clip:text;color:transparent;
  background-image:linear-gradient(90deg,#800000,#e0566e,#A52040,#800000);
  background-size:220% auto;animation:phShimmer 3.4s linear infinite}
@keyframes phShimmer{to{background-position:220% center}}
@media(prefers-reduced-motion:reduce){ .ph-ico{animation:phIn .5s forwards} .ph-grad{animation:none} }
@media(max-width:768px){
  .ph-ico{width:44px;height:44px;font-size:21px;border-radius:13px;opacity:.85}
}
@media(max-width:480px){
  .ph-ico.ph-hide-sm{display:none}
}
/* free-floating 3D image objects (no glass tile) */
.page-hero.ph-animated{min-height:580px;padding-top:172px;padding-bottom:150px}
.ph-ico.ph-img{display:block;width:160px;height:160px;background:none;border:none;box-shadow:none;border-radius:0;
  object-fit:contain;padding:0;filter:drop-shadow(0 22px 30px rgba(0,0,0,.34))}
[data-theme="dark"] .ph-ico.ph-img{background:none;backdrop-filter:none;-webkit-backdrop-filter:none;
  filter:drop-shadow(0 22px 34px rgba(0,0,0,.55))}
@media(max-width:1100px){ .ph-ico.ph-img{width:124px;height:124px} }
@media(max-width:768px){
  .page-hero.ph-animated{min-height:auto;padding-top:92px;padding-bottom:28px}
  .ph-ico.ph-img{width:84px;height:84px;opacity:1}
}
@media(max-width:480px){ .ph-ico.ph-img{width:68px;height:68px} .ph-ico.ph-img.ph-hide-sm{display:none} }
.prose{max-width:760px;margin:0 auto}
/* === Individual services à-la-carte grid === */
.ind-wrap{max-width:1140px;margin:0 auto;padding:10px 24px 24px}
.ind-cat{margin-bottom:44px}
.ind-cat-hd{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.ind-cat-ico{font-size:26px;line-height:1}
.ind-cat-hd h2{font-size:clamp(20px,3vw,28px);font-weight:800;letter-spacing:-0.6px;color:var(--text);margin:0}
.ind-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.ind-card{display:flex;flex-direction:column;gap:8px;border:1px solid var(--border);border-radius:16px;padding:22px 22px 18px;background:var(--card);box-shadow:var(--shadow-sm);transition:border-color .25s,box-shadow .25s,transform .25s}
.ind-card:hover{border-color:var(--accent-border);box-shadow:var(--shadow-md);transform:translateY(-3px)}
.ind-card h3{font-size:16px;font-weight:700;color:var(--text);margin:0}
.ind-card p{font-size:13px;color:var(--text3);line-height:1.55;margin:0;flex:1}
.ind-req{display:inline-flex;align-items:center;gap:6px;align-self:flex-start;margin-top:4px;font-size:13px;font-weight:700;color:var(--accent);text-decoration:none;cursor:pointer}
.ind-req svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-linecap:round;stroke-linejoin:round;transition:transform .2s}
.ind-card:hover .ind-req svg{transform:translateX(3px)}
@media(max-width:900px){ .ind-grid{grid-template-columns:repeat(2,1fr)} }
@media(max-width:560px){ .ind-grid{grid-template-columns:1fr} .ind-wrap{padding:6px 18px 16px} }
/* jump chips */
.ind-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;max-width:920px;margin:0 auto 26px;padding:0 18px}
.ind-chip{font-size:13px;font-weight:600;color:var(--text2);background:var(--card);border:1px solid var(--border);padding:7px 14px;border-radius:100px;cursor:pointer;text-decoration:none;transition:border-color .2s,color .2s}
.ind-chip:hover{border-color:var(--accent-border);color:var(--accent)}
/* accordion */
.ind-acc{max-width:1040px;margin:0 auto 14px;border:1px solid var(--border);border-radius:18px;background:var(--card);overflow:hidden}
.ind-acc-hd{width:100%;display:flex;align-items:center;gap:14px;padding:20px 24px;background:none;border:none;cursor:pointer;text-align:left;font-family:inherit}
.ind-acc-ico{font-size:25px;line-height:1}
img.ind-acc-ico{width:36px;height:36px;object-fit:contain;filter:drop-shadow(0 6px 11px rgba(0,0,0,.34))}
.ind-acc-title{font-size:19px;font-weight:800;color:var(--text);letter-spacing:-.4px}
.ind-acc-count{font-size:12.5px;color:var(--text3)}
.ind-acc-arrow{margin-left:auto;width:18px;height:18px;stroke:var(--text3);fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;transition:transform .3s;flex-shrink:0}
.ind-acc.open .ind-acc-arrow{transform:rotate(180deg)}
.ind-acc-panel{max-height:0;overflow:hidden;transition:max-height .42s cubic-bezier(.16,1,.3,1)}
.ind-acc-panel .ind-grid{padding:2px 22px 24px}
/* selectable cards */
.ind-card{position:relative;cursor:pointer;user-select:none;padding-right:46px}
.ind-chk{position:absolute;top:18px;right:18px;width:22px;height:22px;border-radius:50%;border:2px solid var(--border2);transition:background .2s,border-color .2s;display:flex;align-items:center;justify-content:center}
.ind-chk svg{width:12px;height:12px;stroke:#fff;fill:none;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;opacity:0;transition:opacity .2s}
.ind-card.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-border)}
.ind-card.selected .ind-chk{background:var(--accent);border-color:var(--accent)}
.ind-card.selected .ind-chk svg{opacity:1}
/* bundle card */
.ind-bundle{border-color:var(--accent-border);background:linear-gradient(150deg, var(--accent-bg), var(--card) 70%)}
.ind-tag{display:inline-block;align-self:flex-start;font-size:10.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:var(--accent);padding:3px 9px;border-radius:100px;margin-bottom:2px}
/* build-your-order cart bar */
.ind-cart{position:fixed;left:50%;bottom:22px;transform:translateX(-50%) translateY(160%);z-index:140;display:flex;align-items:center;gap:14px;
  background:var(--text);color:#fff;border-radius:100px;padding:10px 12px 10px 22px;box-shadow:0 18px 44px rgba(0,0,0,.4);transition:transform .4s cubic-bezier(.16,1,.3,1)}
.ind-cart.show{transform:translateX(-50%) translateY(0)}
.ind-cart-label{font-size:14px;font-weight:600;white-space:nowrap}
.ind-cart-n{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;border-radius:100px;background:var(--accent);color:#fff;font-weight:800;font-size:12.5px;margin-right:4px}
.ind-cart-send{display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:700;color:var(--text);background:#fff;border:none;border-radius:100px;padding:9px 18px;cursor:pointer}
.ind-cart-send svg{width:15px;height:15px;fill:#25D366}
.ind-cart-clear{background:none;border:none;color:rgba(255,255,255,.6);font-size:13px;cursor:pointer;font-family:inherit;padding:4px 6px}
.ind-cart-clear:hover{color:#fff}
[data-theme="dark"] .ind-cart{background:#1f1f24;border:1px solid var(--border2)}
@media(max-width:560px){
  .ind-acc-hd{padding:16px 16px}.ind-acc-title{font-size:17px}
  .ind-cart{left:14px;right:14px;transform:translateY(160%);bottom:14px;justify-content:space-between;padding:10px 10px 10px 18px}
  .ind-cart.show{transform:translateY(0)}
}
/* === Mindmap (radial) inside an open accordion === */
.ind-mind{position:relative;width:100%;height:720px;margin:0 auto}
.mind-lines{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;overflow:visible}
.mind-lines path{stroke:var(--border2);stroke-width:1.5;fill:none;opacity:.45;stroke-dasharray:1;stroke-dashoffset:1;transition:stroke-dashoffset .6s ease}
.ind-acc.open .mind-lines path{stroke-dashoffset:0}
.mind-hub{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:6px;width:150px;text-align:center;pointer-events:none}
.mind-hub img{width:112px;height:112px;object-fit:contain;filter:drop-shadow(0 14px 24px rgba(0,0,0,.44))}
.mind-hub span{font-size:14px;font-weight:800;color:var(--text);letter-spacing:-.3px}
.mind-node{position:absolute;transform:translate(-50%,-50%) scale(.2);transform-origin:center;z-index:4;display:flex;flex-direction:column;align-items:center;gap:8px;width:140px;background:none;border:none;cursor:pointer;font-family:inherit;
  opacity:0;transition:opacity .45s ease,transform .55s cubic-bezier(.34,1.4,.5,1)}
.ind-acc.open .mind-node{opacity:1;transform:translate(-50%,-50%) scale(1)}
.mind-ava{width:90px;height:90px;border-radius:50%;display:grid;place-items:center;background:radial-gradient(circle at 50% 28%, color-mix(in srgb,var(--accent) 14%, var(--card)), var(--card));border:1px solid var(--border);box-shadow:0 8px 18px rgba(0,0,0,.22);transition:transform .25s,box-shadow .25s,border-color .25s}
.mind-ava img{width:64px;height:64px;object-fit:contain}
.mind-node:hover .mind-ava,.mind-node.open .mind-ava{transform:scale(1.09);border-color:var(--accent);box-shadow:0 12px 28px rgba(128,0,0,.3)}
.mind-name{font-size:13px;font-weight:600;color:var(--text2);line-height:1.2;max-width:140px}
.mind-node.selected .mind-ava{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-border),0 8px 18px rgba(0,0,0,.22)}
.mind-node.selected .mind-name{color:var(--accent);font-weight:700}
.mind-node.is-bundle .mind-ava{border-color:var(--accent);background:var(--accent-bg)}
.mind-node.is-bundle .mind-tag{font-size:9px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}
/* detail popover */
.mind-detail{position:absolute;left:50%;top:80px;transform:translateX(-50%);width:212px;z-index:30;background:var(--card);border:1px solid var(--border);border-radius:14px;box-shadow:0 18px 44px rgba(0,0,0,.32);padding:14px 14px 13px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .2s}
.mind-node:hover .mind-detail,.mind-node.open .mind-detail{opacity:1;visibility:visible;pointer-events:auto}
.mind-detail h4{font-size:13.5px;font-weight:700;color:var(--text);margin:0 0 5px}
.mind-detail p{font-size:12px;color:var(--text3);line-height:1.5;margin:0 0 10px}
.mind-add{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;color:#fff;background:var(--accent);border:none;border-radius:100px;padding:7px 14px;cursor:pointer;font-family:inherit}
.mind-node.selected .mind-add{background:var(--green)}
@media(max-width:760px){
  .ind-mind{height:auto;display:flex;flex-wrap:wrap;justify-content:center;align-items:flex-start;gap:16px 10px;padding:10px 6px 6px}
  .mind-lines{display:none}
  .mind-hub{position:static;transform:none;flex-direction:row;gap:10px;width:100%;justify-content:center;margin-bottom:10px}
  .mind-hub img{width:46px;height:46px}
  .mind-node{position:static!important;transform:none!important;opacity:1!important;width:88px}
  .mind-detail{position:fixed;left:14px;right:14px;bottom:14px;top:auto;width:auto;transform:none}
}
.prose h2{font-size:28px;font-weight:700;letter-spacing:-0.8px;color:var(--text);margin:38px 0 14px}
.prose h3{font-size:20px;font-weight:700;color:var(--text);margin:26px 0 10px}
.prose p{font-size:16px;line-height:1.75;color:var(--text2);margin-bottom:16px}
.prose ul{margin:0 0 18px;padding-left:20px}
.prose li{font-size:16px;line-height:1.7;color:var(--text2);margin-bottom:8px}
.prose a{color:var(--accent);font-weight:600}
.about-founder{display:grid;grid-template-columns:210px 1fr;gap:34px;align-items:start;max-width:880px;margin:0 auto}
.about-photo{width:210px;height:250px;border-radius:var(--r-2xl);object-fit:cover;background:linear-gradient(135deg,#1a1a1c,#800000);display:flex;align-items:center;justify-content:center;color:#fff;font-size:54px;font-weight:800;flex-shrink:0}
.about-vals{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1000px;margin:32px auto 0}
.about-val{background:rgba(255,255,255,0.92);border:1px solid var(--border);border-radius:var(--r-xl);padding:24px;box-shadow:var(--shadow-md)}
[data-theme="dark"] .about-val{background:rgba(22,22,28,0.92);border-color:rgba(255,255,255,0.09)}
.about-val .ico{font-size:26px;margin-bottom:10px}
.about-val h3{font-size:16px;font-weight:700;color:var(--text);margin-bottom:6px}
.about-val p{font-size:13.5px;color:var(--text3);line-height:1.6;margin:0}
.cred-list{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:18px}
.cred{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--text2);background:var(--card);border:1px solid var(--border);padding:8px 15px;border-radius:100px}
@media(max-width:768px){
  .page-hero{padding:92px 20px 28px}
  .page-hero h1{font-size:35px;letter-spacing:-1px}
  .about-founder{grid-template-columns:1fr;text-align:center;gap:22px}
  .about-photo{margin:0 auto}
  .about-vals{grid-template-columns:1fr}
}

/* ============ BLOG ============ */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1160px;margin:0 auto}
.blog-card{display:flex;flex-direction:column;background:rgba(255,255,255,0.92);border:1px solid var(--border);border-radius:var(--r-2xl);overflow:hidden;text-decoration:none;transition:transform .25s,box-shadow .25s;box-shadow:var(--shadow-md)}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
[data-theme="dark"] .blog-card{background:rgba(22,22,28,0.92);border-color:rgba(255,255,255,0.09)}
.blog-thumb{height:172px;background-size:cover;background-position:center;display:flex;align-items:flex-end;padding:14px}
.blog-tag{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#fff;background:rgba(128,0,0,0.85);padding:5px 12px;border-radius:100px}
.blog-body{padding:20px 22px 24px;display:flex;flex-direction:column;flex:1}
.blog-title{font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.3px;line-height:1.3;margin-bottom:8px}
.blog-excerpt{font-size:13.5px;color:var(--text3);line-height:1.6;flex:1}
.blog-meta{display:flex;gap:12px;font-size:12px;color:var(--text4);margin-top:14px}
.article-hero{max-width:760px;margin:0 auto;padding:110px 24px 0;text-align:center}
.article-hero .blog-tag{display:inline-block;background:var(--accent-bg);color:var(--accent);margin-bottom:16px}
.article-hero h1{font-size:42px;font-weight:800;letter-spacing:-1.5px;line-height:1.14;color:var(--text);margin-bottom:18px}
.article-meta{display:flex;align-items:center;justify-content:center;gap:10px;font-size:13px;color:var(--text3)}
.article-meta .av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#1a1a1c,#800000);color:#fff;font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center}
.article-meta a{color:var(--accent);font-weight:600;text-decoration:none}
.article-body{max-width:740px;margin:8px auto 0;padding:0 24px}
.key-takeaway{background:var(--accent-bg);border-left:3px solid var(--accent);border-radius:0 12px 12px 0;padding:16px 20px;margin:0 0 28px;font-size:15px;color:var(--text2);line-height:1.65}
.article-body table{width:100%;border-collapse:collapse;margin:20px 0;font-size:14.5px}
.article-body th,.article-body td{border:1px solid var(--border);padding:11px 14px;text-align:left}
.article-body th{background:var(--accent-bg);color:var(--text);font-weight:700}
.article-cta{max-width:740px;margin:40px auto;padding:30px;border-radius:var(--r-2xl);text-align:center;background:rgba(255,255,255,0.92);border:1px solid var(--border)}
[data-theme="dark"] .article-cta{background:rgba(22,22,28,0.92);border-color:rgba(255,255,255,0.09)}
.article-cta h3{font-size:22px;font-weight:800;color:var(--text);margin-bottom:8px}
.article-cta p{font-size:14.5px;color:var(--text3);margin-bottom:18px}
@media(max-width:768px){.blog-grid{grid-template-columns:1fr}.article-hero{padding:92px 18px 0}.article-hero h1{font-size:30px;letter-spacing:-1px}}

/* ============ FLUID CIRCULAR MENU (mobile only) ============ */
.fluid-menu{display:none}
#nav-backdrop{
  display:none;position:fixed;inset:0;z-index:190;
  background:rgba(0,0,0,0.42);
  -webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);
  opacity:0;transition:opacity .3s ease;
}
@media(max-width:768px){
  .ham-btn{display:none!important}
  .nav-links{display:none}
  #nav-backdrop.open{display:block;opacity:1}
  .fluid-menu{display:block;position:relative;width:46px;height:46px;margin-left:8px;flex-shrink:0;z-index:210}
  .fm-item{
    position:absolute;top:0;left:0;width:46px;height:46px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    background:var(--card);border:1px solid var(--border);color:var(--text);
    box-shadow:0 8px 22px rgba(0,0,0,0.22);text-decoration:none;cursor:pointer;
    opacity:0;pointer-events:none;transform:translateY(0);
    transition:transform .44s cubic-bezier(.34,1.4,.5,1),opacity .3s,background .2s,color .2s;
    backface-visibility:hidden;-webkit-font-smoothing:antialiased;
  }
  .fm-item svg{display:block!important;width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
  /* liquid-glass name pill — sits to the LEFT of each icon, expands alongside it */
  .fm-label{
    position:absolute;right:calc(100% + 12px);top:50%;
    transform:translateY(-50%) translateX(14px) scale(.9);
    transform-origin:right center;
    white-space:nowrap;font-size:14px;font-weight:600;color:var(--text);
    padding:10px 17px;border-radius:100px;
    background:rgba(255,255,255,0.55);
    -webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);
    border:1px solid rgba(255,255,255,0.6);
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.85), 0 8px 22px rgba(0,0,0,0.16);
    opacity:0;pointer-events:none;
    transition:opacity .28s ease,transform .44s cubic-bezier(.34,1.4,.5,1);
  }
  [data-theme="dark"] .fm-label{
    background:rgba(26,26,32,0.6);
    border-color:rgba(255,255,255,0.12);
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.1), 0 8px 22px rgba(0,0,0,0.5);
  }
  .fm-active .fm-label{color:var(--accent)}
  .fm-active{color:var(--accent);border-color:var(--accent-border);background:var(--accent-bg)}
  .fm-trigger{opacity:1;pointer-events:auto;z-index:50;border:none;
    background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;
    box-shadow:0 8px 22px rgba(128,0,0,0.4)}
  .fluid-menu.open .fm-item:not(.fm-trigger){opacity:1;pointer-events:auto}
  .fluid-menu.open .fm-item{transform:translateY(calc(var(--i) * 56px))}
  .fluid-menu.open .fm-item .fm-label{
    opacity:1;transform:translateY(-50%) translateX(0) scale(1);
    transition-delay:calc(var(--i) * 0.035s);
  }
  .fluid-menu .fm-item:not(.fm-trigger):active{background:var(--accent);color:#fff;border-color:var(--accent)}
  /* trigger icon morph (hamburger <-> X) */
  .fm-ico{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;transition:opacity .3s,transform .3s}
  .fm-ico-x{opacity:0;transform:rotate(-180deg) scale(.4)}
  .fluid-menu.open .fm-ico-menu{opacity:0;transform:rotate(180deg) scale(.4)}
  .fluid-menu.open .fm-ico-x{opacity:1;transform:rotate(0) scale(1)}
}

/* ============ CLIENTS / SPARKLES SECTION ============ */
.clients-sec{position:relative;overflow:hidden;padding:66px 24px 0;text-align:center}
.clients-head{font-size:clamp(26px,4.2vw,40px);font-weight:700;letter-spacing:-1.2px;line-height:1.18;color:var(--text)}
.clients-head .ch-accent{color:var(--accent)}
.clients-slider{margin:28px auto 0;max-width:1000px}
.clients-glow{position:relative;height:340px;margin-top:-26px;overflow:hidden;
  -webkit-mask-image:radial-gradient(60% 62% at 50% 50%, #000 60%, transparent);
  mask-image:radial-gradient(60% 62% at 50% 50%, #000 60%, transparent)}
.clients-glow::before{content:'';position:absolute;inset:0;z-index:0;opacity:.6;
  background:radial-gradient(circle at 50% 100%, rgba(128,0,0,0.55), transparent 70%)}
[data-theme="dark"] .clients-glow::before{background:radial-gradient(circle at 50% 100%, rgba(214,72,104,0.5), transparent 70%);opacity:.7}
#sparkleCanvas{position:absolute;inset:0;width:100%;height:100%;z-index:1;
  -webkit-mask-image:radial-gradient(55% 60% at 50% 85%, #000, transparent 88%);
  mask-image:radial-gradient(55% 60% at 50% 85%, #000, transparent 88%)}
.clients-horizon{position:absolute;left:-50%;top:54%;width:200%;aspect-ratio:1 / 0.7;border-radius:100%;
  background:var(--bg);border-top:1px solid rgba(0,0,0,0.16);z-index:2;
  box-shadow:0 -1px 24px rgba(128,0,0,0.25)}
[data-theme="dark"] .clients-horizon{border-top-color:rgba(255,255,255,0.18);box-shadow:0 -1px 30px rgba(214,72,104,0.3)}
@media(max-width:768px){
  .clients-sec{padding:48px 18px 0}
  .clients-glow{height:240px}
}

/* ============ 3D TESTIMONIALS MARQUEE ============ */
.t3d-sec{padding:80px 24px 90px;overflow:hidden}
.t3d-stage{position:relative;height:560px;max-width:1000px;margin:10px auto 0;overflow:hidden;perspective:700px}
.t3d-rotate{display:flex;gap:18px;justify-content:center;height:100%;transform-style:preserve-3d;
  transform:translateX(-30px) rotateX(14deg) rotateY(-10deg) rotateZ(9deg) scale(1.18)}
.t3d-col{flex-shrink:0;height:100%;overflow:hidden}
.t3d-track{display:flex;flex-direction:column;gap:18px;will-change:transform}
.t3d-track.up{animation:t3dScroll 42s linear infinite}
.t3d-track.down{animation:t3dScroll 42s linear infinite reverse}
.t3d-stage:hover .t3d-track{animation-play-state:paused}
@keyframes t3dScroll{from{transform:translateY(0)}to{transform:translateY(-50%)}}
.t3d-card{
  width:248px;border-radius:16px;padding:16px 17px;
  background:rgba(255,255,255,0.85);border:1px solid var(--border);
  box-shadow:0 8px 26px rgba(0,0,0,0.10);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
}
[data-theme="dark"] .t3d-card{background:rgba(26,26,32,0.85);border-color:rgba(255,255,255,0.09);box-shadow:0 8px 26px rgba(0,0,0,0.4)}
.t3d-card-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.t3d-av{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;flex-shrink:0}
.t3d-name{font-size:13.5px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:5px;line-height:1.2}
.t3d-flag{font-size:12px}
.t3d-user{font-size:11.5px;color:var(--text3);margin-top:2px}
.t3d-stars{color:#FBBF24;font-size:12px;letter-spacing:2px;margin-bottom:7px}
.t3d-body{font-size:12.8px;color:var(--text2);line-height:1.55}
/* edge fades */
.t3d-fade{position:absolute;pointer-events:none;z-index:5}
.t3d-fade-t{inset:0 0 auto 0;height:26%;background:linear-gradient(to bottom,var(--bg),transparent)}
.t3d-fade-b{inset:auto 0 0 0;height:26%;background:linear-gradient(to top,var(--bg),transparent)}
.t3d-fade-l{inset:0 auto 0 0;width:18%;background:linear-gradient(to right,var(--bg),transparent)}
.t3d-fade-r{inset:0 0 0 auto;width:18%;background:linear-gradient(to left,var(--bg),transparent)}
@media(max-width:768px){
  .t3d-sec{padding:56px 14px 64px}
  .t3d-stage{height:440px;perspective:520px}
  .t3d-rotate{gap:14px;transform:translateX(-10px) rotateX(12deg) rotateY(-8deg) rotateZ(7deg) scale(1.2)}
  .t3d-card{width:210px;padding:13px 14px}
  .t3d-col-hide{display:none}
}

/* ============ CONTENT CREATION JOURNEY (horizontal film-strip) ============ */
.journey{position:relative}
.journey-pin{height:100vh;overflow:hidden;display:flex;align-items:center;position:relative}
.journey-track{display:flex;height:100%;align-items:center;will-change:transform;position:relative;z-index:2}
.j-panel{flex:0 0 100vw;height:100%;display:flex;align-items:center;justify-content:center;padding:96px 6vw 90px;box-sizing:border-box}
.j-inner{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:center;max-width:1080px;width:100%}
.j-visual{position:relative;border-radius:26px;overflow:hidden;aspect-ratio:3/4;max-height:62vh;margin:0 auto;width:100%;max-width:420px;
  background:linear-gradient(135deg,#1a1a1c,#800000);box-shadow:0 30px 70px rgba(0,0,0,0.35),0 0 0 1px rgba(255,255,255,0.06)}
.j-visual img{width:100%;height:100%;object-fit:cover;display:block}
/* background img gets a smooth filter transition so blur eases in rather than snapping */
.j-visual > img:not(.j-hero){transition:filter 0.5s ease}
.j-ico{font-size:34px;line-height:1;margin-bottom:8px}
.j-num{font-size:12.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.j-title{font-size:clamp(28px,4vw,46px);font-weight:800;letter-spacing:-1.6px;line-height:1.06;color:var(--text);margin:8px 0 14px}
.j-desc{font-size:16px;color:var(--text2);line-height:1.7;margin-bottom:18px}
.j-points{list-style:none;display:flex;flex-direction:column;gap:9px}
.j-points li{font-size:14px;color:var(--text3);padding-left:24px;position:relative;line-height:1.5}
.j-points li::before{content:'✓';position:absolute;left:0;top:0;color:var(--accent);font-weight:800}
/* progress spine */
.j-prog{position:absolute;left:6vw;right:6vw;bottom:34px;z-index:6}
.j-prog-track{height:3px;background:var(--border);border-radius:4px;position:relative;overflow:hidden}
.j-prog-fill{position:absolute;left:0;top:0;height:100%;width:0;border-radius:4px;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width .1s linear}
.j-prog-labels{display:flex;justify-content:space-between;margin-top:11px;gap:6px}
.j-prog-labels span{font-size:11px;font-weight:600;color:var(--text4);transition:color .2s;white-space:nowrap}
.j-prog-labels span.on{color:var(--accent)}
.j-scrollcue{position:absolute;left:50%;bottom:74px;transform:translateX(-50%);font-size:12px;color:var(--text4);letter-spacing:.05em;z-index:6}
/* MOBILE / reduced-motion: stack vertically, no pin */
@media(max-width:900px){
  .journey-pin{height:auto;overflow:visible;display:block}
  .journey-track{display:block;transform:none!important;width:auto!important}
  .j-panel{flex:none;width:100%;height:auto;min-height:auto;padding:34px 20px}
  .j-inner{grid-template-columns:1fr;gap:22px;max-width:540px}
  .j-visual{max-height:none;aspect-ratio:4/5;max-width:360px}
  .j-prog,.j-scrollcue{display:none}
}

/* journey connection rail (glowing thread + travelling token) */
.j-rail{position:relative;height:3px;background:var(--border);border-radius:4px}
.j-rail-fill{position:absolute;left:0;top:0;height:100%;width:0;border-radius:4px;background:linear-gradient(90deg,var(--accent),var(--accent2));box-shadow:0 0 12px rgba(214,72,104,0.6)}
.j-node{position:absolute;top:50%;width:11px;height:11px;border-radius:50%;background:var(--card);border:2px solid var(--border2);transform:translate(-50%,-50%);transition:background .25s,border-color .25s,box-shadow .25s;z-index:2}
.j-node.on{background:var(--accent);border-color:var(--accent);box-shadow:0 0 12px rgba(214,72,104,0.75)}
.j-token{position:absolute;top:50%;left:0;transform:translate(-50%,-50%);width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:20px;
  box-shadow:0 6px 20px rgba(128,0,0,0.5), 0 0 0 5px rgba(214,72,104,0.18);z-index:3;transition:left .08s linear}
/* 3D image icons in journey (service pages) */
img.j-ico{display:block;width:48px;height:48px;object-fit:contain;margin-bottom:10px;filter:drop-shadow(0 10px 16px rgba(0,0,0,.4))}
.j-token.has-img{background:none;box-shadow:none;border-radius:0;width:54px;height:54px}
.j-token.has-img img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 6px 12px rgba(0,0,0,.55))}

/* === CINEMATIC JOURNEY — depth corridor + layered motion (desktop only) === */
@media(min-width:901px){
  .j-panel{perspective:1600px}
  .j-inner{transform-style:preserve-3d;position:relative}
  .j-visual{transform-style:preserve-3d;will-change:transform,filter}
  .j-copy{will-change:transform}
}
/* ambient bloom behind each card (tinted per stage via --jt) */
.j-aura{position:absolute;inset:-16% -10%;z-index:-1;border-radius:48px;pointer-events:none;
  background:radial-gradient(closest-side, var(--jt,#b5202f), transparent 72%);
  filter:blur(48px);opacity:.5;transform:translateZ(-180px);
  animation:jPulse 3.8s ease-in-out infinite}
@keyframes jPulse{0%,100%{opacity:.4;transform:translateZ(-180px) scale(1)}50%{opacity:.62;transform:translateZ(-180px) scale(1.06)}}
/* soft top-light glow inside the frame */
.j-glow{position:absolute;inset:0;pointer-events:none;mix-blend-mode:screen;
  background:radial-gradient(120% 78% at 50% 14%, rgba(255,255,255,.16), transparent 60%);
  animation:jGlow 4.2s ease-in-out infinite}
@keyframes jGlow{0%,100%{opacity:.28}50%{opacity:.52}}
/* colour-grade vignette that deepens as the stage leaves centre (opacity driven by GSAP) */
.j-grade{position:absolute;inset:0;pointer-events:none;opacity:0;
  background:radial-gradient(120% 120% at 50% 50%, transparent 52%, rgba(6,4,8,.66))}
/* single specular sheen sweep (translated by GSAP on entry) */
.j-sheen{position:absolute;top:-10%;left:0;height:120%;width:55%;pointer-events:none;mix-blend-mode:screen;
  transform:translateX(-170%) skewX(-12deg);
  background:linear-gradient(105deg, transparent, rgba(255,255,255,.4), transparent)}
/* orbiting particle motes */
.j-parts{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.j-dot{position:absolute;width:5px;height:5px;border-radius:50%;
  background:var(--jt,#fff);box-shadow:0 0 9px 1px var(--jt);
  animation:jFloat var(--d,8s) ease-in-out infinite}
@keyframes jFloat{0%{transform:translate(0,10px) scale(.8);opacity:0}
  22%{opacity:.75}78%{opacity:.55}100%{transform:translate(7px,-30px) scale(1.05);opacity:0}}
@media(prefers-reduced-motion:reduce){ .j-aura,.j-glow,.j-dot{animation:none} }
/* Layer B — hero: exact-canvas overlay, emerges from same position as object in background photo */
.j-hero{position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center;
  pointer-events:none;z-index:4;transform-origin:center center;
  filter:drop-shadow(0 28px 52px rgba(0,0,0,.72)) drop-shadow(0 0 36px color-mix(in srgb, var(--jt,#b5202f) 62%, transparent));
  will-change:transform,filter}

/* === Service-page journey: icon/gradient stage (no photos) === */
.j-visual.j-iconic{
  background:
    radial-gradient(120% 90% at 50% 12%, rgba(255,255,255,.14), transparent 58%),
    linear-gradient(150deg, color-mix(in srgb, var(--jt,#800000) 22%, var(--card)), var(--card) 58%, color-mix(in srgb, var(--jt,#800000) 40%, #0a0a0c));
}
.j-visual.j-iconic .j-ghost{position:absolute;inset:0;display:grid;place-items:center;
  font-size:230px;line-height:1;opacity:.12;filter:blur(1px);z-index:1;pointer-events:none;user-select:none}
.j-hero.j-glyph{display:grid;place-items:center;background:none;
  font-size:128px;line-height:1;filter:drop-shadow(0 26px 46px rgba(0,0,0,.55))}
.j-hero.j-glyph svg{width:44%;height:44%;stroke:#fff;fill:none;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round}
@media(max-width:900px){
  .j-visual.j-iconic .j-ghost{font-size:150px}
  .j-hero.j-glyph{font-size:96px}
}

/* === Sticky split-scroll process (service pages — alt scroll style) === */
.sticky-flow{position:relative;padding:30px 0 10px}
.sf-grid{display:grid;grid-template-columns:0.92fr 1.08fr;gap:56px;max-width:1160px;margin:0 auto;padding:0 40px;align-items:start}
.sf-sticky{position:sticky;top:118px;align-self:start}
.sf-card{position:relative;border-radius:28px;aspect-ratio:4/5;max-height:74vh;overflow:hidden;display:grid;place-items:center;
  background:
    radial-gradient(120% 90% at 50% 12%, rgba(255,255,255,.14), transparent 58%),
    linear-gradient(150deg, color-mix(in srgb, var(--jt,#800000) 26%, var(--card)), var(--card) 60%, color-mix(in srgb, var(--jt,#800000) 42%, #0a0a0c));
  box-shadow:0 30px 70px rgba(0,0,0,.35),0 0 0 1px rgba(255,255,255,.06)}
.sf-card::after{content:'';position:absolute;inset:0;pointer-events:none;mix-blend-mode:screen;
  background:radial-gradient(120% 78% at 50% 14%, rgba(255,255,255,.14), transparent 60%)}
.sf-ghost{position:absolute;inset:0;display:grid;place-items:center;font-size:240px;line-height:1;opacity:.10;filter:blur(1px);z-index:1}
.sf-glyph{position:relative;z-index:2;font-size:128px;line-height:1;filter:drop-shadow(0 22px 42px rgba(0,0,0,.5))}
.sf-meta{position:absolute;left:26px;right:26px;bottom:24px;z-index:3;display:flex;align-items:center;justify-content:space-between}
.sf-count{font-size:13px;font-weight:700;letter-spacing:.14em;color:#fff;opacity:.9}
.sf-dots{display:flex;gap:7px}
.sf-dots span{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.32);transition:all .35s cubic-bezier(.16,1,.3,1)}
.sf-dots span.on{background:#fff;width:24px;border-radius:5px}
.sf-steps{display:flex;flex-direction:column;gap:20px;padding:6vh 0 18vh}
.sf-item{border:1px solid var(--border);border-radius:20px;padding:30px 30px;background:var(--card);
  transition:border-color .35s,box-shadow .35s,transform .35s,opacity .35s;opacity:.45}
.sf-item.on{opacity:1;border-color:var(--accent-border);box-shadow:0 18px 50px rgba(0,0,0,.18);transform:translateY(-2px)}
.sf-ic{font-size:30px;line-height:1;margin-bottom:10px;display:none}
.sf-num{font-size:12.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.sf-item h2{font-size:clamp(22px,2.6vw,31px);font-weight:800;letter-spacing:-.9px;line-height:1.1;color:var(--text);margin:7px 0 11px}
.sf-item p{font-size:15px;color:var(--text2);line-height:1.62;margin-bottom:15px}
.sf-item ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.sf-item li{font-size:13.5px;color:var(--text3);padding-left:22px;position:relative;line-height:1.5}
.sf-item li::before{content:'✓';position:absolute;left:0;top:0;color:var(--accent);font-weight:800}
@media(max-width:900px){
  .sf-grid{grid-template-columns:1fr;gap:0;padding:0 20px}
  .sf-sticky{display:none}
  .sf-steps{padding:8px 0 0;gap:16px}
  .sf-item{padding:24px 20px;opacity:1}
  .sf-ic{display:block}
}

/* === Vertical timeline (service pages — alt scroll style 3) === */
.timeline{position:relative;padding:46px 0 24px}
.tl-inner{position:relative;max-width:1000px;margin:0 auto;padding:0 40px}
.tl-spine{position:absolute;left:50%;top:8px;bottom:8px;width:3px;transform:translateX(-50%);background:var(--border);border-radius:3px;overflow:hidden}
.tl-fill{position:absolute;left:0;top:0;width:100%;height:0;background:linear-gradient(180deg,var(--accent),var(--accent2));box-shadow:0 0 14px rgba(214,72,104,.6)}
.tl-row{position:relative;display:grid;grid-template-columns:1fr 1fr;margin-bottom:44px;align-items:center}
.tl-row:last-child{margin-bottom:0}
.tl-card{border:1px solid var(--border);border-radius:20px;padding:26px 28px;background:var(--card);box-shadow:var(--shadow-md);position:relative}
.tl-row.left .tl-card{grid-column:1;margin-right:50px}
.tl-row.right .tl-card{grid-column:2;margin-left:50px}
.tl-dot{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:18px;height:18px;border-radius:50%;background:var(--card);border:3px solid var(--border2);z-index:2;transition:border-color .3s,background .3s,box-shadow .3s}
.tl-dot.on{border-color:var(--accent);background:var(--accent);box-shadow:0 0 0 6px var(--accent-bg),0 0 16px rgba(214,72,104,.7)}
.tl-ico{font-size:30px;line-height:1;margin-bottom:8px}
.tl-num{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.tl-card h2{font-size:clamp(20px,2.4vw,27px);font-weight:800;letter-spacing:-.7px;line-height:1.12;color:var(--text);margin:6px 0 9px}
.tl-card p{font-size:14.5px;color:var(--text2);line-height:1.6;margin-bottom:12px}
.tl-card ul{list-style:none;display:flex;flex-direction:column;gap:7px}
.tl-card li{font-size:13px;color:var(--text3);padding-left:20px;position:relative;line-height:1.5}
.tl-card li::before{content:'✓';position:absolute;left:0;top:0;color:var(--accent);font-weight:800}
@media(max-width:760px){
  .tl-inner{padding:0 18px 0 8px}
  .tl-spine{left:20px;transform:none}
  .tl-row{grid-template-columns:1fr;margin-bottom:24px}
  .tl-row.left .tl-card,.tl-row.right .tl-card{grid-column:1;margin:0 0 0 46px}
  .tl-dot{left:20px}
}
