/* ===================================================================
   Ditecho — premium public site styles (light, modern, animated)
   =================================================================== */

:root{
  --brand-50:#eff6ff; --brand-100:#dbeafe; --brand-200:#bfdbfe; --brand-300:#93c5fd;
  --brand-500:#3b82f6; --brand-600:#2563eb; --brand-700:#1d4ed8;
  --indigo:#4f46e5; --violet:#7c3aed; --cyan:#06b6d4; --emerald:#10b981;
  --ink:#0b1120; --slate:#334155; --muted:#64748b; --faint:#94a3b8;
  --line:#e6eaf1; --line-2:#eef2f7;
  --bg:#ffffff; --bg-soft:#f8fafc; --bg-tint:#f1f5f9; --bg-ink:#0a0f1e;
  --white:#fff;
  --grad:linear-gradient(135deg,#2563eb 0%,#4f46e5 52%,#06b6d4 100%);
  --grad-2:linear-gradient(135deg,#7c3aed,#2563eb 60%,#06b6d4);
  --grad-soft:linear-gradient(135deg,#eff6ff,#eef2ff 55%,#ecfeff);
  --shadow-sm:0 1px 2px rgba(15,23,42,.06),0 1px 3px rgba(15,23,42,.05);
  --shadow:0 10px 30px -12px rgba(30,41,99,.18);
  --shadow-lg:0 30px 60px -20px rgba(30,41,99,.28);
  --shadow-xl:0 50px 90px -30px rgba(15,23,42,.4);
  --glow:0 0 0 1px rgba(37,99,235,.08),0 24px 60px -22px rgba(37,99,235,.45);
  --r:14px; --r-lg:22px; --r-xl:28px; --r-2xl:36px;
  --maxw:1180px;
  --ff:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--ff);color:var(--slate);background:var(--bg);
  line-height:1.65;font-size:16.5px;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
h1,h2,h3,h4{color:var(--ink);line-height:1.1;margin:0 0 .5em;font-weight:800;letter-spacing:-.025em}
h1{font-size:clamp(2.3rem,5vw,4rem)}
h2{font-size:clamp(1.8rem,3.6vw,2.8rem)}
h3{font-size:1.25rem}
p{margin:0 0 1rem}
a{color:var(--brand-600);text-decoration:none;transition:color .2s}
a:hover{color:var(--brand-700)}
img{max-width:100%;display:block}
svg.icon{width:18px;height:18px;flex:none}            /* safe default size for any inline icon */
.more{display:inline-flex;align-items:center;gap:6px;font-weight:650;font-size:.92rem}
.more .icon{width:16px;height:16px;transition:transform .2s}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.section{padding:78px 0}
.section.tight{padding:48px 0}
.bg-soft{background:var(--bg-soft)}
.bg-tint{background:var(--bg-tint)}
.bg-ink{background:var(--bg-ink);color:#c7d2e3}
.text-grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.center{text-align:center}

/* ---- Eyebrow + section heads ---- */
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.78rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;color:var(--brand-700);
  background:var(--brand-50);border:1px solid var(--brand-100);padding:7px 15px;border-radius:999px}
.eyebrow .icon{width:15px;height:15px}
.section-head{max-width:700px;margin:0 auto 40px}
.section-head.left{margin-left:0;text-align:left}
.section-head p{color:var(--muted);font-size:1.1rem;margin-top:.5rem}

/* ---- Buttons ---- */
.btn{position:relative;display:inline-flex;align-items:center;gap:9px;font-weight:650;font-size:1rem;
  padding:13px 24px;border-radius:999px;border:1px solid transparent;cursor:pointer;overflow:hidden;
  transition:transform .18s ease,box-shadow .25s ease,background .25s;white-space:nowrap}
.btn .icon{width:18px;height:18px;position:relative;z-index:1}
.btn span,.btn{z-index:1}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 14px 30px -10px rgba(37,99,235,.6);background-size:160% 160%}
.btn-primary:hover{color:#fff;transform:translateY(-2px);box-shadow:0 22px 40px -10px rgba(37,99,235,.75);background-position:100% 0}
.btn-primary:before{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.45),transparent);transform:skewX(-18deg);transition:left .6s}
.btn-primary:hover:before{left:140%}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--brand-300);background:var(--brand-50);color:var(--brand-700);transform:translateY(-2px)}
.btn-light{background:rgba(255,255,255,.16);color:#fff;border-color:rgba(255,255,255,.34)}
.btn-light:hover{background:rgba(255,255,255,.26);color:#fff;transform:translateY(-2px)}
.btn-white{background:#fff;color:var(--brand-700)}
.btn-white:hover{color:var(--brand-700);transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-lg{padding:16px 32px;font-size:1.05rem}
.btn-block{display:flex;width:100%;justify-content:center}
.wrap-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}

/* ---- Navbar ---- */
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.78);
  backdrop-filter:saturate(180%) blur(16px);-webkit-backdrop-filter:saturate(180%) blur(16px);
  border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s,background .3s}
.nav.scrolled{border-color:var(--line);box-shadow:0 6px 24px -16px rgba(15,23,42,.3);background:rgba(255,255,255,.9)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:11px;font-weight:850;font-size:1.32rem;color:var(--ink);letter-spacing:-.02em}
.brand:hover{color:var(--ink)}
.brand-mark{width:38px;height:38px;filter:drop-shadow(0 6px 14px rgba(37,99,235,.35))}
.brand b{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none;margin:0;padding:0}
.nav-links a{position:relative;color:var(--slate);font-weight:550;font-size:.97rem;padding:9px 14px;border-radius:10px;transition:.2s}
.nav-links a:hover{color:var(--ink);background:var(--bg-tint)}
.nav-links a.active{color:var(--brand-700);background:var(--brand-50)}
.nav-cta{display:flex;align-items:center;gap:12px}
.nav-toggle{display:none;background:none;border:1px solid var(--line);border-radius:10px;padding:8px;color:var(--ink);cursor:pointer}
.nav-toggle .icon{width:22px;height:22px}

/* ===================================================================
   HERO — real photos + animated aurora background
   =================================================================== */
.hero{position:relative;padding:50px 0 80px;overflow:hidden;background:var(--grad-soft)}
.hero .container{position:relative;z-index:2}
/* animated aurora blobs */
.hero .aurora{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero .aurora span{position:absolute;border-radius:50%;filter:blur(70px);opacity:.55;mix-blend-mode:multiply}
.hero .aurora span:nth-child(1){width:540px;height:540px;background:radial-gradient(circle,#93c5fd,transparent 70%);top:-180px;right:-120px;animation:float 16s ease-in-out infinite}
.hero .aurora span:nth-child(2){width:480px;height:480px;background:radial-gradient(circle,#a5f3fc,transparent 70%);bottom:-220px;left:-160px;animation:float 20s ease-in-out infinite reverse}
.hero .aurora span:nth-child(3){width:420px;height:420px;background:radial-gradient(circle,#c4b5fd,transparent 70%);top:30%;left:40%;animation:float 24s ease-in-out infinite}
/* subtle dotted grid overlay */
.hero:after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background-image:radial-gradient(rgba(37,99,235,.10) 1px,transparent 1px);background-size:26px 26px;
  -webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 30%,#000,transparent 75%);
  mask-image:radial-gradient(ellipse 80% 70% at 50% 30%,#000,transparent 75%);opacity:.6}

.hero-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:54px;align-items:center}
.hero h1{margin-bottom:.32em}
.hero h1 .text-grad{background:var(--grad);background-size:200% 200%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:grad-pan 6s ease infinite}
.hero-sub{font-size:1.18rem;color:var(--slate);max-width:560px;margin-bottom:1.8rem}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:1.7rem}
.hero-meta{display:flex;align-items:center;gap:18px;flex-wrap:wrap;color:var(--muted);font-size:.92rem}
.hero-meta .dot{width:5px;height:5px;border-radius:50%;background:var(--faint)}
.hero-meta b{color:var(--ink)}
.hero-rating{display:inline-flex;align-items:center;gap:8px;margin-bottom:22px;font-size:.92rem;color:var(--slate)}
.hero-rating .stars{display:inline-flex;color:#f59e0b}
.hero-rating .stars .icon{width:16px;height:16px;fill:#f59e0b;stroke:#f59e0b}

/* hero visual — real photo in a browser frame + floating phone + glass cards */
.hero-visual{position:relative;height:480px;perspective:1400px}
.hero-stage{position:absolute;inset:0;transform-style:preserve-3d}

.frame-browser{position:absolute;top:8px;left:0;width:88%;border-radius:18px;overflow:hidden;background:#fff;
  border:1px solid var(--line);box-shadow:var(--shadow-xl);animation:rise .8s both}
.frame-browser .bar{height:40px;background:#f1f5f9;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:7px;padding:0 16px}
.frame-browser .bar i{width:11px;height:11px;border-radius:50%;display:block}
.frame-browser .bar i:nth-child(1){background:#ff5f57}
.frame-browser .bar i:nth-child(2){background:#febc2e}
.frame-browser .bar i:nth-child(3){background:#28c840}
.frame-browser .bar .url{margin-left:12px;flex:1;height:20px;border-radius:999px;background:#fff;border:1px solid var(--line);
  font-size:.7rem;color:var(--faint);display:flex;align-items:center;padding:0 12px}
.frame-browser .bar .url .icon{width:12px;height:12px;margin-right:4px;color:var(--emerald)}
.frame-browser.static{position:relative;top:0;left:0;width:100%;border-radius:16px}
.frame-browser .shot{height:300px;overflow:hidden;position:relative}
.frame-browser .shot img{width:100%;display:block;animation:webscroll 24s ease-in-out infinite alternate}

.frame-phone{position:absolute;right:-6px;bottom:-10px;width:150px;height:300px;border-radius:30px;
  border:7px solid #0b1120;background:#0b1120;box-shadow:var(--shadow-xl);overflow:hidden;animation:rise .8s .2s both;z-index:3}
.frame-phone:before{content:"";position:absolute;top:8px;left:50%;transform:translateX(-50%);width:46px;height:6px;border-radius:99px;background:#1e293b;z-index:3}
.frame-phone .ph-slides{position:absolute;inset:0;border-radius:24px;overflow:hidden;background:#0b1120}
.frame-phone .ph-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .6s ease}
.frame-phone .ph-slide.active{opacity:1}
.frame-phone .ph-scroll{position:absolute;inset:0;border-radius:24px;overflow:hidden;background:#fff}
.frame-phone .ph-scroll img{width:100%;display:block;animation:phonescroll 20s ease-in-out infinite alternate}
@keyframes phonescroll{from{transform:translateY(0)}to{transform:translateY(calc(-100% + 280px))}}

.float-glass{position:absolute;background:rgba(255,255,255,.72);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.7);border-radius:16px;box-shadow:var(--shadow-lg);padding:13px 16px;
  display:flex;align-items:center;gap:11px;animation:rise .8s both}
.float-glass .ic{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;color:#fff;flex:none}
.float-glass .ic .icon{width:20px;height:20px}
.float-glass b{font-size:.92rem;color:var(--ink);display:block;line-height:1.15}
.float-glass span{font-size:.74rem;color:var(--muted)}
.fg-1{top:-18px;right:8%;animation-delay:.35s}
.fg-1 .ic{background:var(--grad)}
.fg-2{bottom:54px;left:-26px;animation-delay:.5s}
.fg-2 .ic{background:linear-gradient(135deg,#10b981,#059669)}
.float-anim{animation:rise .8s both,bob 6s ease-in-out 1s infinite}

/* ---- Device showcase (reuses hero frames in a section) ---- */
.device-showcase{position:relative;max-width:900px;height:540px;margin:0 auto;perspective:1400px}
.frame-browser .adm-slides{position:relative;height:300px;overflow:hidden;background:#0f172a}
.device-showcase .adm-slides{height:452px}
.frame-browser .adm-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;object-position:center;
  opacity:0;transition:opacity .7s ease}
.frame-browser .adm-slide.active{opacity:1}
@media(max-width:980px){.device-showcase{height:460px;max-width:680px}.device-showcase .adm-slides{height:360px}}
@media(max-width:680px){.device-showcase{height:300px;max-width:430px}.device-showcase .adm-slides{height:230px}}

/* ---- Marquee (infinite logo / tech strip) ---- */
.marquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;gap:0;width:max-content;animation:scroll-x 32s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{display:flex;align-items:center;gap:10px;padding:22px 38px;color:var(--slate);font-weight:750;font-size:1.05rem;white-space:nowrap}
.marquee-item .icon{width:20px;height:20px;color:var(--brand-600)}
.marquee-item .m-logo{width:24px;height:24px;object-fit:contain;flex:none}
.marquee-item .dot{width:6px;height:6px;border-radius:50%;background:var(--brand-200)}

/* ---- Trust strip ---- */
.trust{border-bottom:1px solid var(--line);background:#fff}
.trust .container{display:flex;align-items:center;gap:30px;flex-wrap:wrap;justify-content:center;padding-top:26px;padding-bottom:26px}
.trust span{color:var(--faint);font-weight:600;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase}
.trust .chip{color:var(--slate);font-weight:700;opacity:.8}

/* ---- Stats band ---- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stat{position:relative;text-align:center;padding:22px 14px;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm);transition:transform .25s,box-shadow .25s}
.stat:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.stat b{display:block;font-size:2.1rem;font-weight:850;letter-spacing:-.04em;line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat span{color:var(--muted);font-weight:600;font-size:.92rem;display:block;margin-top:5px}

/* ---- Generic grids / cards ---- */
.grid{display:grid;gap:22px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;
  box-shadow:var(--shadow-sm);transition:transform .3s cubic-bezier(.2,.7,.3,1),box-shadow .3s,border-color .3s;overflow:hidden}
.card:before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;opacity:0;transition:opacity .3s;
  background:linear-gradient(135deg,var(--brand-300),transparent 40%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.card:hover{transform:translateY(-7px);box-shadow:var(--shadow-lg);border-color:#dbe4f3}
.card:hover:before{opacity:1}
.card .ic{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;color:#fff;
  background:var(--grad);margin-bottom:18px;box-shadow:0 14px 24px -10px rgba(79,70,229,.6);transition:transform .3s}
.card:hover .ic{transform:scale(1.08) rotate(-4deg)}
.card .ic .icon{width:27px;height:27px}
.card h3{margin-bottom:.4rem}
.card p{color:var(--muted);margin:0;font-size:.98rem}
.card .more{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-weight:650;font-size:.92rem}
.card .more .icon{width:16px;height:16px;transition:transform .2s}
.card:hover .more .icon{transform:translateX(5px)}
/* gradient CTA card (fills the services grid) */
.card-cta{background:var(--grad);color:#fff;border:none;display:flex;flex-direction:column}
.card-cta:before{display:none}
.card-cta .ic{background:rgba(255,255,255,.2);box-shadow:none}
.card-cta:hover .ic{transform:scale(1.08) rotate(-4deg)}
.card-cta h3{color:#fff}
.card-cta p{color:rgba(255,255,255,.92)}
.card-cta .more{color:#fff;margin-top:auto}
.card-cta:hover{box-shadow:0 26px 50px -18px rgba(37,99,235,.6)}

/* ---- Service image cards (real photos) ---- */
.scard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:transform .3s cubic-bezier(.2,.7,.3,1),box-shadow .3s;display:flex;flex-direction:column}
.scard:hover{transform:translateY(-7px);box-shadow:var(--shadow-lg)}
.scard-img{position:relative;aspect-ratio:16/9;overflow:hidden;background:var(--bg-tint)}
.scard-img img{width:100%;height:100%;object-fit:cover;transition:transform .55s}
.scard:hover .scard-img img{transform:scale(1.07)}
.scard-img:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(8,12,24,.18))}
.scard-ic{position:absolute;left:18px;bottom:-24px;z-index:1;width:50px;height:50px;border-radius:14px;background:var(--grad);
  color:#fff;display:grid;place-items:center;box-shadow:0 14px 24px -10px rgba(79,70,229,.6);border:3px solid #fff}
.scard-ic .icon{width:24px;height:24px}
.scard-body{padding:34px 22px 24px;display:flex;flex-direction:column;flex:1}
.scard-body h3{margin:0 0 .35rem;font-size:1.18rem}
.scard-body p{color:var(--muted);font-size:.95rem;margin:0}
.scard-body .more{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-weight:650;font-size:.92rem}
.scard-body .more .icon{width:16px;height:16px;transition:transform .2s}
.scard:hover .more .icon{transform:translateX(5px)}
/* gradient CTA tile to match */
.scard-cta{background:var(--grad);color:#fff;border:none}
.scard-cta .scard-body{justify-content:center;padding:30px 24px}
.scard-cta .ic{width:52px;height:52px;border-radius:14px;background:rgba(255,255,255,.2);display:grid;place-items:center;margin-bottom:16px}
.scard-cta .ic .icon{width:26px;height:26px}
.scard-cta h3{color:#fff;font-size:1.25rem}
.scard-cta p{color:rgba(255,255,255,.92)}
.scard-cta .more{color:#fff;margin-top:16px}

/* ---- Bento capabilities grid (photo-rich) ---- */
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:18px}
.bento-cell{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow-sm);transition:transform .35s,box-shadow .35s;color:#fff;display:flex;flex-direction:column;justify-content:flex-end}
.bento-cell:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.bento-cell img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s}
.bento-cell:hover img{transform:scale(1.07)}
.bento-cell:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,12,24,.05) 30%,rgba(8,12,24,.82))}
.bento-cell .bc-body{position:relative;z-index:1;padding:22px}
.bento-cell .bc-tag{display:inline-flex;align-items:center;gap:7px;font-size:.72rem;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;background:rgba(255,255,255,.16);backdrop-filter:blur(6px);padding:5px 11px;border-radius:999px;margin-bottom:10px}
.bento-cell .bc-tag .icon{width:14px;height:14px}
.bento-cell h3{color:#fff;font-size:1.2rem;margin:0 0 4px}
.bento-cell p{color:rgba(255,255,255,.82);font-size:.9rem;margin:0}
.bento-cell.wide{grid-column:span 2}
.bento-cell.tall{grid-row:span 2}
.bento-cell.brandy:after{background:linear-gradient(135deg,rgba(37,99,235,.92),rgba(124,58,237,.88))}

/* ---- Work / product cards ---- */
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.work{position:relative;border-radius:var(--r-xl);overflow:hidden;background:#fff;border:1px solid var(--line);
  box-shadow:var(--shadow-sm);transition:transform .35s,box-shadow .35s}
.work:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.work-cover{display:block;aspect-ratio:16/10;overflow:hidden;position:relative;background:var(--grad)}
.work-cover > img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.work:hover .work-cover > img{transform:scale(1.06)}
/* live covers: looping admin shots / scrolling website */
.work-cover .cover-slides{position:absolute;inset:0;background:#0f172a}
.work-cover .cover-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;object-position:center;opacity:0;transition:opacity .8s ease}
.work-cover .cover-slide.active{opacity:1}
.work-cover .cover-scroll{position:absolute;inset:0;overflow:hidden}
.work-cover .cover-scroll img{width:100%;display:block;animation:coverscroll 26s ease-in-out infinite alternate}
@keyframes coverscroll{from{transform:translateY(0)}to{transform:translateY(calc(-100% + 350px))}}
.work-cover.placeholder{display:grid;place-items:center}
.work-cover .ph-title{color:#fff;font-weight:850;font-size:1.8rem;letter-spacing:-.02em;text-align:center;padding:0 24px;
  text-shadow:0 4px 18px rgba(0,0,0,.25)}
.work-cover .live{position:absolute;top:14px;left:14px;z-index:2;display:inline-flex;align-items:center;gap:7px;
  background:rgba(8,12,24,.6);backdrop-filter:blur(6px);color:#fff;font-size:.72rem;font-weight:700;
  padding:6px 12px;border-radius:999px}
.work-cover .live .pulse{width:8px;height:8px;border-radius:50%;background:#34d399;box-shadow:0 0 0 0 rgba(52,211,153,.7);animation:pulse 1.8s infinite}
.work-body{padding:26px}
.chip{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--brand-700);background:var(--brand-50);border:1px solid var(--brand-100);padding:5px 12px;border-radius:999px;margin-bottom:12px}
.chip.green{color:#047857;background:#ecfdf5;border-color:#a7f3d0}
.work-body h3{font-size:1.4rem}
.work-body p{color:var(--muted);font-size:.99rem;margin-bottom:16px}

/* ---- Split feature ---- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.feature-list{list-style:none;margin:18px 0 0;padding:0}
.feature-list li{display:flex;gap:14px;margin-bottom:18px}
.feature-list .ic{flex:none;width:42px;height:42px;border-radius:12px;background:var(--brand-50);color:var(--brand-700);
  display:grid;place-items:center;border:1px solid var(--brand-100)}
.feature-list .ic .icon{width:21px;height:21px}
.feature-list b{color:var(--ink);display:block}
.feature-list span{color:var(--muted);font-size:.95rem}
.media-frame{position:relative;border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-lg);background:#fff}
.media-frame video,.media-frame img{width:100%;display:block}
.media-frame.tilt{transform:perspective(1200px) rotateY(-7deg) rotateX(3deg)}

/* ---- Process steps (timeline-ish) ---- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:s}
.step{position:relative;padding:30px 22px 26px;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s}
.step:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.step:before{counter-increment:s;content:"0" counter(s);position:absolute;top:-18px;left:22px;height:44px;padding:0 12px;border-radius:13px;
  background:var(--grad);color:#fff;font-weight:800;font-size:1.05rem;display:grid;place-items:center;box-shadow:0 12px 22px -8px rgba(79,70,229,.6)}
.step h3{margin:16px 0 .3rem;font-size:1.12rem}
.step p{color:var(--muted);font-size:.93rem;margin:0}

/* ---- Testimonials ---- */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.quote{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s}
.quote:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.quote .stars{color:#f59e0b;display:flex;gap:2px;margin-bottom:12px}
.quote .stars .icon{width:18px;height:18px;fill:#f59e0b;stroke:#f59e0b}
.quote p{color:var(--slate);font-size:1.02rem;font-style:italic}
.quote .who{display:flex;align-items:center;gap:12px;margin-top:18px}
.quote .av{width:46px;height:46px;border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;font-weight:800}
.quote .who b{color:var(--ink);display:block;font-size:.95rem}
.quote .who span{color:var(--muted);font-size:.84rem}

/* ---- CTA band (photo background) ---- */
.cta-band{position:relative;overflow:hidden;background:var(--grad);border-radius:var(--r-2xl);
  padding:60px;color:#fff;text-align:center;box-shadow:var(--shadow-lg)}
.cta-band.photo{background:var(--ink)}
.cta-band.photo .cta-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.32}
.cta-band.photo:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(37,99,235,.8),rgba(124,58,237,.6),rgba(6,182,212,.55))}
.cta-band:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% -20%,rgba(255,255,255,.22),transparent 50%)}
.cta-band > *{position:relative;z-index:1}
.cta-band h2{color:#fff}
.cta-band p{color:rgba(255,255,255,.92);max-width:580px;margin:0 auto 26px;font-size:1.12rem}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---- Footer ---- */
.footer{position:relative;background:var(--bg-ink);color:#a8b3c7;padding:72px 0 28px;overflow:hidden}
.footer:before{content:"";position:absolute;top:-120px;left:50%;transform:translateX(-50%);width:700px;height:300px;
  background:radial-gradient(circle,rgba(37,99,235,.25),transparent 70%);filter:blur(40px)}
.footer .container{position:relative}
.footer .brand{color:#fff}
.footer .brand b{color:#fff;background:none;-webkit-text-fill-color:#fff}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:36px;padding-bottom:42px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer h4{color:#fff;font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:16px}
.footer ul{list-style:none;margin:0;padding:0}
.footer ul li{margin-bottom:10px}
.footer a{color:#a8b3c7;font-size:.95rem}
.footer a:hover{color:#fff}
.footer .desc{font-size:.96rem;margin:16px 0;max-width:300px}
.foot-contact{display:flex;align-items:center;gap:10px;margin-bottom:10px;color:#cbd5e1;font-size:.95rem}
.foot-contact .icon{width:18px;height:18px;color:var(--cyan)}
.socials{display:flex;gap:10px;margin-top:6px}
.socials a{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.07);display:grid;place-items:center;color:#cbd5e1;transition:.25s}
.socials a:hover{background:var(--grad);color:#fff;transform:translateY(-2px)}
.socials .icon{width:18px;height:18px}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;padding-top:22px;font-size:.88rem;color:#64748b}
.foot-bottom a{color:#94a3b8}

/* ---- Forms ---- */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);padding:34px;box-shadow:var(--shadow)}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;color:var(--ink);font-size:.92rem;margin-bottom:6px}
.input,.textarea,.select{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:12px;font:inherit;
  color:var(--ink);background:var(--bg-soft);transition:border-color .2s,box-shadow .2s,background .2s}
.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--brand-500);background:#fff;box-shadow:0 0 0 4px var(--brand-50)}
.textarea{min-height:130px;resize:vertical}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ---- Floating WhatsApp button ---- */
.wa-float{position:fixed;right:20px;bottom:20px;z-index:70;width:58px;height:58px;border-radius:50%;
  background:#25d366;color:#fff;display:grid;place-items:center;box-shadow:0 16px 30px -8px rgba(37,211,102,.6);
  transition:transform .25s}
.wa-float:hover{transform:scale(1.08);color:#fff}
.wa-float .icon{width:30px;height:30px}
.wa-float:after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid #25d366;animation:ring 2.4s ease-out infinite}

/* ---- Flash / alerts ---- */
.flash-wrap{position:fixed;top:90px;right:20px;z-index:80;display:flex;flex-direction:column;gap:10px;max-width:360px}
.alert{padding:14px 18px;border-radius:12px;font-weight:600;font-size:.94rem;box-shadow:var(--shadow);animation:rise .4s both}
.alert.success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}
.alert.error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}

/* ---- Page hero (inner pages) ---- */
.page-hero{position:relative;background:var(--grad-soft);padding:80px 0 60px;text-align:center;border-bottom:1px solid var(--line);overflow:hidden}
.page-hero:after{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(rgba(37,99,235,.10) 1px,transparent 1px);background-size:26px 26px;
  -webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 30%,#000,transparent 75%);
  mask-image:radial-gradient(ellipse 70% 60% at 50% 30%,#000,transparent 75%);opacity:.6}
.page-hero .container{position:relative;z-index:1}
.page-hero p{color:var(--muted);font-size:1.12rem;max-width:640px;margin:.5rem auto 0}
.breadcrumb{font-size:.86rem;color:var(--muted);margin-bottom:14px}
.breadcrumb a{color:var(--brand-600)}

/* ---- Product detail ---- */
.prod-head{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.prod-feature-video{border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-xl);border:1px solid var(--line);background:#000}
.prod-feature-video video{width:100%;display:block}
.prose{color:var(--slate);font-size:1.06rem}
.prose p{margin-bottom:1rem;white-space:pre-line}
.kv{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0}
.kv .k{background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 15px;font-size:.86rem;font-weight:600;color:var(--slate);display:flex;align-items:center;gap:7px}
.kv .k .icon{width:16px;height:16px;color:var(--brand-600)}

/* phone screenshot gallery */
.phones{display:flex;gap:20px;overflow-x:auto;padding:10px 4px 24px;scroll-snap-type:x mandatory}
.phones::-webkit-scrollbar{height:8px}
.phones::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:99px}
.phone{flex:none;width:228px;scroll-snap-align:start;border:9px solid #0b1120;border-radius:34px;overflow:hidden;
  box-shadow:var(--shadow-lg);background:#0b1120;transition:transform .25s}
.phone:hover{transform:translateY(-6px)}
.phone img{width:100%;display:block;border-radius:24px}

/* video gallery grid */
.video-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.vid{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);background:#000;box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s}
.vid:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.vid video{width:100%;display:block;aspect-ratio:16/10;object-fit:cover}
.vid .cap{position:absolute;left:0;right:0;bottom:0;padding:18px 14px 10px;color:#fff;font-size:.82rem;font-weight:600;
  background:linear-gradient(transparent,rgba(0,0,0,.6));pointer-events:none}

.img-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.img-grid img{width:100%;border-radius:var(--r-lg);border:1px solid var(--line);box-shadow:var(--shadow-sm)}

/* ===================================================================
   Animations
   =================================================================== */
@keyframes float{0%,100%{transform:translate(0,0)}50%{transform:translate(-20px,26px)}}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes rise{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes grad-pan{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes scroll-x{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes webscroll{from{transform:translateY(0)}to{transform:translateY(calc(-100% + 300px))}}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(52,211,153,.7)}70%{box-shadow:0 0 0 9px rgba(52,211,153,0)}100%{box-shadow:0 0 0 0 rgba(52,211,153,0)}}
@keyframes ring{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.7);opacity:0}}

/* scroll reveal (+ stagger via inline --d) */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.3,1);transition-delay:var(--d,0s)}
.reveal.in{opacity:1;transform:none}
.reveal.left{transform:translateX(-32px)}
.reveal.right{transform:translateX(32px)}
.reveal.zoom{transform:scale(.94)}
.reveal.left.in,.reveal.right.in,.reveal.zoom.in{transform:none}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important;animation-iteration-count:1!important}
  .reveal{opacity:1;transform:none}
}

/* ---- Responsive ---- */
@media(max-width:980px){
  .hero-grid,.split,.prod-head{grid-template-columns:1fr}
  .hero-visual{height:400px;margin-top:24px}
  .grid-3,.grid-4,.quotes,.steps,.video-grid{grid-template-columns:repeat(2,1fr)}
  .work-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .bento{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}
  .bento-cell.wide{grid-column:span 2}
  .bento-cell.tall{grid-row:span 1}
}
@media(max-width:680px){
  .section{padding:64px 0}
  .nav-links{position:fixed;inset:74px 0 auto 0;flex-direction:column;background:#fff;border-bottom:1px solid var(--line);
    padding:14px 18px;gap:4px;transform:translateY(-130%);transition:transform .3s;box-shadow:var(--shadow);align-items:stretch}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{padding:12px 14px}
  .nav-toggle{display:inline-flex}
  .nav .btn.hide-sm{display:none}
  .stats,.grid-3,.grid-4,.quotes,.steps,.video-grid,.img-grid,.row-2,.footer-grid{grid-template-columns:1fr}
  .bento{grid-template-columns:1fr;grid-auto-rows:170px}
  .bento-cell.wide{grid-column:span 1}
  .cta-band{padding:40px 22px}
  .hero{padding:60px 0 50px}
  .frame-phone{display:none}
}

/* ===================================================================
   Premium polish — loader, progress, cursor, impact, pricing, lightbox
   =================================================================== */

/* Page loader */
#loader{position:fixed;inset:0;z-index:200;background:var(--bg);display:grid;place-items:center;
  transition:opacity .5s ease,visibility .5s ease}
#loader.done{opacity:0;visibility:hidden}
#loader .l-mark{width:66px;height:66px;animation:bob 1.4s ease-in-out infinite;filter:drop-shadow(0 10px 22px rgba(37,99,235,.35))}
#loader .l-bar{position:absolute;bottom:0;left:0;height:3px;width:0;background:var(--grad);animation:loadbar 1.2s ease forwards}
@keyframes loadbar{to{width:100%}}

/* Scroll progress */
#progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:60;background:var(--grad);box-shadow:0 0 10px rgba(37,99,235,.5)}

/* Impact / results band (dark, animated numbers) */
.impact{position:relative;overflow:hidden;background:var(--bg-ink)}
.impact:before{content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 18% 0%,rgba(37,99,235,.28),transparent 45%),radial-gradient(circle at 88% 100%,rgba(6,182,212,.22),transparent 45%)}
.impact .container{position:relative;z-index:1}
.impact .section-head h2{color:#fff}
.impact .section-head p{color:#9fb0c9}
.impact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.impact-cell{text-align:center;padding:30px 16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);
  border-radius:var(--r-lg);transition:transform .3s,background .3s}
.impact-cell:hover{transform:translateY(-6px);background:rgba(255,255,255,.07)}
.impact-cell b{display:block;font-size:2.9rem;font-weight:850;letter-spacing:-.04em;line-height:1;
  background:linear-gradient(135deg,#7dd3fc,#c4b5fd 60%,#67e8f9);-webkit-background-clip:text;background-clip:text;color:transparent}
.impact-cell span{display:block;margin-top:10px;color:#9fb0c9;font-weight:600;font-size:.95rem}

/* Pricing / packages */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start}
.price{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);padding:34px 28px;
  box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s}
.price:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.price.feat{border:2px solid transparent;background:linear-gradient(#fff,#fff) padding-box,var(--grad) border-box;box-shadow:var(--glow)}
.price .tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--grad);color:#fff;
  font-size:.7rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;padding:6px 14px;border-radius:999px;white-space:nowrap}
.price h3{font-size:1.22rem;margin-bottom:4px}
.price .sub{color:var(--muted);font-size:.92rem;margin-bottom:18px}
.price .amt{font-size:2.1rem;font-weight:850;color:var(--ink);letter-spacing:-.03em;line-height:1}
.price .amt small{font-size:.85rem;font-weight:600;color:var(--muted)}
.price ul{list-style:none;margin:20px 0 24px;padding:0}
.price li{display:flex;gap:10px;align-items:flex-start;margin-bottom:11px;color:var(--slate);font-size:.95rem}
.price li .icon{width:18px;height:18px;color:#16a34a;flex:none;margin-top:2px}
.price .btn{width:100%;justify-content:center}

/* Lightbox */
#lightbox{position:fixed;inset:0;z-index:150;background:rgba(8,12,24,.88);backdrop-filter:blur(4px);
  display:none;place-items:center;padding:30px;cursor:zoom-out}
#lightbox.open{display:grid;animation:rise .3s ease}
#lightbox img{max-width:92vw;max-height:90vh;border-radius:12px;box-shadow:var(--shadow-xl)}
#lightbox .lb-close{position:absolute;top:18px;right:26px;color:#fff;font-size:38px;line-height:1;cursor:pointer;opacity:.85}
.zoomable{cursor:zoom-in}

@media(max-width:980px){.impact-grid{grid-template-columns:repeat(2,1fr)}.pricing{grid-template-columns:1fr;max-width:460px;margin:0 auto}}
@media(max-width:680px){.impact-grid{grid-template-columns:1fr}}

/* ---- Footer newsletter ---- */
.news{margin-top:18px;max-width:300px}
.news label{display:block;font-size:.82rem;color:#cbd5e1;margin-bottom:8px;font-weight:600}
.news-row{display:flex;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:999px;overflow:hidden}
.news-input{flex:1;background:transparent;border:0;padding:11px 16px;color:#fff;font:inherit;outline:none}
.news-input::placeholder{color:#64748b}
.news-btn{border:0;background:var(--grad);color:#fff;padding:0 16px;cursor:pointer;display:grid;place-items:center}
.news-btn .icon{width:18px;height:18px}

/* ---- FAQ accordion ---- */
.faq{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:box-shadow .25s}
.faq-item[open]{box-shadow:var(--shadow)}
.faq-item summary{list-style:none;cursor:pointer;padding:20px 22px;font-weight:700;color:var(--ink);font-size:1.05rem;
  display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:after{content:"+";font-size:1.5rem;font-weight:400;color:var(--brand-600);transition:transform .25s;flex:none}
.faq-item[open] summary:after{transform:rotate(45deg)}
.faq-item .faq-body{padding:0 22px 20px;color:var(--muted);line-height:1.7}

/* ===================================================================
   Dark mode (html.dark) — premium dark theme via variable overrides
   =================================================================== */
html.dark{
  --bg:#0a0f1e; --bg-soft:#0e1426; --bg-tint:#141c30; --bg-ink:#060912;
  --ink:#f1f5f9; --slate:#cbd5e1; --muted:#93a3bc; --faint:#64748b;
  --line:#1e2940; --line-2:#1a2438;
  --brand-50:#101f40; --brand-100:#1b315e; --brand-300:#3b5bb0;
  --grad-soft:linear-gradient(135deg,#0d1730,#101a38 55%,#0b1b2c);
  --shadow-sm:0 1px 2px rgba(0,0,0,.4); --shadow:0 12px 30px -12px rgba(0,0,0,.6);
  --shadow-lg:0 30px 60px -20px rgba(0,0,0,.7); --shadow-xl:0 50px 90px -30px rgba(0,0,0,.85);
}
html.dark body{background:var(--bg);color:var(--slate)}
html.dark .nav{background:rgba(10,15,30,.8)}
html.dark .nav.scrolled{background:rgba(10,15,30,.92);border-color:var(--line)}
html.dark .nav-links a:hover{background:var(--bg-tint);color:#fff}
html.dark .card,html.dark .scard,html.dark .price,html.dark .quote,html.dark .stat,html.dark .step,
html.dark .form-card,html.dark .work,html.dark .frame-browser,html.dark .vid,html.dark .faq-item,
html.dark .media-frame,html.dark .phone{background:var(--bg-soft);border-color:var(--line)}
html.dark .btn-ghost{background:var(--bg-soft);color:var(--ink);border-color:var(--line)}
html.dark .btn-ghost:hover{background:var(--bg-tint);border-color:var(--brand-300);color:#fff}
html.dark .btn-white{background:var(--bg-soft);color:#fff}
html.dark .scard-img,html.dark .work-cover{background:var(--bg-tint)}
html.dark .input,html.dark .textarea,html.dark .select{background:var(--bg-tint);color:var(--ink);border-color:var(--line)}
html.dark .input:focus,html.dark .textarea:focus,html.dark .select:focus{background:var(--bg-soft)}
html.dark .marquee,html.dark .trust{background:var(--bg-soft);border-color:var(--line)}
html.dark .float-glass{background:rgba(20,28,48,.82);border-color:rgba(255,255,255,.08)}
html.dark .float-glass b{color:#fff}
html.dark .chip{background:var(--brand-50);border-color:var(--line);color:#93c5fd}
html.dark .kv .k{background:var(--bg-soft);border-color:var(--line);color:var(--slate)}
html.dark .eyebrow{color:#93c5fd}
html.dark .price.feat{background:linear-gradient(var(--bg-soft),var(--bg-soft)) padding-box,var(--grad) border-box}
html.dark .hero .aurora span{mix-blend-mode:screen;opacity:.28}
html.dark .marquee-item .m-logo{filter:brightness(1.7) saturate(1.2)}
html.dark #loader{background:var(--bg)}

/* Theme toggle button */
.theme-toggle{background:none;border:1px solid var(--line);border-radius:10px;width:40px;height:40px;
  color:var(--ink);cursor:pointer;display:grid;place-items:center;transition:background .2s}
.theme-toggle:hover{background:var(--bg-tint)}
.theme-toggle .icon{width:20px;height:20px}
.theme-toggle .ic-sun{display:none}
html.dark .theme-toggle .ic-sun{display:block}
html.dark .theme-toggle .ic-moon{display:none}

/* ---- Honeypot (hidden from humans) ---- */
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;opacity:0;pointer-events:none}

/* ---- Accessibility: visible keyboard focus ---- */
a:focus-visible,button:focus-visible,.btn:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,summary:focus-visible,details:focus-visible{
  outline:3px solid rgba(37,99,235,.55);outline-offset:2px;border-radius:6px}
.btn:focus-visible{outline-offset:3px}

/* ---- Mobile sticky CTA bar ---- */
.mcta{display:none}
@media(max-width:680px){
  .mcta{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:65;gap:10px;padding:10px 12px;
    background:rgba(255,255,255,.93);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--line)}
  .mcta a{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px;border-radius:12px;font-weight:700;font-size:.98rem}
  .mcta-call{background:var(--bg-tint);color:var(--ink)}
  .mcta-quote{background:var(--grad);color:#fff}
  .mcta .icon{width:18px;height:18px}
  .wa-float{bottom:80px}
  body{padding-bottom:68px}
}
html.dark .mcta{background:rgba(10,15,30,.93);border-color:var(--line)}

/* ---- Lead magnet popup ---- */
.leadpop{position:fixed;inset:0;z-index:140;background:rgba(8,12,24,.6);backdrop-filter:blur(4px);display:none;place-items:center;padding:24px}
.leadpop.open{display:grid;animation:rise .3s ease}
.leadpop-card{position:relative;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-xl);max-width:420px;width:100%;padding:32px 28px;box-shadow:var(--shadow-xl)}
.leadpop-x{position:absolute;top:12px;right:16px;background:none;border:0;font-size:28px;line-height:1;color:var(--muted);cursor:pointer}
.leadpop-row{display:flex;gap:8px}
.leadpop-row input{flex:1;padding:13px 15px;border:1px solid var(--line);border-radius:12px;font:inherit;background:var(--bg-soft);color:var(--ink)}
.leadpop-row input:focus{outline:none;border-color:var(--brand-500);background:var(--bg)}
.leadpop-row .btn{padding:0 18px}

/* ---- Process timeline connecting line ---- */
.steps{position:relative}
.step{position:relative;z-index:1}
@media(min-width:981px){
  .steps:before{content:"";position:absolute;top:4px;left:12.5%;right:12.5%;height:2px;z-index:0;
    background:linear-gradient(90deg,var(--brand-300),var(--violet),var(--cyan));opacity:.45}
}
html.dark .steps:before{opacity:.55}

/* ---- Back to top ---- */
.to-top{position:fixed;left:20px;bottom:20px;z-index:66;width:46px;height:46px;border-radius:50%;
  background:var(--ink);color:#fff;border:0;display:grid;place-items:center;cursor:pointer;
  opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .3s,transform .3s,background .2s;box-shadow:var(--shadow-lg)}
.to-top.show{opacity:1;visibility:visible;transform:none}
.to-top:hover{background:var(--brand-600)}
.to-top svg{width:20px;height:20px}
html.dark .to-top{background:var(--bg-soft);border:1px solid var(--line)}
@media(max-width:680px){.to-top{bottom:78px}}

/* ---- Blog tag filter ---- */
.tag-filter{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:38px}
.tag-filter a{font-size:.86rem;font-weight:650;padding:8px 16px;border-radius:999px;border:1px solid var(--line);
  color:var(--slate);background:var(--bg);transition:.2s}
.tag-filter a:hover{border-color:var(--brand-300);color:var(--brand-700);background:var(--brand-50)}
.tag-filter a.active{background:var(--grad);color:#fff;border-color:transparent}
