/* ============================================================
   MOHAMED FAYEK — Hermes Command Center design system
   Dark-glass "mission control" · violet + gold · Inter Tight
   ============================================================ */

:root{
  /* foundations */
  --bg:#15151F;
  --bg-deep:#0e0e16;
  --glass:rgba(31,31,43,0.55);
  --glass-strong:rgba(31,31,43,0.85);
  --hairline:rgba(255,255,255,0.08);
  --hairline-2:rgba(255,255,255,0.14);
  --text:#F4F4F8;
  --muted:#8A8A9B;
  --muted-2:#b6b6c4;

  /* accents */
  --violet:#8B5CF6;
  --violet-glow:#A78BFA;
  --cyan:#7DD3FC;
  --mint:#5EE2B5;
  --amber:#F5B544;
  --red:#F26D6D;
  --pink:#F472B6;
  --gold:#FBBF24;
  --magenta:#E879F9;

  /* per-page accent (overridable via [data-accent]) */
  --accent:#8B5CF6;
  --accent-glow:#A78BFA;

  --font-display:'Inter Tight',system-ui,-apple-system,Segoe UI,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,SFMono-Regular,monospace;

  --radius:16px;
  --radius-lg:22px;
  --radius-sm:11px;
  --maxw:1180px;
  --gutter:clamp(20px,5vw,40px);
  --blur:14px;
}

/* accent themes */
[data-accent="violet"] { --accent:#8B5CF6; --accent-glow:#A78BFA; }
[data-accent="cyan"]   { --accent:#7DD3FC; --accent-glow:#a5e4ff; }
[data-accent="mint"]   { --accent:#5EE2B5; --accent-glow:#8af0cf; }
[data-accent="amber"]  { --accent:#F5B544; --accent-glow:#ffcd6e; }
[data-accent="gold"]   { --accent:#FBBF24; --accent-glow:#ffd45c; }
[data-accent="pink"]   { --accent:#F472B6; --accent-glow:#ff9bcf; }
[data-accent="magenta"]{ --accent:#E879F9; --accent-glow:#f3a6ff; }

*,*::before,*::after{ box-sizing:border-box; }

/* inline icon defaults (overridden by more specific rules below) */
.mf-ic{ width:1.15em; height:1.15em; display:inline-block; vertical-align:middle; flex:none; }
.ic svg{ width:24px; height:24px; }
.faq__q .pm svg{ width:14px; height:14px; }
.arrow svg{ width:15px; height:15px; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
html.lenis,html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto !important; }

body{
  margin:0;
  background:var(--bg-deep);
  color:var(--text);
  font-family:var(--font-display);
  font-size:17px;
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* ambient page glow */
body::before{
  content:"";
  position:fixed; inset:0;
  z-index:-2;
  background:
    radial-gradient(60% 50% at 15% 0%, rgba(139,92,246,0.16), transparent 60%),
    radial-gradient(50% 45% at 92% 8%, rgba(251,191,36,0.10), transparent 60%),
    radial-gradient(70% 60% at 80% 100%, rgba(125,211,252,0.08), transparent 65%),
    var(--bg-deep);
}
body::after{
  content:"";
  position:fixed; inset:0; z-index:-1; pointer-events:none;
  opacity:.5;
  background-image:radial-gradient(circle at 1px 1px, rgba(255,255,255,0.04) 1px, transparent 0);
  background-size:42px 42px;
  mask-image:radial-gradient(ellipse 100% 80% at 50% 0%, #000 30%, transparent 80%);
}

a{ color:inherit; text-decoration:none; }
img,svg,video{ display:block; max-width:100%; }
button{ font-family:inherit; cursor:pointer; }

/* ---------- layout ---------- */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.container--wide{ max-width:1320px; }
.section{ padding-block:clamp(64px,10vw,128px); position:relative; }
.section--tight{ padding-block:clamp(48px,7vw,80px); }

/* ---------- typography ---------- */
h1,h2,h3,h4{ font-weight:800; line-height:1.05; letter-spacing:-0.02em; margin:0; overflow-wrap:break-word; word-break:break-word; }
h1{ font-size:clamp(2.6rem,6.2vw,4.6rem); }
h2{ font-size:clamp(2rem,4.4vw,3.3rem); }
h3{ font-size:clamp(1.3rem,2.4vw,1.85rem); letter-spacing:-0.01em; }
p{ margin:0 0 1em; color:var(--muted-2); }
.lede{ font-size:clamp(1.05rem,1.8vw,1.3rem); color:var(--muted-2); max-width:60ch; }

.eyebrow{
  font-family:var(--font-mono); text-transform:uppercase;
  letter-spacing:0.22em; font-size:11px; font-weight:500;
  color:var(--accent-glow); margin:0 0 14px;
  display:inline-flex; align-items:center; gap:9px;
}
.eyebrow::before{
  content:""; width:22px; height:1px; background:linear-gradient(90deg,var(--accent),transparent);
}
.eyebrow--center{ justify-content:center; }
.eyebrow--center::before{ display:none; }

.mono{ font-family:var(--font-mono); text-transform:uppercase; letter-spacing:0.16em; font-size:0.8rem; }
.grad-text{ background:linear-gradient(120deg,var(--text) 30%,var(--accent-glow)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.gold-text{ background:linear-gradient(120deg,var(--gold),var(--amber)); -webkit-background-clip:text; background-clip:text; color:transparent; }

.section-head{ max-width:680px; margin-bottom:clamp(36px,5vw,60px); }
.section-head--center{ margin-inline:auto; text-align:center; }

/* ---------- buttons ---------- */
.btn{
  --b:var(--accent);
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-mono); text-transform:uppercase; letter-spacing:0.1em;
  font-size:12.5px; font-weight:600;
  padding:15px 26px; border-radius:12px;
  border:1px solid var(--hairline-2);
  transition:transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s, background .35s, border-color .35s;
  will-change:transform; position:relative; overflow:hidden;
}
.btn svg{ width:17px; height:17px; }
.btn--primary{
  background:linear-gradient(135deg,var(--violet),#7c45f0);
  color:#fff; border-color:transparent;
  box-shadow:0 10px 30px rgba(139,92,246,.34), inset 0 1px 0 rgba(255,255,255,.18);
}
.btn--primary:hover{ transform:translateY(-3px); box-shadow:0 16px 44px rgba(139,92,246,.5), inset 0 1px 0 rgba(255,255,255,.22); }
.btn--wa{ background:linear-gradient(135deg,#22c55e,#16a34a); box-shadow:0 10px 30px rgba(34,197,94,.30), inset 0 1px 0 rgba(255,255,255,.2); color:#fff; border-color:transparent; }
.btn--wa:hover{ transform:translateY(-3px); box-shadow:0 16px 44px rgba(34,197,94,.45); }
.btn--ghost{ background:rgba(255,255,255,.03); color:var(--text); }
.btn--ghost:hover{ transform:translateY(-3px); border-color:var(--accent); background:rgba(255,255,255,.06); }
.btn--lg{ padding:18px 34px; font-size:13.5px; }
.btn--block{ width:100%; justify-content:center; }

/* ---------- pills / chips ---------- */
.pill{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-mono); text-transform:uppercase; letter-spacing:0.12em;
  font-size:11px; padding:7px 14px; border-radius:999px;
  border:1px solid var(--hairline-2); background:rgba(255,255,255,.03); color:var(--muted-2);
}
.pill .dot{ width:7px; height:7px; border-radius:50%; background:var(--accent); box-shadow:0 0 10px var(--accent); }
.pill--accent{ color:var(--accent-glow); border-color:color-mix(in srgb,var(--accent) 40%, transparent); background:color-mix(in srgb,var(--accent) 10%, transparent); }

/* ---------- glass surfaces ---------- */
.glass{
  background:var(--glass);
  -webkit-backdrop-filter:blur(var(--blur)); backdrop-filter:blur(var(--blur));
  border:1px solid var(--hairline);
  border-radius:var(--radius);
}
.card{
  background:var(--glass);
  -webkit-backdrop-filter:blur(var(--blur)); backdrop-filter:blur(var(--blur));
  border:1px solid var(--hairline);
  border-radius:var(--radius);
  padding:28px;
  position:relative; overflow:hidden;
  transition:transform .4s cubic-bezier(.2,.8,.2,1), border-color .4s, box-shadow .4s;
}
.card--hover:hover{ transform:translateY(-6px); border-color:color-mix(in srgb,var(--accent) 50%, transparent); box-shadow:0 24px 60px rgba(0,0,0,.4); }
.card__glow{ position:absolute; inset:0; opacity:0; transition:opacity .4s; pointer-events:none;
  background:radial-gradient(120% 80% at 50% 0%, color-mix(in srgb,var(--accent) 16%, transparent), transparent 70%); }
.card--hover:hover .card__glow{ opacity:1; }

/* ---------- header / nav ---------- */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:100;
  transition:background .4s, border-color .4s, padding .4s, backdrop-filter .4s;
  border-bottom:1px solid transparent;
}
.site-header.is-scrolled{
  background:rgba(14,14,22,0.72);
  -webkit-backdrop-filter:blur(18px) saturate(140%); backdrop-filter:blur(18px) saturate(140%);
  border-bottom-color:var(--hairline);
}
.nav{ display:flex; align-items:center; justify-content:space-between; height:74px; }
.brand{ display:flex; align-items:center; gap:12px; }
.brand img{ height:36px; width:auto; }
.brand__name{ display:block; font-weight:700; font-size:1.02rem; letter-spacing:-0.01em; line-height:1.1; }
.brand__role{ display:block; font-family:var(--font-mono); font-size:9.5px; letter-spacing:0.2em; text-transform:uppercase; color:var(--muted); margin-top:5px; }
.nav__menu{ display:flex; align-items:center; gap:6px; list-style:none; margin:0; padding:0; }
.nav__menu a{
  font-size:14px; font-weight:500; color:var(--muted-2); padding:9px 14px; border-radius:9px;
  transition:color .25s, background .25s; position:relative;
}
.nav__menu a:hover,.nav__menu .current-menu-item>a{ color:var(--text); background:rgba(255,255,255,.05); }
.nav__menu .menu-item-has-children>a::after{ content:"⌄"; margin-left:6px; opacity:.6; font-size:.85em; }
.nav__menu .sub-menu{
  position:absolute; top:calc(100% + 12px); left:0; min-width:230px;
  list-style:none; margin:0; padding:8px;
  background:var(--glass-strong); -webkit-backdrop-filter:blur(18px); backdrop-filter:blur(18px);
  border:1px solid var(--hairline); border-radius:14px; box-shadow:0 24px 60px rgba(0,0,0,.5);
  opacity:0; visibility:hidden; transform:translateY(8px); transition:.28s;
}
.nav__menu .menu-item-has-children{ position:relative; }
.nav__menu .menu-item-has-children:hover .sub-menu{ opacity:1; visibility:visible; transform:translateY(0); }
.nav__menu .sub-menu a{ display:block; padding:11px 14px; }
.nav__actions{ display:flex; align-items:center; gap:14px; }
.nav__toggle{ display:none; background:none; border:0; color:var(--text); padding:8px; }
.nav__toggle svg{ width:26px; height:26px; }

/* ---------- mega menu (desktop) ---------- */
.nav__mega-item{ position:static; }
.nav__mega-trigger{ display:inline-flex !important; align-items:center; gap:6px; }
.mega{
  position:absolute; left:0; right:0; top:100%;
  background:#14141d;
  -webkit-backdrop-filter:blur(20px) saturate(140%); backdrop-filter:blur(20px) saturate(140%);
  border-top:1px solid var(--hairline); border-bottom:1px solid var(--hairline);
  box-shadow:0 34px 70px rgba(0,0,0,.55);
  opacity:0; visibility:hidden; transform:translateY(10px);
  transition:opacity .26s, transform .26s, visibility .26s; padding:30px 0;
}
.nav__mega-item:hover .mega,
.nav__mega-item:focus-within .mega{ opacity:1; visibility:visible; transform:translateY(0); }
.mega__inner{ display:grid; grid-template-columns:repeat(3,1fr); gap:8px 34px; align-items:start; }
.mega__col{ padding:4px 0; }
.mega__hub{ display:flex; align-items:center; gap:12px; padding:0 0 11px; margin-bottom:10px; border-bottom:1px solid var(--hairline); }
.nav__menu .mega__hub:hover{ background:transparent; }
.mega__ic{ width:40px; height:40px; border-radius:11px; flex:none; display:grid; place-items:center; background:color-mix(in srgb,var(--accent) 14%,transparent); border:1px solid color-mix(in srgb,var(--accent) 32%,transparent); color:var(--accent-glow); }
.mega__ic svg{ width:21px; height:21px; }
.mega__hub-txt{ display:flex; flex-direction:column; font-weight:700; font-size:.98rem; color:var(--text); transition:color .2s; }
.mega__hub-txt small{ font-family:var(--font-mono); font-size:9.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); font-weight:500; margin-top:3px; }
.mega__hub:hover .mega__hub-txt{ color:var(--accent-glow); }
.mega__list{ list-style:none; margin:0 0 6px; padding:0; display:grid; gap:1px; }
.mega__list a{ display:block; padding:3px 9px; border-radius:7px; font-size:.9rem; color:var(--muted-2); transition:color .2s, background .2s; }
.mega__list a:hover{ color:var(--text); background:rgba(255,255,255,.05); }
.mega__all{ font-family:var(--font-mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--accent-glow); display:inline-flex; align-items:center; gap:6px; padding:6px 9px; }
.mega__all svg{ width:13px; height:13px; }

/* ---------- mobile services accordion ---------- */
.m-services{ border-bottom:1px solid var(--hairline); }
.m-services summary{ list-style:none; cursor:pointer; font-size:1.7rem; font-weight:700; padding:14px 0; display:flex; align-items:center; justify-content:space-between; }
.m-services summary::-webkit-details-marker{ display:none; }
.m-services summary svg{ transition:transform .3s; color:var(--muted); }
.m-services[open] summary svg{ transform:rotate(180deg); }
.m-services__body{ padding:4px 0 18px; }
.m-hub{ display:flex; align-items:center; gap:11px; font-weight:600; font-size:1.05rem; padding:14px 0 6px; color:var(--text); }
.m-hub__ic{ width:32px; height:32px; border-radius:9px; flex:none; display:grid; place-items:center; background:color-mix(in srgb,var(--accent) 14%,transparent); border:1px solid color-mix(in srgb,var(--accent) 30%,transparent); color:var(--accent-glow); }
.m-hub__ic svg{ width:17px; height:17px; }
.m-svc{ list-style:none; margin:0 0 8px; padding:2px 0 8px 43px; display:grid; gap:1px; }
.m-svc a{ display:block; color:var(--muted-2); font-size:.98rem; padding:7px 0; }

/* offset fixed header below the WP admin bar (logged-in only) */
body.admin-bar .site-header{ top:32px; }
@media(max-width:782px){ body.admin-bar .site-header{ top:46px; } }
body.admin-bar .mobile-nav{ top:32px; }
@media(max-width:782px){ body.admin-bar .mobile-nav{ top:46px; } }

/* mobile drawer */
.mobile-nav{
  position:fixed; inset:0; z-index:99; background:rgba(10,10,16,0.97);
  -webkit-backdrop-filter:blur(20px); backdrop-filter:blur(20px);
  display:block; padding:96px var(--gutter) 56px;
  transform:translateY(-100%); transition:transform .5s cubic-bezier(.7,0,.2,1);
  overflow-y:auto; overflow-x:hidden; -webkit-overflow-scrolling:touch; overscroll-behavior:contain;
}
.mobile-nav.is-open{ transform:translateY(0); }
.mobile-nav ul{ list-style:none; margin:0; padding:0; }
.mobile-nav>ul>li>a{ font-size:1.7rem; font-weight:700; padding:14px 0; display:block; border-bottom:1px solid var(--hairline); }
.mobile-nav .sub-menu{ padding:6px 0 14px 14px; }
.mobile-nav .sub-menu a{ font-size:1.05rem; color:var(--muted-2); padding:9px 0; display:block; }
body.nav-open{ overflow:hidden; }

/* ---------- hero (home) ---------- */
.hero{ position:relative; padding-top:140px; padding-bottom:clamp(60px,9vw,110px); overflow:hidden; }
.hero__grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(30px,5vw,64px); align-items:center; }
.hero h1{ margin-bottom:22px; }
.hero__grid>*,.svc-hero__grid>*,.contact-grid>*{ min-width:0; } /* prevent grid-child overflow */
.hero__sub{ font-size:clamp(1.05rem,1.7vw,1.28rem); color:var(--muted-2); max-width:54ch; margin-bottom:32px; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; }
.hero__stats{ display:flex; gap:30px; margin-top:46px; flex-wrap:wrap; }
.hero__stat .num{ font-size:2.4rem; font-weight:800; letter-spacing:-0.02em; line-height:1; }
.hero__stat .lbl{ font-family:var(--font-mono); font-size:10.5px; text-transform:uppercase; letter-spacing:0.14em; color:var(--muted); margin-top:8px; }

.portrait{ position:relative; }
.portrait__frame{
  border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--hairline-2);
  box-shadow:0 40px 90px rgba(0,0,0,.55); position:relative; background:var(--glass);
}
.portrait__frame img{ width:100%; height:auto; }
.portrait__frame::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%, rgba(14,14,22,.5)); }
.portrait__ring{ position:absolute; inset:-14px; border-radius:30px; background:conic-gradient(from 0deg,var(--violet),var(--gold),var(--cyan),var(--violet)); filter:blur(28px); opacity:.35; z-index:-1; }
.portrait__badge{
  position:absolute; left:-18px; bottom:30px; z-index:3;
  display:flex; align-items:center; gap:12px; padding:13px 18px;
}
.portrait__badge .k{ font-family:var(--font-mono); font-size:9px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
.portrait__badge .v{ font-weight:800; font-size:1.15rem; }
.portrait__badge--top{ left:auto; right:-14px; top:24px; bottom:auto; }

/* ---------- marquee trust bar ---------- */
.marquee{ border-block:1px solid var(--hairline); padding-block:20px; overflow:hidden; -webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent); mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent); }
.marquee__track{ display:flex; gap:56px; width:max-content; animation:marquee 32s linear infinite; }
.marquee__track span{ font-family:var(--font-mono); text-transform:uppercase; letter-spacing:0.14em; font-size:13px; color:var(--muted); display:inline-flex; align-items:center; gap:14px; white-space:nowrap; }
.marquee__track span::after{ content:"◆"; color:var(--accent); font-size:8px; }
@keyframes marquee{ to{ transform:translateX(-50%); } }

/* ---------- service / category cards ---------- */
.grid{ display:grid; gap:22px; }
.grid--2{ grid-template-columns:repeat(2,1fr); }
.grid--3{ grid-template-columns:repeat(3,1fr); }
.grid--4{ grid-template-columns:repeat(4,1fr); }

.svc-card{ display:flex; flex-direction:column; min-height:240px; }
.svc-card .ic{
  width:50px; height:50px; border-radius:13px; display:grid; place-items:center; margin-bottom:20px;
  background:color-mix(in srgb,var(--accent) 14%, transparent);
  border:1px solid color-mix(in srgb,var(--accent) 30%, transparent);
  color:var(--accent-glow);
}
.svc-card .ic svg{ width:24px; height:24px; }
.svc-card h3{ margin-bottom:10px; }
.svc-card p{ font-size:.96rem; margin-bottom:18px; }
.svc-card .arrow{ margin-top:auto; font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--accent-glow); display:inline-flex; align-items:center; gap:8px; transition:gap .3s; }
.svc-card:hover .arrow{ gap:14px; }
.svc-card .count{ position:absolute; top:24px; right:26px; font-family:var(--font-mono); font-size:11px; color:var(--muted); letter-spacing:.1em; }

/* small service chips (hub list) */
.svc-chip{ display:flex; align-items:center; gap:14px; padding:18px 20px; }
.svc-chip .n{ font-family:var(--font-mono); font-size:11px; color:var(--accent-glow); }
.svc-chip h4{ font-size:1.05rem; font-weight:600; margin:0; }
.svc-chip:hover{ border-color:color-mix(in srgb,var(--accent) 50%, transparent); }

/* ---------- stats band ---------- */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--hairline); border:1px solid var(--hairline); border-radius:var(--radius-lg); overflow:hidden; }
.stats .cell{ background:var(--bg); padding:34px 26px; text-align:center; }
.stats .num{ font-size:clamp(2.2rem,3.6vw,3rem); font-weight:800; letter-spacing:-0.02em; line-height:1; }
.stats .lbl{ font-family:var(--font-mono); font-size:10.5px; text-transform:uppercase; letter-spacing:0.14em; color:var(--muted); margin-top:12px; }

/* ---------- process steps ---------- */
.steps{ display:grid; gap:20px; counter-reset:step; }
.step{ display:grid; grid-template-columns:auto 1fr; gap:22px; padding:26px 28px; }
.step .idx{ font-family:var(--font-mono); font-size:13px; color:var(--accent-glow); border:1px solid color-mix(in srgb,var(--accent) 36%, transparent); width:44px; height:44px; border-radius:12px; display:grid; place-items:center; background:color-mix(in srgb,var(--accent) 10%, transparent); }
.step h3{ font-size:1.2rem; margin-bottom:6px; }
.step p{ margin:0; font-size:.96rem; }

/* ---------- deliverables ---------- */
.deliv{ display:grid; gap:14px; }
.deliv li{ list-style:none; display:flex; gap:14px; align-items:flex-start; padding:16px 20px; border:1px solid var(--hairline); border-radius:13px; background:var(--glass); }
.deliv li .chk{ flex:none; width:24px; height:24px; border-radius:7px; display:grid; place-items:center; color:var(--accent); background:color-mix(in srgb,var(--accent) 14%, transparent); }
.deliv li .chk svg{ width:14px; height:14px; }
.deliv li b{ color:var(--text); font-weight:600; }
.deliv li span{ color:var(--muted-2); font-size:.94rem; }

/* ---------- FAQ ---------- */
.faq{ display:grid; gap:12px; }
.faq__item{ border:1px solid var(--hairline); border-radius:14px; background:var(--glass); overflow:hidden; }
.faq__q{ width:100%; text-align:left; background:none; border:0; color:var(--text); font-size:1.08rem; font-weight:600; padding:22px 24px; display:flex; justify-content:space-between; align-items:center; gap:16px; }
.faq__q .pm{ flex:none; width:26px; height:26px; border:1px solid var(--hairline-2); border-radius:8px; display:grid; place-items:center; transition:.3s; color:var(--accent-glow); }
.faq__item.is-open .faq__q .pm{ transform:rotate(45deg); border-color:var(--accent); }
.faq__a{ max-height:0; overflow:hidden; transition:max-height .4s ease; }
.faq__a .inner{ padding:0 24px 22px; color:var(--muted-2); }

/* ---------- testimonials ---------- */
.tst{ position:relative; }
.tst__viewport{ overflow:hidden; }
.tst__track{ display:flex; transition:transform .6s cubic-bezier(.5,0,.2,1); }
.tst__slide{ flex:0 0 100%; padding:6px; }
.tst__card{ padding:clamp(30px,5vw,56px); text-align:center; max-width:840px; margin-inline:auto; }
.tst__stars{ color:var(--gold); letter-spacing:4px; margin-bottom:22px; font-size:1.1rem; }
.tst__quote{ font-size:clamp(1.2rem,2.4vw,1.7rem); font-weight:600; line-height:1.5; letter-spacing:-0.01em; color:var(--text); margin-bottom:26px; }
.tst__who{ font-family:var(--font-mono); text-transform:uppercase; letter-spacing:0.14em; font-size:12px; color:var(--accent-glow); }
.tst__who span{ color:var(--muted); }
.tst__nav{ display:flex; justify-content:center; align-items:center; gap:18px; margin-top:32px; }
.tst__dots{ display:flex; gap:10px; align-items:center; }
.tst__dot{ width:9px; height:9px; border-radius:50%; border:0; background:var(--hairline-2); transition:.3s; padding:0; cursor:pointer; }
.tst__dot.is-active{ background:var(--accent); width:30px; border-radius:5px; }
.tst__arrow{ width:48px; height:48px; border-radius:50%; border:1px solid var(--hairline-2); background:var(--glass); color:var(--text); display:grid; place-items:center; transition:.3s; flex:none; }
.tst__arrow:hover{ border-color:var(--accent); color:var(--accent-glow); background:color-mix(in srgb,var(--accent) 12%,transparent); transform:translateY(-2px); }
.tst__arrow svg{ width:20px; height:20px; }

/* ---------- CTA band ---------- */
.cta-band{ position:relative; overflow:hidden; border-radius:var(--radius-lg); padding:clamp(40px,7vw,84px); text-align:center; border:1px solid var(--hairline-2); background:var(--glass); }
.cta-band::before{ content:""; position:absolute; inset:0; z-index:-1; background:radial-gradient(70% 120% at 50% 0%, rgba(139,92,246,.28), transparent 60%), radial-gradient(60% 100% at 80% 100%, rgba(251,191,36,.16), transparent 60%); }
.cta-band h2{ margin-bottom:18px; }
.cta-band .lede{ margin-inline:auto; margin-bottom:34px; }

/* ---------- contact / WhatsApp form ---------- */
.wa-form{ display:grid; gap:18px; }
.field{ display:grid; gap:8px; }
.field label{ font-family:var(--font-mono); font-size:11px; text-transform:uppercase; letter-spacing:.14em; color:var(--muted); }
.field input,.field textarea,.field select{
  width:100%; background:rgba(255,255,255,.04); border:1px solid var(--hairline-2); border-radius:12px;
  color:var(--text); font-family:inherit; font-size:1rem; padding:14px 16px; transition:border-color .3s, background .3s;
}
.field textarea{ min-height:130px; resize:vertical; }
.field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-color:var(--accent); background:rgba(255,255,255,.06); }
.field select option{ background:var(--bg); }
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,54px); align-items:start; }
.contact-info{ display:grid; gap:16px; }
.info-row{ display:flex; gap:16px; align-items:center; padding:20px 22px; }
.info-row .ic{ width:46px; height:46px; border-radius:12px; display:grid; place-items:center; background:color-mix(in srgb,var(--accent) 14%, transparent); color:var(--accent-glow); flex:none; }
.info-row .k{ font-family:var(--font-mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
.info-row .v{ font-weight:600; font-size:1.05rem; }

/* ---------- service single hero variants ---------- */
.svc-hero{ position:relative; padding-top:138px; padding-bottom:clamp(48px,7vw,84px); overflow:hidden; }
.svc-hero .breadcrumb{ font-family:var(--font-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-bottom:24px; display:flex; gap:10px; flex-wrap:wrap; }
.svc-hero .breadcrumb a:hover{ color:var(--accent-glow); }
.svc-hero h1{ max-width:16ch; margin-bottom:22px; }
.svc-hero .lede{ margin-bottom:34px; }

/* variant: aurora (centered, big glow) */
.svc-hero--aurora{ text-align:center; }
.svc-hero--aurora .breadcrumb{ justify-content:center; }
.svc-hero--aurora h1{ max-width:18ch; margin-inline:auto; }
.svc-hero--aurora .lede{ margin-inline:auto; }
.svc-hero--aurora .svc-hero__cta{ justify-content:center; }
.aurora-blob{ position:absolute; z-index:-1; width:60vw; height:60vw; max-width:780px; max-height:780px; left:50%; top:-22%; transform:translateX(-50%); border-radius:50%; background:radial-gradient(circle,color-mix(in srgb,var(--accent) 38%, transparent),transparent 62%); filter:blur(60px); opacity:.55; }

/* variant: split (text left, stat panel right) */
.svc-hero--split .svc-hero__grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(30px,5vw,60px); align-items:center; }

/* variant: grid (text + floating metric tiles) */
.svc-hero--grid .metric-tiles{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px; margin-top:14px; }

.svc-hero__cta{ display:flex; gap:14px; flex-wrap:wrap; }
.hero-stat-panel{ display:grid; gap:16px; }
.hero-stat-panel .cell{ padding:24px 26px; }
.hero-stat-panel .num{ font-size:2.3rem; font-weight:800; line-height:1; }
.hero-stat-panel .lbl{ font-family:var(--font-mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-top:8px; }

.svc-section h2{ margin-bottom:18px; }
.problem-card{ padding:clamp(28px,4vw,46px); border-left:3px solid var(--accent); }
.outcomes{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.outcome{ text-align:center; padding:30px 22px; }
.outcome .num{ font-size:2.6rem; font-weight:800; line-height:1; }
.outcome .lbl{ color:var(--muted-2); font-size:.95rem; margin-top:10px; }

/* ---------- page hero (about/legal/hub) ---------- */
.page-hero{ padding-top:140px; padding-bottom:clamp(30px,5vw,56px); }
.page-hero h1{ margin-bottom:20px; }

/* legal / prose */
.prose{ max-width:760px; }
.prose h2{ font-size:1.6rem; margin:42px 0 14px; }
.prose h3{ font-size:1.2rem; margin:28px 0 10px; }
.prose p,.prose li{ color:var(--muted-2); }
.prose ul{ padding-left:20px; }
.prose a{ color:var(--accent-glow); text-decoration:underline; text-underline-offset:3px; }

/* about timeline */
.timeline{ display:grid; gap:0; position:relative; }
.tl-item{ display:grid; grid-template-columns:120px 1fr; gap:26px; padding:26px 0; border-top:1px solid var(--hairline); }
.tl-item:last-child{ border-bottom:1px solid var(--hairline); }
.tl-item .yr{ font-family:var(--font-mono); color:var(--accent-glow); letter-spacing:.1em; font-size:14px; padding-top:4px; }
.tl-item h3{ font-size:1.25rem; margin-bottom:6px; }
.tl-item p{ margin:0; }

/* ---------- footer ---------- */
.site-footer{ border-top:1px solid var(--hairline); margin-top:40px; padding-block:60px 34px; position:relative; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:36px; margin-bottom:48px; }
.footer-grid h4{ font-family:var(--font-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-bottom:18px; font-weight:500; }
.footer-grid ul{ list-style:none; margin:0; padding:0; display:grid; gap:11px; }
.footer-grid a{ color:var(--muted-2); font-size:.95rem; }
.footer-grid a:hover{ color:var(--text); }
.footer-blurb{ color:var(--muted-2); font-size:.95rem; max-width:34ch; margin:16px 0 0; }
/* footer contact rows with brand icons */
.footer-contact{ display:grid; gap:12px; list-style:none; margin:0; padding:0; }
.footer-contact a,.footer-contact span.loc{ display:flex; align-items:center; gap:12px; color:var(--muted-2); font-size:.95rem; }
.footer-contact a:hover{ color:var(--text); }
.footer-contact .ic{ width:38px; height:38px; border-radius:11px; display:grid; place-items:center; flex:none; border:1px solid var(--hairline-2); background:rgba(255,255,255,.03); transition:.3s; }
.footer-contact .ic svg{ width:18px; height:18px; }
.footer-contact .ic--wa{ color:#5EE2B5; }
.footer-contact .ic--phone{ color:var(--gold); }
.footer-contact .ic--loc{ color:var(--violet-glow); }
.footer-contact a:hover .ic{ transform:translateY(-2px); border-color:currentColor; }

/* social icon buttons (brand styled) */
.social-icons{ display:flex; gap:12px; margin-top:6px; }
.social-icons a{ width:44px; height:44px; border-radius:12px; display:grid; place-items:center; border:1px solid var(--hairline-2); background:var(--glass); transition:.32s; }
.social-icons a svg{ width:20px; height:20px; }
.social-icons a.s-fb{ color:#7DD3FC; }
.social-icons a.s-ig{ color:#F472B6; }
.social-icons a.s-li{ color:#A78BFA; }
.social-icons a.s-yt{ color:#F26D6D; }
.social-icons a.s-tt{ color:#5EE2B5; }
.social-icons a:hover{ transform:translateY(-3px); border-color:currentColor; background:color-mix(in srgb,currentColor 14%,transparent); box-shadow:0 10px 26px rgba(0,0,0,.35); }

.footer-bottom{ display:flex; justify-content:space-between; align-items:center; gap:20px; padding-top:28px; border-top:1px solid var(--hairline); flex-wrap:wrap; }
.footer-bottom p{ margin:0; font-family:var(--font-mono); font-size:11px; letter-spacing:.08em; color:var(--muted); text-transform:uppercase; }

/* floating WhatsApp */
.wa-float{ position:fixed; right:22px; bottom:22px; z-index:90; width:58px; height:58px; border-radius:50%; background:linear-gradient(135deg,#22c55e,#16a34a); display:grid; place-items:center; box-shadow:0 12px 34px rgba(34,197,94,.45); transition:transform .35s; }
.wa-float:hover{ transform:scale(1.08); }
.wa-float svg{ width:30px; height:30px; }
.wa-float::after{ content:""; position:absolute; inset:0; border-radius:50%; border:2px solid #22c55e; animation:pulse 2.4s ease-out infinite; }
@keyframes pulse{ 0%{ transform:scale(1); opacity:.7; } 100%{ transform:scale(1.7); opacity:0; } }

/* custom cursor glow */
.cursor-glow{ position:fixed; top:0; left:0; width:380px; height:380px; border-radius:50%; pointer-events:none; z-index:1; transform:translate(-50%,-50%); background:radial-gradient(circle,rgba(139,92,246,.10),transparent 60%); transition:opacity .3s; mix-blend-mode:screen; }

/* ---------- reveal animations ---------- */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .8s cubic-bezier(.2,.8,.2,1), transform .8s cubic-bezier(.2,.8,.2,1); }
.reveal.is-in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; }
.reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; }
.reveal[data-d="4"]{ transition-delay:.32s; }
.reveal[data-d="5"]{ transition-delay:.4s; }

/* ---------- blog ---------- */
.cat-pills{ display:flex; flex-wrap:wrap; gap:10px; margin-top:8px; }
.cat-pill{ font-family:var(--font-mono); text-transform:uppercase; letter-spacing:.1em; font-size:11px; padding:9px 16px; border-radius:999px; border:1px solid var(--hairline-2); background:rgba(255,255,255,.03); color:var(--muted-2); transition:.3s; }
.cat-pill:hover,.cat-pill.is-active{ color:var(--accent-glow); border-color:color-mix(in srgb,var(--accent) 50%,transparent); background:color-mix(in srgb,var(--accent) 12%,transparent); }

.post-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.post-card{ display:flex; flex-direction:column; overflow:hidden; padding:0; }
.post-card__media{ aspect-ratio:16/10; overflow:hidden; position:relative; background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 22%,transparent),transparent); }
.post-card__media img{ width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.2,.8,.2,1); }
.post-card:hover .post-card__media img{ transform:scale(1.06); }
.post-card__media .ph{ position:absolute; inset:0; display:grid; place-items:center; color:color-mix(in srgb,var(--accent) 60%,white); opacity:.5; }
.post-card__media .ph svg{ width:46px; height:46px; }
.post-card__body{ padding:24px 26px 28px; display:flex; flex-direction:column; flex:1; }
.post-card__cat{ font-family:var(--font-mono); text-transform:uppercase; letter-spacing:.12em; font-size:10.5px; color:var(--accent-glow); margin-bottom:12px; }
.post-card h3{ font-size:1.25rem; margin-bottom:10px; }
.post-card p{ font-size:.95rem; color:var(--muted-2); margin-bottom:18px; }
.post-meta{ display:flex; gap:14px; align-items:center; font-family:var(--font-mono); font-size:11px; letter-spacing:.06em; color:var(--muted); text-transform:uppercase; margin-top:auto; }
.post-meta .dot{ width:4px; height:4px; border-radius:50%; background:var(--muted); }

/* single post */
.post-hero{ padding-top:140px; padding-bottom:clamp(24px,4vw,40px); }
.post-hero .post-meta{ margin-top:18px; }
.post-hero h1{ max-width:20ch; }
.post-feat{ border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--hairline); margin-bottom:8px; }
.post-feat img{ width:100%; height:auto; }
.prose img{ border-radius:14px; }
.prose blockquote{ border-left:3px solid var(--accent); margin:24px 0; padding:6px 0 6px 22px; color:var(--text); font-size:1.15rem; }
.prose h2{ scroll-margin-top:100px; }
.prose code{ font-family:var(--font-mono); background:rgba(255,255,255,.06); padding:2px 7px; border-radius:6px; font-size:.9em; }
.post-share{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin-top:40px; padding-top:28px; border-top:1px solid var(--hairline); }
.post-share .lbl{ font-family:var(--font-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-right:6px; }

/* author box */
.author-box{ display:flex; gap:22px; align-items:flex-start; padding:28px; margin-top:44px; }
.author-box__img{ width:92px; height:92px; border-radius:16px; object-fit:cover; flex:none; border:1px solid var(--hairline-2); }
.author-box__body{ flex:1; }
.author-box__body h3{ margin:4px 0 10px; }
.author-box__body p{ font-size:.96rem; margin-bottom:14px; }
.author-box__company{ display:inline-flex; align-items:center; gap:7px; font-family:var(--font-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--gold); margin-bottom:14px; }
.author-box__company svg{ width:13px; height:13px; }
.author-box__social{ margin-top:4px; }
.author-box__social a{ width:38px; height:38px; }
.author-box__social a svg{ width:17px; height:17px; }
@media(max-width:600px){ .author-box{ flex-direction:column; } }

/* pagination */
.pagination .nav-links,.posts-pagination{ display:flex; gap:8px; justify-content:center; flex-wrap:wrap; }
.pagination .page-numbers{ display:grid; place-items:center; min-width:44px; height:44px; padding:0 12px; border-radius:11px; border:1px solid var(--hairline-2); background:var(--glass); color:var(--muted-2); font-family:var(--font-mono); font-size:13px; transition:.3s; }
.pagination .page-numbers:hover,.pagination .page-numbers.current{ color:var(--text); border-color:var(--accent); background:color-mix(in srgb,var(--accent) 14%,transparent); }

/* ---------- responsive ---------- */
@media(max-width:1024px){
  /* Use the scrollable mobile drawer on all touch-sized devices (tablets too),
     so the hover-based desktop mega is never relied on for touch. */
  .nav__primary,.nav__actions .btn{ display:none; }
  .nav__toggle{ display:inline-flex; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .grid--4{ grid-template-columns:repeat(2,1fr); }
  .stats{ grid-template-columns:repeat(2,1fr); }
  .post-grid{ grid-template-columns:repeat(2,1fr); }
}
/* Desktop mega (>1024) safety: never exceed the viewport; scroll internally. */
.mega{ max-height:calc(100dvh - 80px); overflow-y:auto; overscroll-behavior:contain; }
/* Any touch device (incl. large tablets like iPad landscape) → use the drawer,
   never the hover-based desktop mega. */
@media (hover: none) and (pointer: coarse){
  .nav__primary,.nav__actions .btn{ display:none !important; }
  .nav__toggle{ display:inline-flex !important; }
}
/* iOS-safe scroll lock: body is fixed while the menu is open. */
body.nav-open{ position:fixed; left:0; right:0; width:100%; overflow:hidden; }
@media(max-width:860px){
  body{ font-size:16px; }
  .hero__grid,.svc-hero--split .svc-hero__grid,.contact-grid{ grid-template-columns:1fr; }
  .portrait{ order:-1; max-width:440px; margin-inline:auto; }
  .grid--2,.grid--3{ grid-template-columns:1fr; }
  .post-grid{ grid-template-columns:1fr; }
  .outcomes{ grid-template-columns:1fr; }
  .tl-item{ grid-template-columns:1fr; gap:6px; }
  .svc-hero--grid .metric-tiles{ grid-template-columns:1fr 1fr; }
}
@media(max-width:520px){
  h1{ font-size:clamp(1.9rem,8.4vw,2.7rem); }
  .grid--4{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:1fr 1fr; }
  .hero__stats{ gap:22px; }
  .step{ grid-template-columns:1fr; gap:12px; }
}

/* ---------- reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
  .marquee__track{ animation:none; }
  .wa-float::after{ animation:none; }
}
