
: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%; }
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:hidden;
  -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}
.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)}
/* 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%);
  }
  .nav-links.open a{padding:13px 16px;border-radius:12px;font-size:15px;width:100%}
  .nav-links.open a.active,.nav-links.open a:hover{background:var(--accent-bg)}
  .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{padding:9px 12px;gap:0}
  .nav-cta.nav-phone svg{width:18px;height:18px}
}
@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) { 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}
.prose{max-width:760px;margin:0 auto}
.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}
@media(max-width:768px){
  .ham-btn{display:none!important}
  .nav-links{display:none}
  .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 .32s cubic-bezier(.4,0,.2,1),opacity .3s,background .2s,color .2s;
    backface-visibility:hidden;-webkit-font-smoothing:antialiased;
  }
  .fm-item svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
  .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) * 54px))}
  .fluid-menu .fm-item:not(.fm-trigger):hover{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}
}
