/* =====================================================================
   3i Planet — Flagship homepage ("Udaipur's #1" build)
   Display: Space Grotesk · Body: Inter · Accent words: Fraunces italic
   Accent: brand blue #0079C4
   ===================================================================== */

:root{
  --bg:#FFFFFF;
  --bg2:#F6F5F1;
  --bg3:#EDEBE3;
  --ink:#0B0B0C;
  --ink2:#17171A;
  --muted:#65656B;
  --faint:#9C99A2;
  --line:rgba(11,11,12,.12);
  --line2:rgba(11,11,12,.06);
  --accent:#0079C4;
  --accent-d:#00598F;
  --accent-2:#2E9BE0;
  --accent-soft:#E4F1FB;
  --accent-glow:rgba(0,121,196,.16);
  --grad:linear-gradient(120deg,#0079C4,#2E9BE0);
  --ease:cubic-bezier(.22,.61,.36,1);
  --maxw:1280px;
  --shadow:0 2px 6px rgba(11,11,12,.05),0 26px 60px -24px rgba(11,11,12,.26);
  --shadow-sm:0 1px 3px rgba(11,11,12,.05),0 10px 26px -16px rgba(11,11,12,.2);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:clip;max-width:100%}
body{font-family:"Inter",system-ui,sans-serif;background:var(--bg);color:var(--ink);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:clip;max-width:100%;width:100%;position:relative}
img,svg,iframe,video,table{max-width:100%}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:#fff}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}
h1,h2,h3,h4{font-family:"Space Grotesk","Inter",sans-serif;font-weight:600;line-height:1.03;letter-spacing:-.025em}
.fr{font-family:"Fraunces",Georgia,serif;font-style:italic;font-weight:400;color:var(--accent)}
.out{-webkit-text-stroke:1.4px var(--ink);color:transparent}

/* custom cursor */
.cur,.cur-r{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);mix-blend-mode:normal}
.cur{width:7px;height:7px;background:var(--accent)}
.cur-r{width:38px;height:38px;border:1.5px solid var(--accent);transition:width .25s var(--ease),height .25s var(--ease),background .25s,opacity .25s}
.cur-r.big{width:64px;height:64px;background:var(--accent-glow);border-color:transparent}
body.has-cursor{cursor:none}
body.has-cursor a,body.has-cursor button{cursor:none}
@media(max-width:1024px),(pointer:coarse){.cur,.cur-r{display:none!important}}

/* tag */
.tag{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:12.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--accent)}
.tag::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.tag.live::before{animation:pulse 1.8s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 var(--accent-glow)}50%{box-shadow:0 0 0 7px rgba(0,121,196,0)}}
.tag.light{color:#fff}.tag.light::before{background:#fff;box-shadow:0 0 0 4px rgba(255,255,255,.16)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:11px;font-weight:600;font-size:15px;cursor:pointer;border:0;background:none}
.btn .txt{display:inline-flex;align-items:center;height:54px;padding:0 26px;border-radius:100px;background:var(--ink);color:#fff;transition:.3s var(--ease)}
.btn .ico{width:54px;height:54px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;transition:.4s var(--ease)}
.btn .ico svg{width:18px;height:18px}
.btn:hover .txt{background:var(--accent)}
.btn:hover .ico{background:var(--accent);transform:rotate(45deg)}
.btn.accent .txt,.btn.accent .ico{background:var(--accent)}
.btn.accent:hover .txt,.btn.accent:hover .ico{background:var(--ink)}
.btn.outline .txt,.btn.outline .ico{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn.outline:hover .txt{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn.outline:hover .ico{background:var(--ink);color:#fff;border-color:var(--ink);transform:rotate(45deg)}
.btn.light .txt,.btn.light .ico{background:#fff;color:var(--ink)}
.btn.light:hover .txt,.btn.light:hover .ico{background:var(--accent);color:#fff}

/* ============ HEADER ============ */
.hp-field,.qhp{position:absolute!important;left:-9999px!important;top:-9999px!important;width:1px;height:1px;opacity:0;pointer-events:none;overflow:hidden}
.qnotice{display:flex;gap:10px;align-items:flex-start;background:#fff8e6;border:1px solid #f6e2a8;border-radius:12px;padding:11px 14px;margin:0 0 18px;font-size:13.5px;line-height:1.5;color:#7a5b12}
.qnotice .qn-ic{font-size:16px;line-height:1.3;flex-shrink:0}
.qnotice a{color:var(--accent);font-weight:600;text-decoration:underline}
/* careers — resume upload + apply form */
.cv-up{display:flex;align-items:center;gap:12px;padding:14px 16px;margin-bottom:14px;border:1.5px dashed var(--line2);border-radius:12px;background:#fbfdff;cursor:pointer;transition:.25s var(--ease)}
.cv-up:hover{border-color:var(--accent);background:#f3f9ff}
.cv-up .cv-ic{width:34px;height:34px;flex-shrink:0;display:grid;place-items:center;border-radius:9px;background:#e8f3fc;color:var(--accent)}
.cv-up .cv-ic svg{width:18px;height:18px}
.cv-up .cv-txt{font-size:14px;color:var(--muted)}
.cv-up input[type=file]{display:none}
.cv-fine{font-size:12.5px;color:var(--faint);margin-top:12px;text-align:center}
/* careers — about working here */
.cwork{display:grid;grid-template-columns:1.7fr 1fr;gap:30px;align-items:start}
.cwork-main h2{margin-bottom:14px}
.cwork-note{background:#fff8e6;border:1px solid #f6e2a8;border-radius:16px;padding:22px;color:#7a5b12}
.cwork-note .cn-ic{font-size:22px}
.cwork-note p{margin:8px 0 12px;font-size:14.5px;line-height:1.6}
@media(max-width:860px){.cwork{grid-template-columns:1fr;gap:22px}}
.err404 .err-big{font-family:var(--ff-fr,Fraunces,serif);font-weight:600;font-size:clamp(110px,22vw,230px);line-height:.9;color:var(--accent);opacity:.13;letter-spacing:-.04em;margin-bottom:-12px}
.err-links{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;max-width:760px;margin:0 auto}
.err-links a{display:inline-flex;padding:11px 20px;border:1px solid var(--line);border-radius:50px;font-weight:600;font-size:14.5px;color:var(--ink);transition:.25s var(--ease)}
.err-links a:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-2px)}
.hdr{position:sticky;top:0;z-index:200;background:rgba(255,255,255,.94);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--line);transition:.35s var(--ease)}
.hdr.scrolled{border-bottom-color:var(--line);background:rgba(255,255,255,.95)}
.nav{display:flex;align-items:center;justify-content:space-between;height:86px;transition:height .35s var(--ease)}
.hdr.scrolled .nav{height:70px}
.logo img{height:40px;width:auto}
.menu{display:flex;gap:36px;list-style:none}
.menu a{font-weight:500;font-size:15px;position:relative;padding:6px 0}
.menu a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--accent);transition:width .3s var(--ease)}
.menu a:hover::after,.menu a.active::after{width:100%}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;z-index:50}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}
.mobcta{display:none;align-items:center;gap:7px;background:var(--accent);color:#fff;font-weight:600;font-size:13.5px;padding:9px 14px;border-radius:30px}
.mobcta svg{width:15px;height:15px}
.navscrim{display:none}

/* ============ HERO ============ */
.hero{position:relative;padding:64px 0 60px;text-align:center;overflow:hidden}
.hero::before{content:"";position:absolute;left:50%;top:-160px;transform:translateX(-50%);width:760px;height:560px;border-radius:50%;background:radial-gradient(circle,var(--accent-glow),transparent 66%);pointer-events:none}
.hero .in{position:relative;z-index:2}
.hero .tag{margin-bottom:24px}
.hero h1{font-size:clamp(44px,7.6vw,104px);font-weight:600;letter-spacing:-.035em;line-height:.98}
.hero p.sub{max-width:600px;margin:28px auto 34px;color:var(--muted);font-size:18px}
.hero-cta{display:flex;justify-content:center;align-items:center;gap:18px;flex-wrap:wrap}
.hero-rate{display:flex;flex-direction:column;gap:2px;text-align:left}
.hero-rate .stars{color:var(--accent);letter-spacing:2px;font-size:15px}
.hero-rate .rt{font-size:13px;color:var(--muted)}
.hero-rate .rt strong{color:var(--ink)}

.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
/* ===== Quote / SEO-audit form (shared by quote.php & seo-audit.php) ===== */
.qsec{padding-top:30px}
.qsplit{display:grid;grid-template-columns:1.02fr 1fr;gap:26px;align-items:stretch;margin-top:14px}
.qside{position:relative;overflow:hidden;border-radius:24px;padding:42px 38px;color:#fff;background:linear-gradient(150deg,var(--accent,#0079C4) 0%,#0a4a73 100%);box-shadow:0 30px 70px -34px rgba(0,70,120,.7)}
.qside-glow{position:absolute;top:-90px;right:-70px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.22),transparent 70%);pointer-events:none}
.qside-ey{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.85);margin-bottom:14px}
.qside h1{font-size:clamp(28px,3vw,40px);line-height:1.12;margin:0 0 14px;color:#fff}
.qside h1 .fr{color:#bfe6ff}
.qside-sub{color:rgba(255,255,255,.9);font-size:15.5px;line-height:1.6;margin:0 0 26px;max-width:440px}
.qben{list-style:none;padding:0;margin:0 0 28px;display:grid;gap:12px}
.qben li{display:flex;align-items:center;gap:12px;font-size:15px;font-weight:500}
.qb-ic{flex:none;width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.18);display:grid;place-items:center}
.qb-ic svg{width:14px;height:14px;stroke:#fff}
.qsteps{display:flex;gap:10px;flex-wrap:wrap;padding:20px 0;border-top:1px solid rgba(255,255,255,.18);border-bottom:1px solid rgba(255,255,255,.18)}
.qstep-i{display:flex;align-items:center;gap:9px;font-size:13.5px;font-weight:600}
.qstep-i b{width:26px;height:26px;border-radius:50%;background:#fff;color:var(--accent,#0079C4);display:grid;place-items:center;font-family:'Space Grotesk',sans-serif}
.qrate{display:flex;align-items:center;gap:10px;margin-top:22px;font-size:14px;color:rgba(255,255,255,.92)}
.qstars{color:#ffd35c;letter-spacing:2px;font-size:16px}
.qrate-lk{color:#fff;text-decoration:none}.qrate-lk:hover{text-decoration:underline}
.qcontact{display:flex;flex-direction:column;gap:10px;margin-top:24px}
.qc-link{display:inline-flex;align-items:center;gap:10px;color:#fff;text-decoration:none;font-size:14.5px;font-weight:500;opacity:.95}
.qc-link:hover{opacity:1;text-decoration:underline}
.qc-link svg{width:18px;height:18px;fill:#fff;flex:none}
.qcard{background:#fff;border:1px solid var(--line,#e6ecf2);border-radius:24px;padding:34px 32px;box-shadow:0 30px 70px -38px rgba(13,42,72,.4)}
.qcard-h{font-size:24px;margin:0 0 4px}
.qcard-sub{color:var(--muted,#526174);margin:0 0 22px;font-size:14.5px}
.qtwo{display:grid;grid-template-columns:1fr 1fr;gap:15px}
.qfield{margin-bottom:15px}
.qfield label{display:block;font-weight:600;margin-bottom:7px;font-size:14px;color:var(--ink,#0d2a48)}
.qfield .opt{color:var(--faint,#90a0b2);font-weight:400}
.qfield input,.qfield textarea,.qfield select{width:100%;padding:13px 15px;border:1px solid var(--line,#d7e0ea);border-radius:12px;font-size:15.5px;font-family:inherit;background:#fbfdff;color:var(--ink,#0d2a48)}
.qfield input:focus,.qfield textarea:focus,.qfield select:focus{outline:none;border-color:var(--accent,#0079C4);background:#fff;box-shadow:0 0 0 3px rgba(0,121,196,.12)}
.qhp{position:absolute!important;left:-9999px!important;width:1px;height:1px;opacity:0}
.qbtn{width:100%;justify-content:center;margin-top:8px;padding:15px}
.qfine{color:var(--faint,#90a0b2);font-size:12.5px;text-align:center;margin:14px 0 0}
.qmsg{margin:0 0 14px;font-size:14px;font-weight:600;padding:11px 14px;border-radius:10px}
.qmsg.err{color:#b42318;background:#fdeef0;border:1px solid #f3c6cd}
.qdone{text-align:center;max-width:620px;margin:30px auto;background:#fff;border:1px solid var(--line,#e6ecf2);border-radius:24px;padding:52px 34px;box-shadow:0 30px 70px -38px rgba(13,42,72,.4)}
.qdone-ic{width:68px;height:68px;border-radius:50%;background:#e9f8ef;color:#11703a;display:grid;place-items:center;font-size:34px;margin:0 auto 20px;border:1px solid #b7e6c8}
.qdone h2{font-size:27px;margin:0 0 10px}
.qdone p{color:var(--muted,#526174);max-width:480px;margin:0 auto 24px;line-height:1.6}
.qdone-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
@media(max-width:900px){.qsplit{grid-template-columns:1fr}.qside{padding:34px 28px}}
@media(max-width:560px){.qtwo{grid-template-columns:1fr}.qcard{padding:26px 22px}.qdone-row .btn{width:100%;justify-content:center}}
/* ===== SEO Case Studies ===== */
.cs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.cs-card{display:flex;flex-direction:column;background:var(--card,#fff);border:1px solid var(--line);border-radius:20px;padding:26px;box-shadow:0 24px 50px -40px rgba(8,20,35,.4);transition:.28s var(--ease)}
.cs-card:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:0 30px 60px -34px rgba(0,121,196,.35)}
.cs-top{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px}
.cs-ind{font-size:11.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:var(--accent-soft,#eaf3fb);padding:6px 11px;border-radius:30px}
.cs-pin{font-size:12.5px;color:var(--faint,#90a0b3)}
.cs-name{font-family:"Space Grotesk";font-size:24px;font-weight:600;letter-spacing:-.02em;margin:0 0 2px}
.cs-site{font-size:13px;color:var(--muted);margin-bottom:18px}
.cs-stats{display:flex;gap:22px;padding:16px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cs-stats b{font-family:"Space Grotesk";font-size:30px;color:var(--accent);display:block;line-height:1}
.cs-stats span{font-size:12px;color:var(--muted)}
.cs-kw{display:flex;flex-wrap:wrap;gap:7px;margin:16px 0}
.cs-chip{font-size:12px;background:#f3f7fb;border:1px solid var(--line);border-radius:30px;padding:5px 10px;color:var(--ink)}
.cs-chip i{color:var(--accent);font-style:normal;font-weight:700}
.cs-more{margin-top:auto;display:inline-flex;align-items:center;gap:7px;color:var(--accent);font-weight:600;font-size:14px}
.cs-more svg{width:15px;height:15px}
/* ===== Software Products (portfolio-style) ===== */
.prod-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.prod-card{position:relative;display:flex;flex-direction:column;background:var(--card,#fff);border:1px solid var(--line);border-radius:22px;padding:30px;overflow:hidden;box-shadow:0 24px 50px -40px rgba(8,20,35,.4);transition:.28s var(--ease)}
.prod-card::after{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,var(--accent),#36b1ff);opacity:0;transition:.28s var(--ease)}
.prod-card:hover{transform:translateY(-5px);border-color:var(--accent);box-shadow:0 34px 64px -34px rgba(0,121,196,.4)}
.prod-card:hover::after{opacity:1}
.prod-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.prod-ic{display:inline-flex;align-items:center;justify-content:center;width:54px;height:54px;border-radius:14px;background:var(--accent-glow,rgba(0,121,196,.1));color:var(--accent)}
.prod-ic svg{width:28px;height:28px}
.prod-badge{font-size:11.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--accent-d,#0061a0);background:var(--accent-glow,rgba(0,121,196,.1));padding:5px 11px;border-radius:999px}
.prod-cat{font-size:13px;font-weight:600;letter-spacing:.02em;color:var(--faint)}
.prod-name{font-family:"Space Grotesk";font-size:26px;font-weight:600;letter-spacing:-.02em;margin:3px 0 8px}
.prod-tag{color:var(--muted);font-size:15.5px;line-height:1.6;margin:0 0 22px}
.prod-more{margin-top:auto;display:inline-flex;align-items:center;gap:7px;color:var(--accent);font-weight:600;font-size:14.5px}
.prod-more svg{width:15px;height:15px;transition:transform .25s var(--ease)}
.prod-card:hover .prod-more svg{transform:translateX(4px)}
@media(max-width:720px){.prod-grid{grid-template-columns:1fr}}
/* in-page product callout (on relevant service pages) */
.prod-callout{display:flex;align-items:center;gap:18px;margin-top:34px;padding:22px 24px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(120deg,var(--accent-glow,rgba(0,121,196,.08)),#fff 70%);box-shadow:0 24px 50px -42px rgba(8,20,35,.4);transition:.26s var(--ease)}
.prod-callout:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 30px 58px -38px rgba(0,121,196,.4)}
.prod-callout .pc-ic{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:13px;background:#fff;border:1px solid var(--line);color:var(--accent)}
.prod-callout .pc-ic svg{width:27px;height:27px}
.prod-callout .pc-txt{display:flex;flex-direction:column;gap:2px;min-width:0}
.prod-callout .pc-ey{font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--accent-d,#0061a0)}
.prod-callout .pc-txt strong{font-family:"Space Grotesk";font-size:19px;letter-spacing:-.01em}
.prod-callout .pc-tag{color:var(--muted);font-size:14px}
.prod-callout .pc-go{flex:0 0 auto;margin-left:auto;display:inline-flex;align-items:center;gap:7px;color:var(--accent);font-weight:600;font-size:14px;white-space:nowrap}
.prod-callout .pc-go svg{width:15px;height:15px}
@media(max-width:640px){.prod-callout{flex-wrap:wrap}.prod-callout .pc-go{margin-left:0;width:100%}}
/* ===== Themed product page ===== */
.prod-hero .prod-pill{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--accent-d,#0061a0);background:var(--accent-glow,rgba(0,121,196,.1));padding:7px 15px;border-radius:999px;margin-bottom:8px}
.prod-hero h1{font-size:clamp(34px,4.6vw,56px);font-weight:600;letter-spacing:-.03em;margin:10px 0 0;max-width:18ch}
.prod-hero p{margin-top:16px;color:var(--muted);font-size:18px;max-width:600px}
.prod-hcta{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
.prod-bul{display:flex;gap:22px;flex-wrap:wrap;margin-top:22px}
.prod-bul span{display:inline-flex;align-items:center;gap:7px;font-size:14.5px;font-weight:500;color:var(--ink)}
.prod-bul .ck-ic{width:17px;height:17px;color:#16a34a}
.feat2 h3{font-family:"Space Grotesk";font-size:18px;font-weight:600;letter-spacing:-.01em;margin:0 0 5px}
.prc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:start}
.prc-card{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:20px;padding:30px 28px;box-shadow:0 24px 50px -42px rgba(8,20,35,.4);transition:.26s var(--ease)}
.prc-card.featured{border-color:var(--accent);box-shadow:0 30px 60px -34px rgba(0,121,196,.4);transform:translateY(-6px)}
.prc-card:hover{transform:translateY(-4px);border-color:var(--accent)}
.prc-card.featured:hover{transform:translateY(-9px)}
.prc-tag{position:absolute;top:-12px;left:28px;background:var(--accent);color:#fff;font-size:12px;font-weight:700;letter-spacing:.03em;padding:5px 13px;border-radius:999px}
.prc-card h3{font-family:"Space Grotesk";font-size:23px;font-weight:600;margin:0 0 6px}
.prc-desc{color:var(--muted);font-size:14.5px;margin:0 0 18px;min-height:42px}
.prc-feats{list-style:none;margin:0 0 24px;padding:0;display:flex;flex-direction:column;gap:11px}
.prc-feats li{display:flex;align-items:flex-start;gap:9px;font-size:14.5px;color:var(--ink);line-height:1.5}
.prc-feats .ck-ic{flex:0 0 auto;width:17px;height:17px;margin-top:3px;color:#16a34a}
.prc-card .btn{margin-top:auto;width:100%;justify-content:center}
.prc-note{text-align:center;color:var(--faint);font-size:14px;margin-top:24px}
.prc-grid.one{grid-template-columns:minmax(0,440px);justify-content:center}
.prc-grid.two{grid-template-columns:repeat(2,minmax(0,400px));justify-content:center}
@media(max-width:900px){.prc-grid,.prc-grid.one,.prc-grid.two{grid-template-columns:1fr;max-width:440px;margin:0 auto}.prc-card.featured{transform:none}}
/* product hero grid + interface mockup */
.prod-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center}
.prod-hero.has-mock h1{max-width:14ch}
.prod-hero-mock{position:relative}
.pmk-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:0 40px 80px -50px rgba(8,20,35,.55);overflow:hidden}
.pmk-top{display:flex;align-items:center;gap:7px;padding:13px 16px;background:linear-gradient(90deg,var(--accent),#36b1ff)}
.pmk-top span{width:11px;height:11px;border-radius:50%;background:rgba(255,255,255,.6)}
.pmk-top .pmk-ttl{margin-left:10px;color:#fff;font-size:13px;font-weight:600;letter-spacing:.01em}
.pmk-body{padding:18px;display:flex;flex-direction:column;gap:12px}
.pmk-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.pmk-stats div{background:var(--bg2,#f4f6fb);border:1px solid var(--line);border-radius:12px;padding:12px 14px}
.pmk-stats b{display:block;font-family:"Space Grotesk";font-size:24px;font-weight:600;color:var(--accent-d,#0061a0);line-height:1}
.pmk-stats span{font-size:11px;color:var(--faint);text-transform:uppercase;letter-spacing:.04em}
.pmk-row{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:11px 13px}
.pmk-av{flex:0 0 auto;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--accent),#36b1ff)}
.pmk-info{flex:1;min-width:0}
.pmk-info b{display:block;font-size:14px;font-weight:600}
.pmk-info span{font-size:11.5px;color:var(--faint)}
.pmk-pill{font-style:normal;font-size:11px;font-weight:600;padding:4px 10px;border-radius:999px}
.pmk-pill.green{color:#0a7a3d;background:#e3f6ec}
.pmk-pill.blue{color:#0061a0;background:#e2f0fb}
.pmk-float{position:absolute;left:-14px;bottom:-16px;display:flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:11px 15px;box-shadow:0 24px 44px -26px rgba(8,20,35,.5)}
.pmk-float .pmk-qr{flex:0 0 auto;width:34px;height:34px;border-radius:7px;background:conic-gradient(#0b1422 25%,#fff 0 50%,#0b1422 0 75%,#fff 0);background-size:8px 8px}
.pmk-float b{display:block;font-size:13px;color:#0a7a3d}
.pmk-float span{font-size:11px;color:var(--faint)}
@media(max-width:860px){.prod-hero-grid{grid-template-columns:1fr;gap:34px}.prod-hero.has-mock h1{max-width:18ch}.prod-hero-mock{max-width:440px}}
/* tight stats band on product pages */
.prod-stats{padding:30px 0 0}
.prod-stats .cs-band{margin-bottom:0}
/* second interface showcase (two-column) */
.prod-show{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}
.prod-show-copy h2{font-size:clamp(26px,3vw,36px);font-weight:600;letter-spacing:-.02em;margin:0 0 12px;font-family:"Space Grotesk"}
.prod-show-sub{color:var(--muted);font-size:16.5px;line-height:1.65;margin:0 0 20px}
.prod-show-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:13px}
.prod-show-list li{display:flex;align-items:flex-start;gap:10px;font-size:15.5px;color:var(--ink);line-height:1.55}
.prod-show-list .ck-ic{flex:0 0 auto;width:18px;height:18px;margin-top:3px;color:#16a34a}
/* certificate mockup */
.cert-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:14px;padding:30px 28px;box-shadow:0 40px 80px -50px rgba(8,20,35,.55);max-width:460px}
.cert-card::before{content:"";position:absolute;inset:8px;border:1.5px solid var(--accent-glow,rgba(0,121,196,.25));border-radius:9px;pointer-events:none}
.cert-rib{display:inline-block;font-family:"Fraunces",serif;font-size:18px;font-weight:600;color:var(--accent-d,#0061a0);border-bottom:2px solid var(--accent);padding-bottom:5px;margin-bottom:16px}
.cert-inst b{display:block;font-size:15px;letter-spacing:.04em}
.cert-inst span{font-size:11.5px;color:var(--faint)}
.cert-body{font-size:13.5px;color:var(--muted);line-height:1.7;margin:16px 0 20px}
.cert-foot{display:flex;align-items:flex-end;justify-content:space-between;gap:18px}
.cert-qr{width:58px;height:58px;border-radius:8px;background:conic-gradient(#0b1422 25%,#fff 0 50%,#0b1422 0 75%,#fff 0);background-size:11px 11px;border:3px solid #fff;box-shadow:0 0 0 1px var(--line)}
.cert-sign{text-align:center}
.cert-line{display:block;width:130px;border-top:1.5px solid var(--ink);margin-bottom:5px}
.cert-sign small{font-size:11px;color:var(--faint)}
@media(max-width:860px){.prod-show{grid-template-columns:1fr;gap:30px}.prod-show-mock{max-width:460px}}
/* detail */
.cs-hero{padding:104px 0 40px}
.sec.cs-stats-sec{padding-top:18px}
@media(max-width:768px){.cs-hero{padding:84px 0 30px}.sec.cs-stats-sec{padding-top:12px}}
.cs-hero h1{font-size:clamp(30px,3.5vw,44px);line-height:1.12;letter-spacing:-.02em;max-width:26ch;margin-top:10px}
.cs-hero .ey2{margin-bottom:2px}
.cs-hero p{margin-top:12px;font-size:16px}
.cs-band{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;background:linear-gradient(160deg,#0b1422,#16273c);border-radius:20px;padding:30px;color:#fff;margin-bottom:40px}
.cs-band b{font-family:"Space Grotesk";font-size:clamp(30px,4vw,46px);color:#fff;display:block;line-height:1}
.cs-band div:nth-child(2) b,.cs-band div:nth-child(1) b{color:#5fb6ec}
.cs-band span{font-size:13px;color:#9fb6cd}
.cs-detail{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:start}
.cs-summary h2{font-family:"Fraunces",Georgia,serif;font-weight:400;font-size:clamp(28px,3.4vw,42px);margin-bottom:14px}
.cs-summary p{color:var(--muted);font-size:16px;line-height:1.6}
.cs-ranks{background:var(--card,#fff);border:1px solid var(--line);border-radius:18px;padding:24px}
.cs-ranks h3{font-family:"Space Grotesk";font-size:18px;margin-bottom:14px}
.cs-rank-list{list-style:none;margin:0;padding:0}
.cs-rank-list li{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line);font-size:14.5px}
.cs-rank-list li:last-child{border-bottom:0}
.cs-rank-list .ck{font-weight:500;color:var(--ink)}
.cs-rank-list .cp{flex:0 0 auto;font-family:"Space Grotesk";font-weight:700;font-size:13px;background:#eef2f6;color:var(--muted);border-radius:20px;padding:4px 11px}
.cs-rank-list .cp.p3{background:#e3f2ff;color:var(--accent)}
.cs-rank-list .cp.p1{background:#e6f7ed;color:#13854a}
.cs-note{font-size:12px;color:var(--faint);margin-top:14px;line-height:1.5}
@media(max-width:980px){.cs-grid{grid-template-columns:1fr 1fr}.cs-detail{grid-template-columns:1fr;gap:26px}}
@media(max-width:680px){.cs-band{grid-template-columns:1fr 1fr;gap:20px}}
@media(max-width:560px){.cs-grid{grid-template-columns:1fr}}
/* Homepage software-services shortcuts */
.soft-chips{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.soft-chip{display:flex;align-items:center;gap:12px;padding:15px 18px;background:var(--card,#fff);border:1px solid var(--line);border-radius:14px;transition:.25s var(--ease)}
.soft-chip:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 22px 44px -30px rgba(0,121,196,.45)}
.soft-chip .sc-ic{width:38px;height:38px;flex:0 0 auto;display:grid;place-items:center;border-radius:10px;background:var(--accent-soft,#eaf3fb);color:var(--accent)}
.soft-chip .sc-ic svg{width:19px;height:19px}
.soft-chip .sc-t{flex:1;margin:0;font-family:inherit;font-weight:600;font-size:15px;line-height:1.3;color:var(--ink)}
.soft-chip .sc-ar{flex:0 0 auto;color:var(--faint,#90a0b3);transition:.25s var(--ease)}
.soft-chip .sc-ar svg{width:16px;height:16px}
.soft-chip:hover .sc-ar{color:var(--accent)}
@media(max-width:900px){.soft-chips{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.soft-chips{grid-template-columns:1fr}}
/* Resources / free-tools grid */
.rgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.rcard{display:flex;flex-direction:column;background:var(--card,#fff);border:1px solid var(--line);border-radius:18px;padding:26px;box-shadow:0 24px 50px -40px rgba(8,20,35,.4);transition:.28s var(--ease)}
.rcard:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:0 30px 60px -34px rgba(0,121,196,.35)}
.rcard .ric{width:52px;height:52px;display:grid;place-items:center;border-radius:14px;background:var(--accent-soft,#eaf3fb);color:var(--accent);font-size:24px;margin-bottom:16px}
.rcard h3{font-size:19px;margin-bottom:8px}
.rcard p{color:var(--muted);font-size:14.5px;line-height:1.55;flex:1}
.rcard .rmore{display:inline-flex;align-items:center;gap:8px;margin-top:16px;color:var(--accent);font-weight:600;font-size:14px}
.rcard .rmore .ico{width:30px;height:30px;border-radius:50%;background:var(--accent-soft,#eaf3fb);color:var(--accent);display:grid;place-items:center;transition:.3s var(--ease);flex:0 0 auto}
.rcard .rmore .ico svg{width:15px;height:15px}
.rcard:hover .rmore .ico{background:var(--accent);color:#fff;transform:rotate(45deg)}
@media(max-width:900px){.rgrid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.rgrid{grid-template-columns:1fr}}
/* ===== Homepage hero slider ===== */
.hsl{position:relative;overflow:hidden;background:linear-gradient(180deg,#f4f7fb 0%,#eaf2fa 100%)}
.hsl-track{position:relative;min-height:min(78vh,640px)}
.hsl-slide{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity .7s var(--ease);display:flex;align-items:center}
.hsl-slide.on{opacity:1;visibility:visible;position:relative}
.hsl-in{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;padding:48px 0 78px}
.hsl-copy{max-width:560px}
.hsl-tag{display:inline-block;font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);background:var(--accent-soft,#eaf3fb);padding:8px 16px;border-radius:30px;margin-bottom:22px;opacity:0;transform:translateY(14px)}
.hsl-h{display:block;font-family:var(--ff-head,'Space Grotesk'),sans-serif;font-weight:700;font-size:clamp(34px,4vw,54px);line-height:1.08;letter-spacing:-.025em;margin-bottom:18px;opacity:0;transform:translateY(18px)}
.hsl-p{font-size:clamp(15px,1.5vw,18px);color:var(--muted);max-width:540px;line-height:1.6;margin-bottom:30px;opacity:0;transform:translateY(18px)}
.hsl-cta{display:flex;gap:14px;flex-wrap:wrap;opacity:0;transform:translateY(18px)}
.hsl-slide.on .hsl-tag{animation:hslUp .6s .15s forwards}
.hsl-slide.on .hsl-h{animation:hslUp .6s .28s forwards}
.hsl-slide.on .hsl-p{animation:hslUp .6s .42s forwards}
.hsl-slide.on .hsl-cta{animation:hslUp .6s .56s forwards}
@keyframes hslUp{to{opacity:1;transform:none}}
.hsl-media{position:relative}
.hsl-media img{width:100%;height:auto;max-height:440px;object-fit:cover;border-radius:22px;box-shadow:0 40px 80px -40px rgba(8,20,35,.45);opacity:0;transform:scale(.96)}
.hsl-slide.on .hsl-media img{animation:hslImg .8s .2s forwards}
@keyframes hslImg{to{opacity:1;transform:none}}
.hsl-ph{aspect-ratio:4/3;border-radius:22px;background:radial-gradient(circle at 30% 25%,#3ea3e0,#0079C4 60%,#015a96);display:grid;place-items:center;box-shadow:0 40px 80px -40px rgba(0,121,196,.6)}
.hsl-ph span{font-family:var(--ff-head,'Space Grotesk');font-weight:700;font-size:90px;color:#fff;opacity:.9}
.hsl-arr{position:absolute;top:50%;transform:translateY(-50%);z-index:6;width:50px;height:50px;border-radius:50%;border:1px solid var(--line);background:rgba(255,255,255,.85);backdrop-filter:blur(6px);color:var(--ink);font-size:26px;line-height:1;cursor:pointer;display:grid;place-items:center;transition:.25s var(--ease)}
.hsl-arr:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.hsl-arr.prev{left:22px}.hsl-arr.next{right:22px}
.hsl-dots{position:absolute;bottom:24px;left:0;right:0;display:flex;gap:10px;justify-content:center;z-index:6}
.hsl-dot{width:10px;height:10px;border-radius:50%;border:0;background:#c4d3e2;cursor:pointer;transition:.25s var(--ease)}
.hsl-dot.on{background:var(--accent);width:30px;border-radius:6px}
@media(max-width:900px){
  .hsl,.hsl-slide.on{display:block}
  .hsl-track{min-height:auto}
  .hsl-in{grid-template-columns:1fr;gap:22px;padding:26px 0 6px;text-align:center}
  .hsl-tag{margin-bottom:16px}
  .hsl-h{font-size:clamp(27px,7vw,38px);margin-bottom:14px}
  .hsl-p{margin:0 auto 22px;font-size:15px}
  .hsl-cta{justify-content:center;gap:10px}
  .hsl-media{order:-1}
  .hsl-media img,.hsl-ph{max-height:230px;object-position:center}
  .hsl-arr{display:none!important}
  /* dots flow below the slide (no overlap with wrapped buttons) */
  .hsl-dots{position:static;bottom:auto;margin:16px auto 28px}
}
@media(max-width:480px){
  .hsl-cta .btn .txt{height:48px;padding:0 20px;font-size:14px}
  .hsl-cta .btn .ico{width:48px;height:48px}
  .hsl-media img,.hsl-ph{max-height:200px;border-radius:16px}
}
/* hero browser */
.hero-stage{position:relative;margin:58px auto 0;max-width:960px}
.spin{position:absolute;left:-46px;top:-46px;width:112px;height:112px;z-index:5}
.spin svg.ring{width:100%;height:100%;animation:spin 14s linear infinite}
.spin text{font-family:"Space Grotesk";font-size:9px;letter-spacing:.3em;fill:var(--ink);text-transform:uppercase;font-weight:600}
.spin .mid{position:absolute;inset:0;display:grid;place-items:center}
.spin .mid span{width:44px;height:44px;border-radius:50%;background:var(--accent);display:grid;place-items:center}
.spin .mid svg{width:18px;height:18px}
@keyframes spin{to{transform:rotate(360deg)}}
.browser{border-radius:20px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);background:#fff}
.b-bar{display:flex;align-items:center;gap:13px;padding:13px 16px;background:var(--bg2);border-bottom:1px solid var(--line)}
.b-dots{display:flex;gap:7px}.b-dots i{width:11px;height:11px;border-radius:50%;display:block}
.b-dots i:nth-child(1){background:#ff5f57}.b-dots i:nth-child(2){background:#febc2e}.b-dots i:nth-child(3){background:#28c840}
.b-url{flex:1;min-width:0;background:#fff;border:1px solid var(--line);border-radius:100px;padding:6px 14px;font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:7px;overflow:hidden}
.b-url .lk{color:#28c840;font-size:11px}
.b-url .tp{display:inline-block;overflow:hidden;white-space:nowrap;width:0;border-right:1.5px solid var(--accent);animation:tpurl 6.5s var(--ease) infinite}
@keyframes tpurl{0%{width:0}22%{width:12.5em}88%{width:12.5em}100%{width:0}}
.b-body{display:grid;grid-template-columns:1.05fr .95fr;min-height:300px}
.code{background:#0C1A28;padding:22px 20px;display:flex;flex-direction:column;gap:13px}
.cl{display:flex;gap:6px}.cl.i1{padding-left:18px}.cl.i2{padding-left:36px}
.cl .t{height:9px;border-radius:4px;transform-origin:left;transform:scaleX(0);opacity:0;animation:tp 6.5s var(--ease) infinite}
.cl:nth-child(1) .t{animation-delay:.2s}.cl:nth-child(2) .t{animation-delay:.7s}.cl:nth-child(3) .t{animation-delay:1.2s}.cl:nth-child(4) .t{animation-delay:1.7s}.cl:nth-child(5) .t{animation-delay:2.2s}.cl:nth-child(6) .t{animation-delay:2.7s}.cl:nth-child(7) .t{animation-delay:3.2s}
.tg{background:#7FC5EC}.ky{background:#2E9BE0}.st{background:#8BD6A0}.fn{background:#E6B566}.mu{background:rgba(255,255,255,.22)}
@keyframes tp{0%{transform:scaleX(0);opacity:0}6%{opacity:1}10%{transform:scaleX(1)}90%{transform:scaleX(1);opacity:1}97%,100%{opacity:0;transform:scaleX(1)}}
.prev{background:#fff;padding:18px;display:flex;flex-direction:column;gap:10px}
.pb{border-radius:6px;background:var(--bg2);opacity:0;transform:translateY(12px);animation:asm 6.5s var(--ease) infinite}
.pb.nav{height:14px;background:var(--grad);animation-delay:.5s}
.pb.h1{height:14px;width:78%;background:var(--ink);animation-delay:1.1s}
.pb.h2{height:9px;width:54%;animation-delay:1.5s}
.pb.img{height:74px;background:var(--accent-soft);position:relative;overflow:hidden;animation-delay:2s}
.pb.img::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.6) 50%,transparent 70%);transform:translateX(-100%);animation:shine 2.6s var(--ease) infinite;animation-delay:2.6s}
.pb.ln{height:8px;animation-delay:2.5s}.pb.ln.s{width:66%;animation-delay:2.8s}
.pb.bt{height:18px;width:74px;border-radius:100px;background:var(--accent);margin-top:4px;animation-delay:3.2s}
@keyframes asm{0%,8%{opacity:0;transform:translateY(12px)}14%{opacity:1;transform:none}90%{opacity:1}97%,100%{opacity:0;transform:translateY(6px)}}
@keyframes shine{to{transform:translateX(100%)}}
.fcard{position:absolute;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 18px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1px;z-index:4}
.fcard .b{font-family:"Space Grotesk";font-size:24px;color:var(--accent);line-height:1}
.fcard .l{font-size:12px;color:var(--muted);font-weight:500}
.fc1{right:-30px;top:90px;animation:flo 5s ease-in-out infinite}
.fc2{left:-24px;bottom:60px;animation:flo 6s ease-in-out infinite reverse}
@keyframes flo{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* ============ MARQUEE ============ */
.mq{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:24px 0;overflow:hidden}
.mq-t{display:flex;width:max-content;animation:mqx 24s linear infinite}
.mq-t span{font-family:"Space Grotesk";font-weight:600;font-size:clamp(26px,3.6vw,46px);letter-spacing:-.02em;white-space:nowrap;display:inline-flex;align-items:center}
.mq-t span::after{content:"✱";color:var(--accent);font-size:.55em;margin:0 36px}
@keyframes mqx{to{transform:translateX(-50%)}}

/* logos */
.logos{padding:56px 0;background:var(--bg2)}
.logos .lab{text-align:center;color:var(--faint);font-size:13px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-bottom:30px}
.logo-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:28px 48px;max-width:920px;margin:0 auto}
.logo-row img{height:30px;width:auto;object-fit:contain;opacity:.5;filter:grayscale(1);transition:.3s var(--ease)}
.logo-row img:hover{opacity:1;filter:none}

/* sections */
.sec{padding:80px 0}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap;margin-bottom:40px}
.sec-head h2,.sec-head .thead{font-size:clamp(34px,5vw,68px);font-weight:600;letter-spacing:-.03em}
.thead{display:block}
.sec-head p{max-width:430px;color:var(--muted);font-size:16.5px}

/* about */
.about{background:var(--bg2)}
.statement{font-family:"Space Grotesk";font-weight:500;font-size:clamp(26px,3.4vw,46px);line-height:1.16;letter-spacing:-.02em;max-width:1040px;margin-top:24px}
.statement b{color:var(--accent);font-weight:600}.statement .mut{color:var(--faint)}
.about-row{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap;margin-top:50px}
.about-row p{max-width:480px;color:var(--muted)}
.counters{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;margin-top:70px;padding-top:54px;border-top:1px solid var(--line)}
.cnt .n{font-family:"Space Grotesk";font-weight:600;font-size:clamp(38px,5vw,66px);letter-spacing:-.03em;line-height:1}
.cnt .n .p{color:var(--accent)}
.cnt .l{margin-top:10px;color:var(--muted);font-size:14.5px;font-weight:500}

/* services hover rows + cursor image */
.svc{border-top:1px solid var(--line)}
.srow{display:grid;grid-template-columns:74px 1fr minmax(0,320px) auto;align-items:center;gap:28px;padding:34px 24px;border-bottom:1px solid var(--line);position:relative;overflow:hidden;transition:.4s var(--ease)}
.srow .num{font-family:"Space Grotesk";font-size:16px;color:var(--faint);font-weight:600}
.srow .ttl{font-family:"Space Grotesk";font-weight:600;font-size:clamp(22px,2.7vw,38px);letter-spacing:-.02em;transition:.3s var(--ease)}
.srow .desc{color:var(--muted);font-size:14.5px;line-height:1.55;max-width:320px;transition:color .3s var(--ease)}
.srow:hover .desc{color:rgba(255,255,255,.72)}
.srow .go{width:52px;height:52px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;transition:.4s var(--ease)}
.srow .go svg{width:18px;height:18px}
.srow::before{content:"";position:absolute;inset:0;background:var(--ink);transform:translateY(101%);transition:transform .45s var(--ease);z-index:0}
.srow>*{position:relative;z-index:1}
.srow:hover::before{transform:translateY(0)}
.srow:hover .num{color:rgba(255,255,255,.5)}
.srow:hover .ttl{color:#fff;transform:translateX(10px)}
.srow:hover .go{background:var(--accent);border-color:var(--accent);color:#fff;transform:rotate(45deg)}
.svc-float{position:fixed;width:280px;height:188px;border-radius:14px;overflow:hidden;pointer-events:none;opacity:0;transform:translate(-50%,-50%) scale(.82) rotate(-4deg);transition:opacity .3s var(--ease),transform .3s var(--ease);z-index:120;box-shadow:var(--shadow)}
.svc-float.show{opacity:1;transform:translate(-50%,-50%) scale(1) rotate(-4deg)}
.svc-float img{width:100%;height:100%;object-fit:cover}
@media(pointer:coarse){.svc-float{display:none}}

/* works */
.works{background:var(--ink);color:#fff}
.works .sec-head h2,.works .sec-head .thead{color:#fff}.works .sec-head p{color:rgba(255,255,255,.6)}.works .tag{color:var(--accent-2)}
.wgrid{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.work{display:block;border-radius:20px;overflow:hidden;background:#151517;border:1px solid rgba(255,255,255,.08)}
.work .ph{aspect-ratio:16/11;overflow:hidden}
.work .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.work:hover .ph img{transform:scale(1.06)}
.work .meta{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:24px 26px}
.work .meta h3{font-size:23px}.work .meta .cat{font-size:13px;color:rgba(255,255,255,.55);margin-top:5px}
.work .meta .go{width:48px;height:48px;border-radius:50%;border:1px solid rgba(255,255,255,.2);display:grid;place-items:center;transition:.4s var(--ease)}
.work .meta .go svg{width:17px;height:17px}
.work:hover .meta .go{background:var(--accent);border-color:var(--accent);transform:rotate(45deg)}
.works-foot{text-align:center;margin-top:54px}

/* awards strip */
.awards{background:var(--bg2);padding:64px 0}
.awards .in{display:flex;align-items:center;gap:30px;flex-wrap:wrap;justify-content:center;text-align:center}
.awards .trophy{font-size:40px}
.awards .aw-txt{max-width:620px}
.awards .aw-txt b{font-family:"Space Grotesk";font-weight:600}
.awards .aw-txt span{display:block;color:var(--muted);font-size:15px;margin-top:6px}

/* testimonials */
.testi{background:var(--bg)}
.tgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}
.tq{background:var(--bg2);border:1px solid var(--line);border-radius:22px;padding:38px;transition:.35s var(--ease)}
.tq:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.tq .stars{color:var(--accent);letter-spacing:2px;font-size:15px;margin-bottom:16px}
.tq p{font-family:"Space Grotesk";font-weight:500;font-size:clamp(18px,2.1vw,23px);line-height:1.42;letter-spacing:-.01em;margin-bottom:26px}
.tq .who{display:flex;align-items:center;gap:14px}
.tq .who img{width:50px;height:50px;border-radius:50%;object-fit:cover}
.tq .who .nm{font-weight:600;font-size:15.5px}.tq .who .co{font-size:13.5px;color:var(--muted)}

/* CTA */
.cta{padding:130px 0;text-align:center;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:720px;height:720px;border-radius:50%;background:radial-gradient(circle,var(--accent-glow),transparent 64%)}
.cta .in{position:relative;z-index:1}
.cta .tag{margin-bottom:24px}
.cta h2,.cta .thead{font-size:clamp(44px,8vw,116px);font-weight:600;letter-spacing:-.04em;line-height:.98}
.cta .sub{max-width:520px;margin:26px auto 40px;color:var(--muted);font-size:18px}
.cta .row{display:flex;justify-content:center;gap:18px;flex-wrap:wrap}

/* footer */
.foot{background:var(--ink);color:rgba(255,255,255,.6);padding:80px 0 0}
.f-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;padding-bottom:50px;margin-bottom:46px;border-bottom:1px solid rgba(255,255,255,.12)}
.f-top .big{font-family:"Space Grotesk";font-weight:600;font-size:clamp(28px,4vw,54px);letter-spacing:-.03em;color:#fff;max-width:560px;line-height:1.05}
.f-top .big a{color:var(--accent-2)}
.f-reach{display:flex;flex-direction:column;gap:10px;align-items:flex-start}
.f-reach a{font-size:16px;color:rgba(255,255,255,.8);transition:.2s}.f-reach a:hover{color:#fff}
.f-cols{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:34px;padding-bottom:48px}
.f-brand img{height:42px;margin-bottom:18px}.f-brand p{font-size:14px;max-width:300px;line-height:1.6}
.f-col h4{font-family:"Space Grotesk";font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#fff;margin-bottom:18px}
.f-col ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.f-col a{font-size:14px;transition:.2s}.f-col a:hover{color:#fff}
.f-social{display:flex;gap:10px;margin-top:20px}
.f-social a{width:40px;height:40px;border:1px solid rgba(255,255,255,.18);border-radius:50%;display:grid;place-items:center;transition:.25s var(--ease)}
.f-social a:hover{background:var(--accent);border-color:var(--accent);transform:translateY(-3px)}
.f-social svg{width:16px;height:16px;fill:rgba(255,255,255,.8)}.f-social a:hover svg{fill:#fff}
.f-bottom{border-top:1px solid rgba(255,255,255,.12);padding:22px 0;display:flex;justify-content:space-between;align-items:center;gap:14px 24px;flex-wrap:wrap}
.f-bottom p{font-size:13px;color:rgba(255,255,255,.5)}
.f-bottom ul{list-style:none;display:flex;gap:20px;flex-wrap:wrap}
.f-bottom a{font-size:13px;transition:.2s}.f-bottom a:hover{color:#fff}

/* whatsapp */
.wa{position:fixed;left:22px;bottom:22px;z-index:650;width:58px;height:58px;border-radius:50%;background:#25D366;display:grid;place-items:center;box-shadow:0 10px 26px -8px rgba(37,211,102,.7);transition:.3s var(--ease)}
.wa:hover{transform:scale(1.08)}.wa svg{width:32px;height:32px;fill:#fff}

/* back-to-top rocket (sits above the WhatsApp button on the right) */
.totop{position:fixed;right:22px;bottom:22px;z-index:299;width:50px;height:50px;border:0;border-radius:50%;
  background:var(--ink);color:#fff;display:grid;place-items:center;cursor:pointer;overflow:visible;
  box-shadow:0 12px 26px -10px rgba(0,0,0,.55);
  opacity:0;visibility:hidden;transform:translateY(14px) scale(.85);transition:opacity .3s var(--ease),visibility .3s,transform .3s var(--ease),background .25s}
.totop.show{opacity:1;visibility:visible;transform:none}
.totop:hover{background:var(--accent);transform:translateY(-3px)}
.totop svg{width:24px;height:24px;position:relative;z-index:3;transition:transform .2s}
.totop:hover svg{transform:translateY(-2px)}
/* flame jet */
.totop .flame{position:absolute;left:50%;bottom:9px;width:9px;height:11px;z-index:2;
  border-radius:50% 50% 48% 48%/40% 40% 70% 70%;
  background:radial-gradient(120% 80% at 50% 20%,#fff6c2 0%,#ffd23f 35%,#ff7a18 75%,rgba(255,90,0,0) 100%);
  transform:translateX(-50%) scaleY(0);transform-origin:top center;opacity:0;filter:blur(.4px)}
/* smoke / cloud puffs at the launch pad */
.totop::before,.totop::after{content:"";position:absolute;bottom:3px;width:16px;height:16px;border-radius:50%;
  background:rgba(196,205,218,.9);opacity:0;z-index:1;pointer-events:none;filter:blur(1px)}
.totop::before{left:9px}.totop::after{right:9px}
/* launch sequence */
.totop.launch{animation:rocketLaunch .95s cubic-bezier(.45,-0.25,.55,1) forwards}
.totop.launch svg{animation:rocketWobble .95s ease-in-out}
.totop.launch .flame{animation:rocketFlame .95s ease-out forwards}
.totop.launch::before{animation:smokeL .9s ease-out forwards}
.totop.launch::after{animation:smokeR .9s ease-out forwards}
@keyframes rocketLaunch{
  0%{transform:translateY(0) scale(1)}
  12%{transform:translateY(4px) scale(.94)}        /* charge-up dip */
  24%{transform:translateY(5px) scale(.93)}
  42%{transform:translateY(-26px) scale(1.02)}     /* lift-off */
  100%{transform:translateY(-150vh) scale(.55)}    /* blast off */
}
@keyframes rocketWobble{0%,24%{transform:none}30%{transform:rotate(-3deg)}38%{transform:rotate(3deg)}46%{transform:rotate(0)}}
@keyframes rocketFlame{
  0%,16%{opacity:0;transform:translateX(-50%) scaleY(0)}
  30%{opacity:1;transform:translateX(-50%) scaleY(2.2)}
  60%{opacity:1;transform:translateX(-50%) scaleY(4)}
  100%{opacity:.5;transform:translateX(-50%) scaleY(5.5)}
}
@keyframes smokeL{0%,18%{opacity:0;transform:scale(.3)}30%{opacity:.95}100%{opacity:0;transform:scale(3) translate(-18px,12px)}}
@keyframes smokeR{0%,18%{opacity:0;transform:scale(.3)}30%{opacity:.95}100%{opacity:0;transform:scale(3) translate(18px,12px)}}
@media(prefers-reduced-motion:reduce){.totop.launch{animation:none;transform:translateY(8px) scale(.9)}.totop.launch .flame,.totop.launch::before,.totop.launch::after,.totop.launch svg{animation:none}}
@media(max-width:600px){.totop{right:18px;bottom:18px;width:46px;height:46px}.wa{left:16px;bottom:16px;width:52px;height:52px}.wa:hover{transform:scale(1.08)}}

/* reveal */
.rv{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.rv.in{opacity:1;transform:none}

/* responsive */
@media(max-width:1024px){
  .wrap{padding:0 28px}
  .counters{grid-template-columns:1fr 1fr;gap:30px 20px}
  .wgrid,.tgrid{grid-template-columns:1fr}
  .f-cols{grid-template-columns:1fr 1fr}
  .spin{left:-14px;top:-22px;width:88px;height:88px}
  .fc1{right:8px}.fc2{left:8px}
}
@media(max-width:760px){
  .nav .btn{display:none}
  .burger{display:flex}
  .mobcta{display:inline-flex}
  /* slide-from-top animated mobile menu */
  .menu{display:flex;position:fixed;top:86px;left:0;right:0;flex-direction:column;gap:2px;z-index:190;
    background:var(--bg);border-top:1px solid var(--line2);box-shadow:0 26px 44px -22px rgba(8,20,35,.4);
    padding:14px 26px 26px;
    max-height:calc(100vh - 86px);overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;
    transform:translateY(-14px);opacity:0;visibility:hidden;pointer-events:none;
    transition:transform .3s var(--ease),opacity .3s var(--ease),visibility .3s}
  .menu.open{transform:translateY(0);opacity:1;visibility:visible;pointer-events:auto}
  .menu li{opacity:0;transform:translateY(-6px);transition:.3s var(--ease)}
  .menu.open li{opacity:1;transform:none}
  .menu.open li:nth-child(1){transition-delay:.04s}.menu.open li:nth-child(2){transition-delay:.08s}
  .menu.open li:nth-child(3){transition-delay:.12s}.menu.open li:nth-child(4){transition-delay:.16s}
  .menu.open li:nth-child(5){transition-delay:.2s}.menu.open li:nth-child(6){transition-delay:.24s}
  .menu li{list-style:none}
  .menu>li{border-bottom:1px solid var(--line2)}
  .menu>li:last-child{border-bottom:0}
  .menu a{display:flex;align-items:center;justify-content:space-between;width:100%;
    font-size:16.5px;font-weight:600;line-height:1.2;padding:15px 2px;color:var(--ink)}
  .menu a::after{display:none!important}   /* kill desktop underline indicator */
  .menu a.active{color:var(--accent)}
  /* burger -> X */
  .burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .burger.open span:nth-child(2){opacity:0}
  .burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  /* dim page behind open menu */
  .navscrim{position:fixed;inset:0;background:rgba(8,20,35,.42);opacity:0;visibility:hidden;transition:.3s;z-index:40}
  body.menu-open .navscrim{opacity:1;visibility:visible}
  body.menu-open{overflow:hidden}
  .sec{padding:54px 0}
  .b-body{grid-template-columns:1fr}.code{display:none}
  .srow{grid-template-columns:44px 1fr auto;gap:14px;padding:24px 4px}
  .srow .desc{display:none}
  .srow:hover .ttl{transform:none}
  .f-cols{grid-template-columns:1fr 1fr}
}
@media(max-width:460px){.counters{grid-template-columns:1fr 1fr}.f-cols{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){
  .mq-t,.spin svg.ring,.cl .t,.pb,.pb.img::after,.b-url .tp,.lmq{animation:none}
  .cl .t{transform:none;opacity:1}.pb{opacity:1;transform:none}.b-url .tp{width:12.5em;border-right:0}
  .ab-stats .si svg *{transition:none;stroke-dashoffset:0}
  .rv{opacity:1;transform:none}
}

/* ===== sliding logo strip (bigger) ===== */
.logos2{padding:54px 0;background:var(--bg2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.logos2 .lab{text-align:center;color:var(--faint);font-size:13px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-bottom:32px}
.lstrip{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.lmq{display:flex;gap:64px;width:max-content;align-items:center;animation:lmqx 34s linear infinite}
.logos2:hover .lmq{animation-play-state:paused}
.lmq img{height:64px;width:auto;object-fit:contain;opacity:.62;filter:grayscale(1);transition:.3s var(--ease)}
.lmq img:hover{opacity:1;filter:none;transform:scale(1.06)}
@keyframes lmqx{to{transform:translateX(-50%)}}
@media(max-width:760px){.lmq{gap:44px}.lmq img{height:50px}}

/* ===== editorial about (SEO content) ===== */
.ab{background:var(--bg2)}
.ab-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:start}
.ey2{display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.ey2::before{content:"";width:22px;height:1.5px;background:var(--accent)}
.ab .acopy h1,.ab h2{font-family:"Fraunces",Georgia,serif;font-weight:400;font-size:clamp(32px,4vw,52px);letter-spacing:-.01em;line-height:1.05;margin:16px 0 22px}
.ab .acopy h1 i,.ab h2 i{font-style:italic;color:var(--accent)}
.ab .acopy p{color:var(--muted);font-size:16.5px;margin-bottom:18px}
.ab .acopy strong{color:var(--ink)}
.ab .ilink{color:var(--accent-d);font-weight:600;border-bottom:1px solid var(--accent-soft)}
.ab .acopy .btn{margin-top:8px}
.feat-col{display:flex;flex-direction:column;gap:20px;position:sticky;top:100px}
.feat2{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px;display:flex;gap:20px;align-items:flex-start;transition:.3s var(--ease);position:relative;overflow:hidden}
.feat2::before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:var(--g);transition:width .35s var(--ease)}
.feat2:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.feat2:hover::before{width:4px}
.feat2 .fi{width:54px;height:54px;border-radius:14px;background:var(--accent-soft);display:grid;place-items:center;flex-shrink:0}
.feat2 .fi img{width:30px;height:30px;object-fit:contain}
.feat2 h4,.feat2 h3,.feat2 .thead{font-family:"Space Grotesk";font-size:20px;margin-bottom:7px}
.feat2 p{color:var(--muted);font-size:14.5px;line-height:1.55;margin:0}
.feat2 em{color:var(--ink);font-style:normal;font-weight:600}
/* about stats band (dark) */
.ab-stats{background:var(--ink);border-radius:26px;padding:54px 30px;margin-top:64px;display:grid;grid-template-columns:repeat(4,1fr);position:relative;overflow:hidden}
.ab-stats::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.6;background:radial-gradient(circle at 14% 18%,rgba(30,155,255,.22),transparent 42%),radial-gradient(circle at 88% 92%,rgba(54,214,244,.16),transparent 44%)}
.ab-stat{text-align:center;padding:6px 16px;border-right:1px solid rgba(255,255,255,.14);color:#fff;position:relative;z-index:1}
.ab-stat:last-child{border-right:0}
.ab-stat .si{width:30px;height:30px;margin:0 auto 14px}
.ab-stat .si svg{width:30px;height:30px;stroke:var(--accent-2);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.ab-stat .si svg *{stroke-dasharray:90;stroke-dashoffset:90;transition:stroke-dashoffset 1.3s var(--ease) .3s}
.ab-stats.in .si svg *{stroke-dashoffset:0}
.ab-stat .num{font-family:"Space Grotesk";font-weight:600;font-size:clamp(38px,5vw,58px);line-height:1}
.ab-stat .num .p{color:var(--accent-2)}
.ab-stat .lbl{margin-top:10px;font-size:13px;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.05em;font-weight:600}

/* ===== light portfolio + blog cards ===== */
.cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.pcard{background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;transition:.35s var(--ease);display:block}
.pcard:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.pcard .ph{aspect-ratio:16/11;overflow:hidden;background:var(--bg2)}
.pcard .ph img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.pcard:hover .ph img{transform:scale(1.06)}
.pcard .bd{padding:22px 24px 26px}
.pcard .cat{font-size:12.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--accent-d)}
.pcard h3,.pcard .pc-ttl{font-family:"Space Grotesk";font-size:21px;margin-top:8px;line-height:1.25;font-weight:600}
.pcard:hover h3{color:var(--accent-d)}
.cards-foot{text-align:center;margin-top:50px}

/* ===== dark corporate footer ===== */
.dfoot{background:var(--ink);color:rgba(255,255,255,.62);padding:64px 0 0}
.df-top{display:flex;align-items:center;justify-content:space-between;gap:22px;flex-wrap:wrap;padding-bottom:34px;margin-bottom:42px;border-bottom:1px solid rgba(255,255,255,.12)}
.df-top .dlogo img{height:42px;width:auto}
.dsoc{display:flex;gap:10px}
.dsoc a{width:38px;height:38px;border:1px solid rgba(255,255,255,.18);border-radius:50%;display:grid;place-items:center;transition:.25s var(--ease)}
.dsoc a:hover{background:var(--accent);border-color:var(--accent);transform:translateY(-3px)}
.dsoc svg{width:15px;height:15px;fill:rgba(255,255,255,.8)}
.dsoc a:hover svg{fill:#fff}
.df-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:34px 28px;padding-bottom:44px}
.df-col .df-h{font-family:"Space Grotesk";font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#fff;margin-bottom:18px}
.df-col ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.df-col a{font-size:14px;color:rgba(255,255,255,.62);transition:.2s}
.df-col a:hover{color:var(--accent-2)}
.df-bottom{border-top:1px solid rgba(255,255,255,.12);padding:22px 0;display:flex;justify-content:space-between;align-items:center;gap:12px 26px;flex-wrap:wrap}
.df-bottom p{font-size:13px;color:rgba(255,255,255,.5)}
.df-bottom ul{list-style:none;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.df-bottom ul li{display:flex;align-items:center;gap:10px}
.df-bottom ul li+li::before{content:"·";color:rgba(255,255,255,.4)}
.df-bottom a{font-size:13px;color:rgba(255,255,255,.62);transition:.2s}.df-bottom a:hover{color:#fff}
.df-badges{display:flex;gap:10px;align-items:center;flex-wrap:wrap;font-size:12px;font-weight:600;letter-spacing:.01em}
.df-badges span{display:inline-flex;align-items:center;gap:7px;color:rgba(255,255,255,.8);background:linear-gradient(180deg,rgba(255,255,255,.09),rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:7px 14px 7px 11px;transition:.2s}
.df-badges span:hover{color:#fff;border-color:var(--accent-2,#3aa0e0);background:linear-gradient(180deg,rgba(0,121,196,.22),rgba(0,121,196,.06))}
.df-badges span svg{width:15px;height:15px;color:var(--accent-2,#3aa0e0);flex:none}

@media(max-width:980px){
  .ab-grid{grid-template-columns:1fr;gap:40px}
  .feat-col{position:static}
  .cards3{grid-template-columns:1fr 1fr}
  .df-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:760px){
  .ab-stats{grid-template-columns:1fr 1fr;gap:30px 0;padding:40px 20px}
  .ab-stat:nth-child(2){border-right:0}
  .ab-stat:nth-child(1),.ab-stat:nth-child(2){border-bottom:1px solid rgba(255,255,255,.14);padding-bottom:28px}
  .cards3{grid-template-columns:1fr}
  .df-grid{grid-template-columns:1fr 1fr}
}
/* mobile: collapse footer columns into tap-to-open accordions (keeps it short) */
@media(max-width:600px){
  .df-grid{grid-template-columns:1fr;gap:0;padding-bottom:18px}
  .df-col{border-bottom:1px solid rgba(255,255,255,.1)}
  .df-col .df-h{display:flex;align-items:center;justify-content:space-between;margin:0;padding:16px 2px;cursor:pointer}
  .df-col .df-h::after{content:"+";font-size:18px;font-weight:400;color:rgba(255,255,255,.6);transition:transform .25s}
  .df-col.open .df-h::after{content:"–"}
  .df-col ul{max-height:0;overflow:hidden;gap:0;transition:max-height .3s var(--ease)}
  .df-col.open ul{max-height:600px;padding-bottom:14px;gap:13px}
  .df-col ul li{padding:0}
  /* compact bottom bar: copyright + both badges side-by-side */
  .df-bottom{flex-direction:column;align-items:center;text-align:center;gap:12px;padding:18px 0 26px}
  .df-badges{justify-content:center;gap:8px}
  .df-badges span{font-size:11px;padding:6px 10px}
  .dfoot{padding-bottom:74px}   /* clear the floating WhatsApp / rocket buttons */
}

/* =========================================================
   Inner pages (About / Services / Portfolio / Contact)
   ========================================================= */
.phero{position:relative;padding:104px 0 64px;background:var(--bg2);border-bottom:1px solid var(--line);overflow:hidden}
.phero::before{content:"";position:absolute;top:-160px;right:-120px;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,var(--accent-glow),transparent 68%);pointer-events:none}
.phero .wrap{position:relative;z-index:1}
.bcrumb{display:flex;gap:8px;align-items:center;font-size:13.5px;color:var(--faint);margin-bottom:14px;flex-wrap:wrap}
.bcrumb a{transition:color .2s}.bcrumb a:hover{color:var(--accent-d)}.bcrumb span{opacity:.55}
.phero h1{font-size:clamp(38px,5.4vw,68px);font-weight:600;letter-spacing:-.03em;margin:12px 0 0;max-width:16ch}
.phero p{margin-top:18px;color:var(--muted);font-size:18px;max-width:580px}

.feat2 .fi svg{width:26px;height:26px;stroke:var(--accent);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.feat2 .pn{font-family:"Space Grotesk";font-weight:600;font-size:24px;color:transparent;-webkit-text-stroke:1.4px var(--accent);display:block}

/* portfolio filters */
.filters{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:46px}
.fbtn{height:44px;padding:0 22px;border-radius:100px;border:1px solid var(--line);background:#fff;color:var(--ink);font:inherit;font-weight:600;font-size:14px;cursor:pointer;transition:.25s var(--ease)}
.fbtn:hover{border-color:var(--ink)}
.fbtn.active{background:var(--ink);color:#fff;border-color:var(--ink)}

/* contact */
.cgrid{display:grid;grid-template-columns:1fr 1.1fr;gap:40px;align-items:start}
.cinfo{display:flex;flex-direction:column;gap:18px}
.cform{background:#fff;border:1px solid var(--line);border-radius:24px;padding:36px;box-shadow:var(--shadow-sm)}
.cform h3{font-family:"Space Grotesk";font-size:25px;margin-bottom:6px}
.cform .fnote{color:var(--muted);font-size:14.5px;margin-bottom:22px}
.cform .two{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.cform input,.cform select,.cform textarea{width:100%;padding:13px 16px;border:1px solid var(--line);border-radius:12px;font:inherit;font-size:15px;background:var(--bg2);color:var(--ink)}
.cform input::placeholder,.cform textarea::placeholder{color:var(--faint)}
.cform textarea{resize:vertical;margin-bottom:18px}
.cform select{margin-bottom:14px;color:var(--muted)}
.cform .ok{display:none;align-items:center;gap:8px;background:var(--accent-soft);color:var(--accent-d);border-radius:12px;padding:12px 16px;font-weight:600;font-size:14px;margin-bottom:18px}
.cform .btn{width:100%;justify-content:center}
.map{border-radius:24px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.map iframe{display:block;width:100%;height:380px;border:0}
@media(max-width:860px){.cgrid{grid-template-columns:1fr}.cform .two{grid-template-columns:1fr}}
/* category chips (portfolio + blog) */
.cat-chips{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 30px}
.cat-chips a{font-size:13.5px;font-weight:500;color:var(--muted);background:var(--bg2);border:1px solid var(--line);border-radius:30px;padding:8px 16px;transition:.2s}
.cat-chips a:hover{background:var(--accent);border-color:var(--accent);color:#fff}
/* contact intro (below map) */
.c-intro-h{font-family:"Space Grotesk";font-size:20px;font-weight:600;letter-spacing:-.01em}
.c-intro-body{color:var(--muted);font-size:14px;line-height:1.6;margin-top:6px}
.c-intro-body p{margin:0}
/* WhatsApp contact card */
.wa-card{display:flex;align-items:center;gap:16px;transition:.2s;cursor:pointer}
.wa-card .wa-fi{background:#25D366!important;color:#fff!important}
.wa-card .wa-fi svg{width:26px;height:26px;fill:#fff!important;stroke:none!important;color:#fff}
.wa-card h4{transition:.2s}
.wa-card .wa-go{display:inline-block;color:#25D366;font-weight:700;transition:transform .2s}
.wa-card:hover{border-color:#25D366;box-shadow:0 16px 34px -20px rgba(37,211,102,.6);transform:translateY(-2px)}
.wa-card:hover h4{color:#128C7E}
.wa-card:hover .wa-go{transform:translateX(4px)}

/* =========================================================
   Article / page body (WordPress content) — .prose
   ========================================================= */
.prose{max-width:820px;margin:0 auto;font-size:17px;line-height:1.75;color:var(--ink2)}
.prose > *{margin-bottom:20px}
.prose h2{font-family:"Space Grotesk";font-size:clamp(26px,3.2vw,38px);letter-spacing:-.02em;margin:42px 0 14px;line-height:1.15}
.prose h3{font-family:"Space Grotesk";font-size:clamp(20px,2.4vw,26px);margin:32px 0 12px}
.prose h4{font-family:"Space Grotesk";font-size:19px;margin:24px 0 10px}
.prose p{color:var(--muted)}
.prose strong{color:var(--ink)}
.prose a{color:var(--accent-d);border-bottom:1px solid var(--accent-soft)}
.prose a:hover{border-bottom-color:var(--accent)}
.prose ul,.prose ol{padding-left:22px;color:var(--muted)}
.prose li{margin-bottom:8px}
.prose img,.prose figure img{border-radius:14px;border:1px solid var(--line);width:100%;height:auto}
.prose figure{margin:28px 0}
.prose blockquote{border-left:3px solid var(--accent);padding:6px 20px;color:var(--ink2);font-style:italic}
.prose table{width:100%;border-collapse:collapse;font-size:15px}
.prose th,.prose td{border:1px solid var(--line);padding:10px 12px;text-align:left}
.prose iframe{max-width:100%;border-radius:14px}

/* listing grid reuse (pcard) already defined; date pill */
.meta-row{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:14px;margin-bottom:8px}

/* portfolio pagination */
.pager{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-items:center;margin-top:52px}
.pager .pg{min-width:44px;height:44px;padding:0 14px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:10px;font-weight:600;font-size:14px;color:var(--ink);background:#fff;transition:.25s var(--ease)}
.pager .pg:hover{border-color:var(--ink)}
.pager .pg.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.pager .dots{color:var(--faint);padding:0 4px}
.pager-info{text-align:center;color:var(--muted);font-size:14px;margin-top:16px}

/* ===== Portfolio: big search + full-image masonry ===== */
.pf-search{max-width:720px;margin:0 auto}
.pf-search form{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:100px;padding:8px 8px 8px 22px;box-shadow:var(--shadow);transition:.25s var(--ease)}
.pf-search form:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft),var(--shadow)}
.pf-search .si{width:22px;height:22px;color:var(--faint);flex-shrink:0}
.pf-search input{flex:1;min-width:0;border:0;background:none;font:inherit;font-size:16.5px;color:var(--ink);outline:none;padding:14px 4px}
.pf-search input::placeholder{color:var(--faint)}
.pf-search button{flex-shrink:0;border:0;cursor:pointer;height:50px;padding:0 30px;border-radius:100px;background:var(--accent);color:#fff;font:inherit;font-weight:600;font-size:15px;transition:.25s var(--ease)}
.pf-search button:hover{background:var(--ink)}
.pf-result{text-align:center;margin-top:18px;color:var(--muted);font-size:15px}
.pf-result a{color:var(--accent-d);font-weight:600;margin-left:4px}

.pf-masonry{column-count:3;column-gap:24px}
@media(max-width:980px){.pf-masonry{column-count:2}}
@media(max-width:600px){.pf-masonry{column-count:1}}
.pf-item{break-inside:avoid;-webkit-column-break-inside:avoid;display:block;margin:0 0 24px;background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:.35s var(--ease)}
.pf-item:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.pf-item img{width:100%;height:auto;display:block}
.pf-item .bd{padding:16px 18px 18px}
.pf-item .cat{font-size:11.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--accent-d)}
.pf-item h3,.pf-item .pf-ttl{font-family:"Space Grotesk";font-size:18px;margin-top:6px;line-height:1.3;font-weight:600}
.pf-item .pf-ttl{display:flex;align-items:center;justify-content:space-between;gap:10px}
.pf-item .pf-ar{flex:none;width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:var(--accent,#0079C4);color:#fff;transform:translate(2px,2px) scale(.92);opacity:.85;transition:.25s}
.pf-item .pf-ar svg{width:15px;height:15px}
.pf-item:hover .pf-ar{transform:translate(0,0) scale(1);opacity:1}
.pf-item:hover h3{color:var(--accent-d)}

/* project detail meta (client / services / link) */
.proj-meta{display:flex;flex-wrap:wrap;gap:14px 30px;margin-top:22px}
.proj-meta .pm{display:flex;flex-direction:column;gap:3px;font-size:15px;color:var(--ink)}
.proj-meta .pm .k{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-d)}

/* project: big image first, title + meta below */
.proj-hero-img{border-radius:20px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);margin-bottom:34px}
.proj-hero-img img{width:100%;height:auto;display:block}
.proj-head{max-width:820px;margin:0 auto 10px}
.proj-head h1{font-size:clamp(32px,4.6vw,56px);font-weight:600;letter-spacing:-.03em;line-height:1.03}
.proj-head .proj-meta{margin-top:20px}

/* content-end project CTA band */
.proj-cta{max-width:820px;margin:46px auto 0;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  background:var(--accent-soft);border:1px solid var(--accent-soft);border-radius:20px;padding:30px 34px}
.proj-cta h3{font-family:"Space Grotesk";font-size:clamp(20px,2.4vw,26px);letter-spacing:-.01em;line-height:1.2}
.proj-cta p{color:var(--muted);font-size:15px;margin-top:6px}
@media(max-width:600px){.proj-cta{padding:24px}}

/* ===== Services mega menu ===== */
.menu li.has-mega{position:static}
.menu .has-mega>a .caret{font-size:9px;margin-left:4px;display:inline-block;transition:transform .25s var(--ease);color:var(--faint)}
.menu .has-mega:hover>a .caret{transform:rotate(180deg);color:var(--accent)}
.mega{position:absolute;left:0;right:0;top:100%;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);box-shadow:0 24px 50px -24px rgba(11,11,12,.28);opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .25s var(--ease),transform .25s var(--ease),visibility .25s;z-index:190}
.menu .has-mega:hover .mega{opacity:1;visibility:visible;transform:none}
.mega-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:30px 34px;padding:34px 40px 28px}
.mega-foot{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;padding:18px 40px;border-top:1px solid var(--line);background:var(--bg2)}
.mega-foot .mf-left{font-size:14.5px;color:var(--muted)}
.mega-foot .mf-left strong{color:var(--ink);font-weight:600}
.mega-foot .btn .txt{height:46px}.mega-foot .btn .ico{width:46px;height:46px}
.mega-col .mega-h{font-family:"Space Grotesk";font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-d);margin-bottom:15px}
.mega-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.mega-col li{margin:0}
.mega-col a{font-size:14px;color:var(--muted);transition:color .2s,padding .2s;display:block;padding:0}
.mega-col a:hover{color:var(--accent-d);padding-left:4px}
.mega-promo{background:var(--accent-soft);border-radius:16px;padding:24px}
.mega-promo h4{font-family:"Space Grotesk";font-size:18px;letter-spacing:-.01em;color:var(--ink);text-transform:none;margin-bottom:8px}
.mega-promo p{font-size:13.5px;color:var(--muted);line-height:1.5;margin-bottom:16px}
.mega-promo .btn .txt{height:46px}
.mega-promo .btn .ico{width:46px;height:46px}
@media(max-width:1024px){.mega-inner{grid-template-columns:1fr 1fr;gap:26px}}
@media(max-width:760px){
  /* Services becomes a tap-to-expand accordion */
  .menu .has-mega>a{display:flex;align-items:center;justify-content:space-between}
  .menu .has-mega>a .caret{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;margin:0;font-size:12px;border-radius:8px;background:var(--accent-soft);color:var(--accent)}
  .menu .has-mega.sub-open>a .caret{transform:rotate(180deg)}
  .mega{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;background:transparent;display:none}
  .menu .has-mega.sub-open .mega{display:block}
  .mega-inner{display:block;padding:6px 0 4px}
  .mega-col{margin:0}
  .mega-col .mega-h{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--accent);margin:12px 0 4px}
  .mega-col ul{display:block}
  .mega-col ul li a{display:block;padding:9px 0 9px 12px;font-size:15px;border-bottom:1px solid var(--line2);color:var(--muted)}
  .mega-foot{display:none}
}

/* ===== Sitemap ===== */
.sm-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:34px}
.sm-col h4{font-family:"Space Grotesk";font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--accent-d);margin-bottom:14px}
.sm-col ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.sm-col a{font-size:14px;color:var(--muted);transition:.2s}
.sm-col a:hover{color:var(--accent-d);padding-left:3px}
@media(max-width:980px){.sm-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.sm-grid{grid-template-columns:1fr}}

/* ===== Reviews ===== */
.rev-hero{display:flex;align-items:center;gap:30px;flex-wrap:wrap;margin-top:30px}
.rev-score{display:flex;flex-direction:column;gap:2px}
.rev-score .num{font-family:"Space Grotesk";font-size:46px;font-weight:600;line-height:1}
.rev-score .stars{color:var(--accent);letter-spacing:3px;font-size:18px}
.rev-score .lbl{color:var(--muted);font-size:13.5px}
.rev-grid{columns:3;column-gap:24px}
@media(max-width:980px){.rev-grid{columns:2}}
@media(max-width:600px){.rev-grid{columns:1}}
.rev-card{break-inside:avoid;-webkit-column-break-inside:avoid;margin:0 0 24px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px;transition:.3s var(--ease)}
.rev-card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.rev-card .stars{color:var(--accent);letter-spacing:2px;font-size:15px;margin-bottom:12px}
.rev-card .stars .off{color:var(--line)}
.rev-card p{font-size:15px;line-height:1.6;color:var(--ink2);margin-bottom:18px}
.rev-card .who{display:flex;align-items:center;gap:12px}
.rev-card .av{width:40px;height:40px;border-radius:50%;background:var(--accent-soft);color:var(--accent-d);display:grid;place-items:center;font-weight:700;font-family:"Space Grotesk"}
.rev-card .nm{font-weight:600;font-size:14.5px}

/* ===== Careers / jobs ===== */
.jobs{display:flex;flex-direction:column;gap:14px;max-width:880px;margin:0 auto}
.job{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px 28px;transition:.3s var(--ease)}
.job:hover{border-color:var(--bd-2,var(--ink));box-shadow:var(--shadow-sm)}
.job-main h3{font-family:"Space Grotesk";font-size:21px}
.job-meta{display:flex;gap:8px;color:var(--muted);font-size:14px;margin-top:6px}
.job-closed{color:var(--faint);font-size:14px;font-weight:600}

/* ===== Reviews — Google card style (override) ===== */
.rev-card{padding:24px 26px}
.rev-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.rev-who{display:flex;align-items:center;gap:12px;min-width:0}
.rev-card .av{width:44px;height:44px;border-radius:50%;background:var(--accent-soft);color:var(--accent-d);display:grid;place-items:center;font-weight:700;font-family:"Space Grotesk";overflow:hidden;flex-shrink:0}
.rev-card .av img{width:100%;height:100%;object-fit:cover}
.rev-id{min-width:0}
.rev-id .nm{font-weight:600;font-size:15px;line-height:1.2}
.rev-id .sub{font-size:12.5px;color:var(--muted);margin-top:2px}
.g-badge svg{width:22px;height:22px;display:block}
.rev-card .stars{margin-bottom:10px}
.rev-card p{margin-bottom:0;color:var(--ink2)}

/* ===== Careers: expandable job cards ===== */
details.job{display:block;padding:0;cursor:pointer;overflow:hidden}
details.job summary{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:24px 28px;list-style:none}
details.job summary::-webkit-details-marker{display:none}
details.job summary::marker{content:''}
.job-tog{font-size:26px;color:var(--accent);font-weight:300;line-height:1;transition:transform .25s var(--ease);flex-shrink:0}
details.job[open] .job-tog{transform:rotate(45deg)}
.job-body{padding:2px 28px 26px;animation:jobopen .3s var(--ease)}
@keyframes jobopen{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.job-body h4{font-family:"Space Grotesk";font-size:12.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--accent-d);margin-bottom:10px}
.job-body ul{padding-left:20px;color:var(--muted);font-size:15px;line-height:1.55;margin-bottom:14px}
.job-body li{margin-bottom:6px}
.job-exp{font-size:14.5px;color:var(--ink2);margin-bottom:18px}

/* ===== Careers: job cards (grid) ===== */
.job-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:1000px;margin:0 auto}
@media(max-width:760px){.job-grid{grid-template-columns:1fr}}
.job-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:30px 30px 28px;display:flex;flex-direction:column;transition:.3s var(--ease)}
.job-card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.job-card-top{display:flex;align-items:center;justify-content:space-between;gap:14px}
.job-card-top h3{font-family:"Space Grotesk";font-size:22px;letter-spacing:-.01em}
.job-badge{font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:5px 12px;border-radius:100px;white-space:nowrap}
.job-badge.open{color:#0a7d34;background:#e7f6ec}
.job-badge.closed{color:#c0341d;background:#fdecea}
.job-tags{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 4px}
.job-tags span{font-size:12.5px;font-weight:500;color:var(--muted);background:var(--bg2);border:1px solid var(--line);border-radius:8px;padding:4px 11px}
.job-card h4{font-family:"Space Grotesk";font-size:12.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--accent-d);margin:20px 0 10px}
.job-reqs{padding-left:20px;color:var(--muted);font-size:14.5px;line-height:1.55;margin-bottom:20px}
.job-reqs li{margin-bottom:7px}
.job-apply{align-self:flex-start;margin-top:auto}
.job-closed-note{color:var(--faint);font-size:14px;font-weight:500;margin-top:auto}

/* 4-up reviews grid on content pages */
.cards4{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.cards4 .rev-card{padding:22px}
.cards4 .rev-card p{font-size:14px;line-height:1.55}
@media(max-width:1024px){.cards4{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.cards4{grid-template-columns:1fr}}

/* ===== Header domain-search icon + modal ===== */
.hdr-search{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--ink);cursor:pointer;transition:.22s var(--ease);flex:0 0 auto}
.hdr-search svg{width:19px;height:19px}
.hdr-search:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-1px)}
.hdr--dark .hdr-search,.hdr--transparent .hdr-search{background:transparent;color:#fff;border-color:rgba(255,255,255,.3)}
@media(max-width:992px){.hdr-search{display:none}}
.dchk{position:fixed;inset:0;z-index:1200;display:none}
.dchk.on{display:block}
.dchk-scrim{position:absolute;inset:0;background:rgba(8,16,28,.55);backdrop-filter:blur(3px);animation:dchkf .25s ease}
.dchk-box{position:absolute;left:50%;top:84px;transform:translateX(-50%);width:min(560px,calc(100% - 28px));background:#fff;border-radius:22px;box-shadow:0 40px 90px -30px rgba(8,16,28,.55);padding:30px 30px 26px;animation:dchkp .28s var(--ease)}
@keyframes dchkf{from{opacity:0}}@keyframes dchkp{from{opacity:0;transform:translate(-50%,-10px)}}
.dchk-x{position:absolute;top:14px;right:16px;border:none;background:transparent;font-size:26px;line-height:1;color:var(--faint);cursor:pointer}
.dchk-x:hover{color:var(--ink)}
.dchk-ey{font-size:12.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--accent-d,#0061a0)}
.dchk-h{font-family:"Space Grotesk";font-size:26px;font-weight:600;letter-spacing:-.02em;margin:4px 0 4px}
.dchk-sub{color:var(--muted);font-size:14.5px;margin:0 0 18px}
.dchk-in{display:flex;gap:10px}
.dchk-in input{flex:1;min-width:0;border:1px solid var(--line);border-radius:12px;padding:13px 15px;font-size:15px;font-family:inherit}
.dchk-in input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow,rgba(0,121,196,.15))}
.dchk-in .btn{flex:0 0 auto}
.dchk-tlds{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:12px;font-size:13px}
.dchk-tlds span{color:var(--faint)}
.dchk-tlds button{border:1px solid var(--line);background:#fff;border-radius:999px;padding:5px 12px;font-size:13px;cursor:pointer;transition:.18s}
.dchk-tlds button:hover{border-color:var(--accent);color:var(--accent)}
.dchk-result{margin-top:18px}
.dchk-loading{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:14px}
.dchk-spin{width:16px;height:16px;border:2px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:blsp .7s linear infinite}
.dchk-card{border:1px solid var(--line);border-radius:16px;padding:20px}
.dchk-card.ok{background:#f0fbf5;border-color:#b7e4c9}
.dchk-card.no{background:#fbfdff}
.dchk-card.warn{background:#fff7ed;border-color:#fcd9a8;color:#9a4b00;font-size:14px}
.dchk-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}
.dchk-top b{font-family:"Space Grotesk";font-size:20px;letter-spacing:-.01em;word-break:break-all}
.dchk-tag{flex:0 0 auto;font-size:12px;font-weight:700;padding:5px 11px;border-radius:999px}
.dchk-tag.ok{background:#16a34a;color:#fff}
.dchk-tag.no{background:#fee2e2;color:#b42318}
.dchk-card p{color:var(--muted);font-size:14px;margin:0 0 14px}
.dchk-whois{margin:6px 0 14px;border-top:1px solid var(--line)}
.dchk-row{display:flex;gap:14px;padding:9px 0;border-bottom:1px solid var(--line);font-size:13.5px}
.dchk-row span{flex:0 0 104px;color:var(--faint);font-weight:600}
.dchk-row div{flex:1;min-width:0;color:var(--ink);word-break:break-word;line-height:1.5}
.dchk-help{margin:12px 0 14px!important;font-size:13px!important}
.dchk-card .btn{width:100%;justify-content:center}
@media(max-width:560px){.dchk-box{top:64px;padding:24px 20px 20px}.dchk-h{font-size:22px}}
.qdomain-note{display:flex;align-items:center;gap:10px;background:var(--accent-glow,rgba(0,121,196,.08));border:1px solid var(--line);border-radius:12px;padding:11px 14px;margin-bottom:14px;font-size:14px}
.qdomain-note b{color:var(--accent-d,#0061a0)}

/* ===== Software page: type cards ===== */
.soft-card{display:block;background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px;transition:.3s var(--ease)}
.soft-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}
.soft-ic{width:52px;height:52px;border-radius:13px;background:var(--accent-soft);color:var(--accent-d);display:grid;place-items:center;margin-bottom:18px;transition:.3s var(--ease)}
.soft-card:hover .soft-ic{background:var(--grad);color:#fff}
.soft-ic svg{width:26px;height:26px}
.soft-card h3{font-family:"Space Grotesk";font-size:19px;line-height:1.25;margin-bottom:9px}
.soft-card p{color:var(--muted);font-size:14px;line-height:1.55;margin-bottom:16px}
.soft-card .more{display:inline-flex;align-items:center;gap:6px;color:var(--accent-d);font-weight:600;font-size:13.5px}
.soft-card .more svg{width:14px;height:14px}

/* ===== About: Vision & Mission cards ===== */
.vm-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px}
@media(max-width:760px){.vm-grid{grid-template-columns:1fr}}
.vm-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:34px;transition:.3s var(--ease)}
.vm-card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.vm-ic{width:54px;height:54px;border-radius:14px;background:var(--accent-soft);color:var(--accent-d);display:grid;place-items:center;margin-bottom:18px}
.vm-ic svg{width:28px;height:28px}
.vm-card h3{font-family:"Space Grotesk";font-size:22px;margin-bottom:10px}
.vm-card>p{color:var(--muted);font-size:15px;line-height:1.6;margin-bottom:14px}
.vm-card ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.vm-card li{position:relative;padding-left:28px;font-size:15px;color:var(--ink2);line-height:1.5}
.vm-card li::before{content:"";position:absolute;left:0;top:7px;width:16px;height:16px;border-radius:50%;background:var(--accent-soft);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230079C4' stroke-width='3'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");background-size:11px;background-repeat:no-repeat;background-position:center}

/* soft-card with optional image header (admin-uploaded) */
.soft-card{padding:0;overflow:hidden;display:flex;flex-direction:column}
.soft-card .soft-bd{padding:24px 28px 28px}
.soft-card .soft-ic{margin:28px 28px 2px}
.soft-ph{aspect-ratio:16/10;overflow:hidden;background:var(--bg2);border-bottom:1px solid var(--line)}
.soft-ph img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.soft-card.has-img:hover .soft-ph img{transform:scale(1.05)}

/* ===== About: office carousel (scroll-snap, no JS) ===== */
.office-wrap{position:relative}
.office-arr{position:absolute;top:50%;transform:translateY(-50%);z-index:4;width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:rgba(255,255,255,.92);color:var(--ink);display:grid;place-items:center;cursor:pointer;box-shadow:0 10px 24px -12px rgba(13,42,72,.4);transition:.2s}
.office-arr:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-50%) scale(1.06)}
.office-arr svg{width:20px;height:20px}
.office-arr.prev{left:18px}.office-arr.next{right:18px}
.office-carousel{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px 40px 14px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.office-carousel::-webkit-scrollbar{height:0}
.office-carousel::-webkit-scrollbar-old{height:8px}
.office-carousel::-webkit-scrollbar-thumb{background:var(--line);border-radius:10px}
.office-slide{flex:0 0 auto;width:min(560px,82vw);scroll-snap-align:center;border-radius:20px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);background:var(--bg2)}
.office-slide img{width:100%;height:340px;object-fit:cover;display:block}
@media(max-width:760px){.office-slide img{height:240px}}

/* Internal Link Juicer auto-links inside content */
.prose a.ilj-link, a.ilj-link{color:var(--accent);text-decoration:none;border-bottom:1px solid var(--accent-soft);transition:border-color .2s}
.prose a.ilj-link:hover,a.ilj-link:hover{border-bottom-color:var(--accent)}

/* ===== Theme Options — header styles, topbar, animations ===== */
.topbar{background:var(--ink);color:#cdd3dc;font-size:13px}
.topbar a{color:#cdd3dc;text-decoration:none;margin-right:18px;transition:.2s}
.topbar a:hover{color:#fff}
.tb-in{display:flex;align-items:center;justify-content:space-between;min-height:38px;flex-wrap:wrap;gap:6px}
.tb-s{display:flex;align-items:center}
.tb-s a{margin:0 0 0 14px}
.tb-s svg{width:15px;height:15px;vertical-align:middle}
@media(max-width:600px){.tb-c a{margin-right:12px;font-size:12px}}

.hdr--static{position:relative}
.hdr--dark{background:#0f1b2d!important;border-bottom-color:rgba(255,255,255,.08)}
.hdr--dark .menu>li>a,.hdr--dark .logo{color:#fff}
.hdr--dark .caret{color:#fff}
.hdr--dark.scrolled{background:#0b1422!important}
.hdr--transparent{position:absolute;left:0;right:0;background:transparent;border-bottom-color:transparent;backdrop-filter:none}
.hdr--transparent .menu>li>a,.hdr--transparent .logo{color:#fff}
.hdr--transparent.scrolled{position:fixed;background:rgba(255,255,255,.96)!important;backdrop-filter:blur(16px)}
.hdr--transparent.scrolled .menu>li>a,.hdr--transparent.scrolled .logo{color:var(--ink)}
@media(min-width:993px){
  .hdr--centered .nav{display:grid;grid-template-columns:1fr auto 1fr;align-items:center}
  .hdr--centered nav{grid-column:1;justify-self:start}
  .hdr--centered .logo{grid-column:2;justify-self:center}
  .hdr--centered .btn{grid-column:3;justify-self:end}
}
.hdr--floating{background:transparent!important;border:none;backdrop-filter:none}
.hdr--floating .nav{margin:14px auto;width:min(1180px,calc(100% - 36px));background:rgba(255,255,255,.92);backdrop-filter:blur(16px);border:1px solid var(--line);border-radius:50px;padding:0 16px 0 24px;box-shadow:var(--shadow-sm)}
.hdr--boxed .nav{margin:12px auto;width:min(1200px,calc(100% - 30px));background:#fff;border:1px solid var(--line);border-radius:16px;padding:0 20px;box-shadow:var(--shadow-sm)}
.hdr--shrink.scrolled .nav{height:60px}

body.anim-off .rv{opacity:1!important;transform:none!important}

@media(max-width:992px){
  body.mh-centered .nav{position:relative}
  body.mh-centered .logo{position:absolute;left:50%;transform:translateX(-50%)}
}

/* ===== Header style overrides (robust, body-scoped) ===== */
body.hs-dark .hdr,body.hs-transparent .hdr--transparent.scrolled{}
body.hs-dark .menu a,body.hs-transparent .menu a{color:#fff}
body.hs-dark .menu a::after,body.hs-transparent .menu a::after{background:#fff}
body.hs-dark .caret,body.hs-transparent .caret{color:rgba(255,255,255,.7)!important}
body.hs-dark .burger span,body.hs-transparent .burger span{background:#fff}
body.hs-transparent.hdrsolid .menu a,body.hs-transparent .hdr--transparent.scrolled .menu a{color:var(--ink)}
body.hs-transparent .hdr--transparent.scrolled .burger span{background:var(--ink)}
body.hs-transparent .hdr--transparent.scrolled .caret{color:var(--faint)!important}
/* the mega dropdown panel stays light regardless of header colour */
body.hs-dark .mega,body.hs-transparent .mega{color:var(--ink)}
body.hs-dark .mega a,body.hs-transparent .mega a{color:var(--ink)}
/* floating / boxed: keep menu dark text (light pill) */
body.hs-floating .menu a,body.hs-boxed .menu a{color:var(--ink)}

/* Cookie consent bar */
.cookie-bar{position:fixed;left:16px;right:16px;bottom:16px;z-index:300;background:var(--ink);color:#e8ecf2;border-radius:14px;padding:14px 18px;display:flex;align-items:center;gap:16px;justify-content:space-between;box-shadow:0 12px 40px rgba(0,0,0,.3);max-width:760px;margin:0 auto;font-size:14px}
.cookie-bar button{flex:none;background:var(--accent);color:#fff;border:none;border-radius:9px;padding:9px 22px;font-weight:600;cursor:pointer;font-family:inherit}
.cookie-bar button:hover{background:var(--accent-d)}
@media(max-width:560px){.cookie-bar{flex-direction:column;align-items:stretch;text-align:center;gap:10px}}

/* Get-estimation CTA band (above footer) */
.estimate-cta{background:var(--accent-soft);border-top:1px solid var(--accent-soft)}
.ecta-in{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:46px 0;flex-wrap:wrap}
.estimate-cta .ey2{color:var(--accent)}
.estimate-cta h2,.estimate-cta .thead{font-size:clamp(24px,3.4vw,38px);letter-spacing:-.02em;margin-top:6px}
@media(max-width:640px){
  .ecta-in{flex-direction:column;align-items:center;text-align:center;padding:36px 0;gap:18px}
  .ecta-in>div{width:100%}
  .ecta-in .ey2{justify-content:center}
  .ecta-in h2,.ecta-in .thead{font-size:22px;line-height:1.25}
  .ecta-in .btn{width:100%;max-width:340px;justify-content:center;margin:0 auto}
}
@media(max-width:600px){
  .cta{padding:64px 0}
  .hero-cta,.cta .row{flex-direction:column;align-items:stretch}
  .hero-cta .btn,.cta .row .btn{width:100%;justify-content:center}
  .hero-rate{justify-content:center;text-align:center}
  .cta h2,.cta .thead{font-size:clamp(30px,8vw,40px)}
}

/* ===== Free Tools ===== */
.tool-card{max-width:820px;background:#fff;border:1px solid #e6ecf2;border-radius:18px;padding:28px;box-shadow:0 18px 50px -28px rgba(13,42,72,.25)}
.tool-lab{display:block;font-weight:600;font-size:14px;margin-bottom:8px;color:var(--ink,#0d2a48)}
.tool-card textarea,.tool-card input[type=text],.tool-card input[type=tel]{width:100%;border:1px solid #d7e0ea;border-radius:12px;padding:14px;font:inherit;font-size:15px;resize:vertical}
.tool-card textarea:focus,.tool-card input:focus,.tool-sel:focus{outline:none;border-color:var(--accent,#0079C4)}
.tool-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:14px}
.tool-up{display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:500;color:#526174}
.tool-up input{width:auto}
.tool-out{display:flex;gap:10px;margin-top:4px}
.tool-out input{flex:1;border:1px solid #d7e0ea;border-radius:12px;padding:14px;font:inherit;font-size:15px;font-family:monospace;letter-spacing:.02em;background:#f7f9fb}
.tool-note{margin-top:12px;font-size:13.5px;color:var(--accent-d,#0a4a73);min-height:18px}
.tool-grid2{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}
.tool-color{width:100%;height:46px;padding:4px;border:1px solid #d7e0ea;border-radius:10px;cursor:pointer;background:#fff}
.tool-hex{max-width:120px}
.tool-sel{width:100%;height:46px;border:1px solid #d7e0ea;border-radius:10px;padding:0 12px;font:inherit;background:#fff}
.code{font-family:monospace;font-size:13.5px;line-height:1.55}
/* QR */
.qr-stage{display:flex;justify-content:center;margin-top:22px}
#qrbox{display:inline-block;padding:14px;background:#fff;border:1px solid #eef2f7;border-radius:14px}
#qrbox img,#qrbox canvas{display:block}
/* Palette */
.pal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:10px;margin-top:22px}
.pal-sw{height:96px;border:none;border-radius:12px;cursor:pointer;display:flex;align-items:flex-end;justify-content:center;padding:10px;font:inherit;box-shadow:inset 0 0 0 1px rgba(0,0,0,.05);transition:transform .12s}
.pal-sw:hover{transform:translateY(-3px)}
.pal-sw span{background:rgba(255,255,255,.92);border-radius:6px;padding:3px 8px;font-size:12px;font-weight:700;letter-spacing:.03em;color:#10263d}
.grad-prev{height:150px;border-radius:14px;margin-top:18px;border:1px solid #eef2f7;background:linear-gradient(135deg,#0079C4,#00C2A8)}
/* Domain checker */
.dc-tlds{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:14px}
.dc-tlds button{border:1px solid #d7e0ea;background:#f7f9fb;border-radius:999px;padding:6px 14px;font:inherit;font-size:13px;font-weight:600;cursor:pointer;color:#3a4a5c}
.dc-tlds button:hover{border-color:var(--accent,#0079C4);color:var(--accent,#0079C4)}
.dc-result{margin-top:18px}
.dc-card{display:flex;align-items:center;gap:14px;flex-wrap:wrap;border-radius:14px;padding:18px 20px;font-size:16px}
.dc-card .btn{margin-left:auto}
.dc-ok{background:#e9f8ef;border:1px solid #b7e6c8;color:#11703a}
.dc-no{background:#fdeef0;border:1px solid #f3c6cd;color:#a32436}
.dc-warn{background:#fff7e8;border:1px solid #f3dca6;color:#8a6310}
/* related tools */
.tool-more{margin-top:46px;max-width:820px}
.tool-more-h{font-size:18px;margin-bottom:14px}
.tool-more-grid{display:flex;flex-wrap:wrap;gap:10px}
.tool-chip{display:inline-flex;align-items:center;gap:8px;border:1px solid #e1e8f0;background:#fff;border-radius:999px;padding:9px 16px;font-weight:600;font-size:14px;color:#27384b;text-decoration:none;transition:.15s}
.tool-chip:hover{border-color:var(--accent,#0079C4);color:var(--accent,#0079C4);transform:translateY(-2px)}
.tc-ic{font-size:15px;color:var(--accent,#0079C4)}
@media(max-width:560px){.dc-card .btn{margin-left:0;width:100%;justify-content:center}}

/* ===== Footer Free Tools strip ===== */
.df-tools{display:flex;align-items:center;gap:18px;flex-wrap:wrap;padding:20px 0;border-top:1px solid rgba(255,255,255,.1);margin-top:6px}
.df-tools .dft-lab{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent,#3aa0e0)}
.dft-links{display:flex;flex-wrap:wrap;gap:8px 22px}
.dft-links a{color:var(--faint,#9fb0c4);font-size:14px;text-decoration:none;transition:.15s}
.dft-links a:hover{color:#fff}
@media(max-width:600px){.df-tools{flex-direction:column;align-items:flex-start;gap:10px}.dft-links{gap:8px 16px}}

/* ===== WhatsApp live indicator + bubble ===== */
/* .wa is position:fixed (above) — that already anchors the absolute children */
.wa-live{position:absolute;top:6px;right:6px;width:12px;height:12px;border-radius:50%;background:#34d36b;border:2px solid #fff;box-shadow:0 0 0 0 rgba(52,211,107,.6);animation:waPulse 2s infinite}
@keyframes waPulse{0%{box-shadow:0 0 0 0 rgba(52,211,107,.55)}70%{box-shadow:0 0 0 9px rgba(52,211,107,0)}100%{box-shadow:0 0 0 0 rgba(52,211,107,0)}}
.wa-bubble{position:absolute;left:66px;top:50%;transform:translateY(-50%) translateX(-8px);background:#fff;color:#10263d;border-radius:12px;padding:8px 13px;box-shadow:0 10px 30px -10px rgba(0,0,0,.3);font-size:12.5px;line-height:1.3;white-space:nowrap;display:flex;flex-direction:column;opacity:0;pointer-events:none;transition:.25s}
.wa-bubble b{color:#11703a;font-size:12.5px}
.wa:hover .wa-bubble{opacity:1;transform:translateY(-50%) translateX(0)}
.wa-bubble:after{content:"";position:absolute;left:-6px;top:50%;transform:translateY(-50%);border:6px solid transparent;border-right-color:#fff}
@media(max-width:600px){.wa-bubble{display:none}}

/* ===== Blog reading progress bar ===== */
.readbar{position:fixed;top:0;left:0;right:0;height:3px;background:transparent;z-index:1200;pointer-events:none}
.readbar i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--accent,#0079C4),#00C2A8);transition:width .08s linear}

/* ===== Exit-intent popup ===== */
.xpop{position:fixed;inset:0;z-index:1300;display:none;align-items:center;justify-content:center;padding:20px;background:rgba(8,22,38,.55);backdrop-filter:blur(3px)}
.xpop.on{display:flex;animation:xpFade .25s ease}
@keyframes xpFade{from{opacity:0}to{opacity:1}}
.xpop-card{position:relative;width:100%;max-width:440px;background:#fff;border-radius:22px;padding:34px 30px 26px;text-align:center;overflow:hidden;box-shadow:0 40px 90px -30px rgba(0,40,80,.6);animation:xpPop .3s cubic-bezier(.2,.9,.3,1.2)}
@keyframes xpPop{from{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:none}}
.xpop-deco{position:absolute;top:-70px;left:-40px;right:-40px;height:150px;background:linear-gradient(135deg,var(--accent,#0079C4),#00C2A8);border-radius:0 0 50% 50%;opacity:.14}
.xpop-x{position:absolute;top:12px;right:14px;border:none;background:#eef3f8;width:34px;height:34px;border-radius:50%;font-size:22px;line-height:1;color:#5a6b7e;cursor:pointer;z-index:2}
.xpop-x:hover{background:#e0e8f0}
.xpop-badge{position:relative;display:inline-block;background:var(--accent,#0079C4);color:#fff;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:6px 14px;border-radius:999px;margin-bottom:14px}
.xpop-h{position:relative;font-size:24px;line-height:1.2;margin:0 0 10px}
.xpop-t{position:relative;color:#5a6b7e;font-size:14.5px;line-height:1.55;margin:0 0 20px}
.xpop-form{display:flex;flex-direction:column;gap:10px}
.xpop-in{width:100%;border:1px solid #d7e0ea;border-radius:12px;padding:13px 15px;font:inherit;font-size:15px}
.xpop-in:focus{outline:none;border-color:var(--accent,#0079C4)}
.xpop-hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.xpop-btn{justify-content:center;margin-top:4px}
.xpop-ok{display:none;color:#11703a;font-weight:700;font-size:17px;padding:18px 0}
.xpop-ok.show{display:block;animation:xpFade .3s ease}
.xpop-fine{color:#90a0b2;font-size:12px;margin:14px 0 0}

/* homepage project cards — portfolio-style arrow */
.pcard .pc-ttl{display:flex;align-items:center;justify-content:space-between;gap:10px}
.pcard .pf-ar{flex:none;width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:var(--accent,#0079C4);color:#fff;transform:translate(2px,2px) scale(.92);opacity:.85;transition:.25s}
.pcard .pf-ar svg{width:16px;height:16px}
.pcard:hover .pf-ar{transform:none;opacity:1}
/* testimonial avatar fallback (initials) when no client photo */
.tq .who .av{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,var(--accent,#0079C4),#0a4a73);color:#fff;display:grid;place-items:center;font-weight:700;font-family:"Space Grotesk";font-size:20px;flex:none}

/* portfolio: browse-by-industry chips moved to bottom (SEO internal links) */
.cat-browse{margin-top:50px;padding-top:36px;border-top:1px solid var(--line)}
.cat-browse-h{font-size:19px;margin:0 0 16px;font-weight:700;font-family:"Space Grotesk"}

/* ===== Service page template ===== */
.svc-hero-cta{display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-top:24px}
.svc-rate{font-size:14px;color:var(--muted);display:inline-flex;align-items:center;gap:8px;background:none}.svc-rate .st{display:inline-flex;gap:3px;background:none}.svc-rate .st svg{display:block;background:none}.svc-rate strong{color:var(--ink)}
.svc-trust{display:flex;gap:30px;flex-wrap:wrap;margin-top:22px}
.svc-trust span{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.svc-trust b{display:block;font-family:"Space Grotesk",sans-serif;font-size:23px;color:var(--ink);line-height:1.1;letter-spacing:-.01em}
.faq{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.faq-i{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:.2s}
.faq-i[open]{border-color:var(--accent);box-shadow:0 14px 34px -24px rgba(0,121,196,.5)}
.faq-i summary{list-style:none;cursor:pointer;padding:18px 22px;font-weight:600;font-size:16px;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq-i summary::-webkit-details-marker{display:none}
.faq-x{flex:none;width:22px;height:22px;position:relative}
.faq-x:before,.faq-x:after{content:"";position:absolute;background:var(--accent);border-radius:2px;transition:.25s}
.faq-x:before{top:10px;left:3px;width:16px;height:2px}
.faq-x:after{left:10px;top:3px;width:2px;height:16px}
.faq-i[open] .faq-x:after{transform:rotate(90deg);opacity:0}
.faq-a{padding:2px 22px 20px;color:var(--muted);line-height:1.65;font-size:15px}

/* render ★ rating glyphs as monochrome text (not the OS colour-emoji box) */
.stars,.svc-rate .st,.rev-card .stars,.tq .stars,.hero-rate .stars,.rev-score .stars{font-variant-emoji:text}
