/*
Theme Name: Al Shafi Digital
Theme URI: http://localhost:8765
Author: Al Shafi Digital
Description: Premium animated growth-studio theme — TikTok VA, Shopify, Etsy, Amazon and full e-commerce services. Editorial design, smooth motion.
Version: 3.2.1
License: GPL-2.0-or-later
Text Domain: asd
*/

/* ============ TOKENS ============ */
:root{
  --bg:#F5F4EF; --bg-2:#ECEBE4; --paper:#FFFFFF; --ink:#0C0C0F; --ink-2:#1A1A20;
  --muted:#5A5A63; --muted-2:#8A8A93; --line:rgba(12,12,15,.12); --line-2:rgba(12,12,15,.07);
  --volt:#CDFF3B; --volt-deep:#B6F000; --indigo:#3B22F0; --flame:#FF4326;
  --r:18px; --r-lg:26px; --r-xl:38px;
  --maxw:1280px;
  --ease:cubic-bezier(.19,1,.22,1); --ease-2:cubic-bezier(.65,.05,.36,1);
  --t:.5s; --tf:.28s;
  --shadow:0 28px 60px -32px rgba(12,12,15,.45);
  --shadow-sm:0 8px 24px -14px rgba(12,12,15,.4);
  --font-display:'Bricolage Grotesque'; --font-body:'Inter'; --font-mono:'Space Mono';
  --marquee-dur:32s;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font-body),system-ui,sans-serif;font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;cursor:none}
@media(hover:none){body{cursor:auto}}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:var(--font-display),var(--font-body),sans-serif;margin:0;font-weight:800;line-height:.98;letter-spacing:-.025em}
p{margin:0 0 1rem}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,4vw,56px)}
.eyebrow{font-family:var(--font-mono),monospace;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--ink);display:inline-block}
.hl{background:var(--volt);padding:0 .12em;border-radius:.12em;color:var(--ink);box-decoration-break:clone;-webkit-box-decoration-break:clone}
.pad{padding:clamp(80px,11vw,170px) 0}
section{position:relative}

/* ============ CUSTOM CURSOR ============ */
.cur,.cur-d{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;border-radius:50%;mix-blend-mode:difference;will-change:transform}
.cur{width:38px;height:38px;border:1.5px solid #fff;transform:translate(-50%,-50%);transition:width .3s var(--ease),height .3s var(--ease),background .3s,opacity .3s}
.cur-d{width:6px;height:6px;background:#fff;transform:translate(-50%,-50%)}
.cur.grow{width:64px;height:64px;background:#fff}
@media(hover:none){.cur,.cur-d{display:none}}

/* ============ NAV ============ */
.nav{position:fixed;top:0;left:0;right:0;z-index:80;transition:background .3s ease,border-color .3s ease,box-shadow .3s ease;border-bottom:1px solid transparent}
.nav.scrolled{background:var(--bg);border-color:var(--line-2);box-shadow:0 6px 24px -14px rgba(20,20,20,.28)}
.nav.hide{transform:none}
.nav .inner{display:flex;align-items:center;justify-content:space-between;gap:24px;max-width:var(--maxw);margin:0 auto;padding:18px clamp(20px,4vw,56px)}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:800;font-size:1.18rem;letter-spacing:-.02em}
.brand .mark{width:34px;height:34px;border-radius:10px;background:var(--ink);color:var(--volt);display:grid;place-items:center;font-weight:800;font-size:1.05rem;transition:transform .5s var(--ease)}
.brand:hover .mark{transform:rotate(-12deg) scale(1.05)}
.nav-links{display:flex;gap:4px;align-items:center}
.nav-links a:not(.btn){padding:9px 15px;color:var(--ink);font-size:.95rem;font-weight:500;position:relative;opacity:.7;transition:opacity var(--tf)}
.nav-links a:not(.btn)::after{content:"";position:absolute;left:15px;right:15px;bottom:4px;height:1.5px;background:var(--ink);transform:scaleX(0);transform-origin:left;transition:transform var(--tf) var(--ease)}
.nav-links a:not(.btn):hover{opacity:1}
.nav-links a:not(.btn):hover::after{transform:scaleX(1)}
.btn{position:relative;display:inline-flex;align-items:center;gap:9px;padding:14px 26px;border-radius:100px;font-weight:600;font-size:.96rem;cursor:none;border:0;background:var(--ink);color:#fff;overflow:hidden;isolation:isolate;transition:color .4s var(--ease),transform .3s var(--ease)}
.btn>*{position:relative;z-index:1}
.btn::before{content:"";position:absolute;inset:0;z-index:-1;background:var(--volt);border-radius:100px;transform:translateY(101%);transition:transform .45s var(--ease)}
.btn:hover{color:var(--ink)}
.btn:hover::before{transform:translateY(0)}
.btn.alt{background:var(--volt);color:var(--ink)}
.btn.alt::before{background:var(--ink)}
.btn.alt:hover{color:#fff}
.btn.ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn.ghost::before{background:var(--ink)}
.btn.ghost:hover{color:#fff}
.nav-toggle{display:none;background:none;border:0;color:var(--ink);cursor:pointer}
.nav-links .btn{display:none}

/* ============ HERO ============ */
.hero{padding:clamp(140px,18vw,210px) 0 clamp(50px,7vw,90px)}
.hero .top{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:34px}
.hero .top p{max-width:340px;color:var(--muted);font-size:1.02rem;margin:0}
.hero h1{font-size:clamp(2.9rem,11vw,9.5rem);font-weight:800;letter-spacing:-.04em;line-height:1.08}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .line>span{display:block;transform:translateY(110%);transition:transform 1s var(--ease)}
.loaded .hero h1 .line>span{transform:none}
.hero h1 .line:nth-child(2)>span{transition-delay:.08s}
.hero h1 .line:nth-child(3)>span{transition-delay:.16s}
.rotbox{box-sizing:content-box;display:inline-flex;align-items:center;justify-content:flex-start;background:var(--volt);border-radius:.16em;padding:.04em .18em;overflow:hidden;vertical-align:middle;height:1.05em;line-height:1;position:relative;transition:width .5s var(--ease)}
.rotbox .rotator{display:inline-grid}
.rotbox .rotator span{grid-area:1/1;opacity:0;transform:translateY(60%);transition:.55s var(--ease);white-space:nowrap;line-height:1;width:max-content;justify-self:start}
.rotbox .rotator span.on{opacity:1;transform:none}
.hero-foot{display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap;margin-top:clamp(36px,5vw,60px)}
.hero-cta{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.scrollcue{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:10px}
.scrollcue .arr{width:36px;height:36px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;animation:bob 1.8s var(--ease) infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* ============ MARQUEE ============ */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:20px 0;overflow:hidden;background:var(--ink);color:var(--bg)}
.marquee .track{display:flex;width:max-content;animation:asd-marquee var(--marquee-dur) linear infinite;will-change:transform}
@keyframes asd-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee:hover .track{animation-play-state:paused}
.marquee span{font-family:var(--font-display);font-weight:700;font-size:1.35rem;display:flex;align-items:center;white-space:nowrap;letter-spacing:-.01em}
.marquee span i{margin:0 36px;color:var(--volt);font-style:normal}

/* ============ SECTION HEAD ============ */
.shead{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:end;margin-bottom:clamp(46px,6vw,76px)}
.shead h2{font-size:clamp(2.1rem,6vw,4.4rem)}
.shead .sub{color:var(--muted);font-size:1.08rem;max-width:420px;justify-self:end}
@media(max-width:760px){.shead{grid-template-columns:1fr}.shead .sub{justify-self:start}}

/* ============ SERVICES (signature hover list) ============ */
.svc-list{border-top:1px solid var(--line)}
.svc-row{position:relative;display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:28px;padding:clamp(22px,2.6vw,38px) clamp(6px,2vw,30px);border-bottom:1px solid var(--line);overflow:hidden;transition:color .45s var(--ease),padding-left .45s var(--ease)}
.svc-row::before{content:"";position:absolute;inset:0;background:var(--ink);transform:translateY(101%);transition:transform .5s var(--ease);z-index:0}
.svc-row>*{position:relative;z-index:1}
.svc-row:hover{color:var(--bg);padding-left:clamp(18px,3vw,46px)}
.svc-row:hover::before{transform:translateY(0)}
.svc-num{font-family:var(--font-mono);font-size:.8rem;color:var(--muted-2);transition:color .45s}
.svc-row:hover .svc-num{color:var(--volt)}
.svc-name{font-family:var(--font-display);font-weight:700;font-size:clamp(1.5rem,3.6vw,2.7rem);letter-spacing:-.02em}
.svc-desc{max-width:340px;color:var(--muted);font-size:.96rem;text-align:right;transition:color .45s}
.svc-row:hover .svc-desc{color:rgba(245,244,239,.7)}
.svc-arrow{width:52px;height:52px;border-radius:50%;border:1.5px solid var(--line);display:grid;place-items:center;transition:transform .45s var(--ease),background .45s,border-color .45s;color:currentColor}
.svc-row:hover .svc-arrow{background:var(--volt);border-color:var(--volt);color:var(--ink);transform:rotate(-45deg)}
@media(max-width:860px){
  .svc-row{grid-template-columns:auto 1fr auto;gap:16px}
  .svc-desc{display:none}
}

/* ============ STATS / MARQUEE NUMBERS ============ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,3vw,40px)}
.stat{border-top:2px solid var(--ink);padding-top:18px}
.stat b{font-family:var(--font-display);font-size:clamp(2.6rem,6vw,5rem);font-weight:800;display:block;letter-spacing:-.03em;line-height:1}
.stat small{color:var(--muted);font-size:.92rem;display:block;margin-top:8px}
@media(max-width:760px){.stats{grid-template-columns:1fr 1fr}}

/* ============ PROCESS ============ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,26px)}
.step{background:var(--paper);border:1px solid var(--line-2);border-radius:var(--r-lg);padding:clamp(26px,3vw,40px);transition:transform .5s var(--ease),box-shadow .5s}
.step:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.step .n{font-family:var(--font-mono);font-size:.8rem;color:var(--muted-2);letter-spacing:.1em}
.step .dot{width:46px;height:46px;border-radius:50%;background:var(--volt);display:grid;place-items:center;margin:18px 0 22px;font-family:var(--font-display);font-weight:800;font-size:1.2rem}
.step h3{font-size:1.45rem;margin-bottom:10px}
.step p{color:var(--muted);margin:0;font-size:.98rem}
@media(max-width:860px){.steps{grid-template-columns:1fr}}

/* ============ FEATURE SPLIT ============ */
.feat{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,70px);align-items:center}
.feat h2{font-size:clamp(2rem,4.6vw,3.4rem);margin-bottom:18px}
.feat ul{list-style:none;padding:0;margin:26px 0 0;display:grid;gap:2px}
.feat li{display:flex;gap:16px;align-items:flex-start;padding:18px 0;border-top:1px solid var(--line)}
.feat li .tick{flex:0 0 28px;width:28px;height:28px;border-radius:50%;background:var(--ink);color:var(--volt);display:grid;place-items:center;font-size:.8rem;margin-top:2px}
.feat li b{font-weight:700;font-size:1.05rem}
.feat li span{display:block;color:var(--muted);font-size:.95rem;margin-top:2px}
.feat .panel{aspect-ratio:4/5;border-radius:var(--r-xl);background:var(--ink);color:var(--bg);padding:clamp(28px,3vw,44px);display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.feat .panel .blob{position:absolute;width:120%;height:60%;left:-10%;bottom:-15%;background:radial-gradient(closest-side,var(--volt),transparent);opacity:.85;filter:blur(10px);animation:drift 12s var(--ease) infinite alternate}
@keyframes drift{to{transform:translate(8%,-10%) scale(1.15)}}
.feat .panel .big{font-family:var(--font-display);font-weight:800;font-size:clamp(3rem,7vw,5.5rem);line-height:.9;letter-spacing:-.03em;position:relative}
.feat .panel .cap{color:rgba(245,244,239,.7);position:relative;max-width:280px}
@media(max-width:860px){.feat{grid-template-columns:1fr}.feat .panel{aspect-ratio:16/10}}

/* ============ TESTIMONIALS ============ */
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px)}
.quote{background:var(--paper);border:1px solid var(--line-2);border-radius:var(--r-lg);padding:clamp(26px,3vw,36px);display:flex;flex-direction:column;transition:transform .5s var(--ease),box-shadow .5s}
.quote:hover{transform:translateY(-6px);box-shadow:var(--shadow-sm)}
.quote .stars{color:var(--ink);letter-spacing:3px;font-size:.95rem}
.quote p{font-size:1.06rem;margin:16px 0 auto;line-height:1.5}
.quote .who{display:flex;align-items:center;gap:13px;margin-top:24px;padding-top:20px;border-top:1px solid var(--line)}
.quote .av{width:46px;height:46px;border-radius:50%;background:var(--volt);display:grid;place-items:center;font-family:var(--font-display);font-weight:800}
.quote .who b{display:block;font-size:.98rem}
.quote .who small{color:var(--muted-2)}
@media(max-width:860px){.tgrid{grid-template-columns:1fr}}

/* ============ PRICING ============ */
.prices{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px);align-items:stretch}
.price{display:flex;flex-direction:column;padding:clamp(26px,3vw,40px);border:1px solid var(--line);border-radius:var(--r-lg);background:var(--paper);transition:transform .5s var(--ease),box-shadow .5s}
.price:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.price.pop{background:var(--ink);color:var(--bg)}
.price.pop .amt small,.price.pop .desc{color:rgba(245,244,239,.65)}
.price .tag{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.price.pop .tag{color:var(--volt)}
.price .amt{font-family:var(--font-display);font-weight:800;font-size:clamp(2.4rem,4.5vw,3.4rem);margin:14px 0 6px;letter-spacing:-.03em}
.price .amt small{font-family:var(--font-body);font-size:.95rem;color:var(--muted);font-weight:400}
.price .desc{color:var(--muted);font-size:.95rem}
.price ul{list-style:none;padding:0;margin:22px 0;display:grid;gap:12px;flex:1}
.price li{font-size:.96rem;display:flex;gap:11px;align-items:center}
.price li::before{content:"";width:18px;height:18px;border-radius:50%;background:var(--volt);color:var(--ink);display:grid;place-items:center;flex:0 0 18px;font-size:.7rem;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%230C0C0F' stroke-width='3' stroke-linecap='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}
.badge-pop{align-self:flex-start;background:var(--volt);color:var(--ink);font-family:var(--font-mono);font-size:.68rem;font-weight:700;letter-spacing:.1em;padding:6px 12px;border-radius:100px;margin-bottom:16px}
@media(max-width:860px){.prices{grid-template-columns:1fr}}

/* ============ FAQ ============ */
.faq{max-width:880px;margin:0 auto;border-top:1px solid var(--ink)}
.qa{border-bottom:1px solid var(--line)}
.qa button{width:100%;text-align:left;background:none;border:0;color:var(--ink);padding:26px 8px;font-size:clamp(1.1rem,2.2vw,1.45rem);font-weight:700;cursor:none;display:flex;justify-content:space-between;gap:18px;align-items:center;font-family:var(--font-display);letter-spacing:-.01em}
.qa .pm{flex:0 0 28px;width:28px;height:28px;display:grid;place-items:center;transition:transform .4s var(--ease)}
.qa.open .pm{transform:rotate(135deg)}
.qa .ans{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.qa .ans p{padding:0 8px 26px;color:var(--muted);margin:0;max-width:640px;font-size:1.02rem}

/* ============ CTA + CONTACT ============ */
.cta-band{background:var(--ink);color:var(--bg);border-radius:var(--r-xl);padding:clamp(40px,6vw,90px);position:relative;overflow:hidden}
.cta-band .glow{position:absolute;width:60%;height:120%;right:-10%;top:-20%;background:radial-gradient(closest-side,rgba(205,255,59,.35),transparent);filter:blur(20px)}
.cta-band .eyebrow{color:rgba(245,244,239,.7)}
.cta-band .eyebrow::before{background:var(--volt)}
.cta-band h2{font-size:clamp(2.2rem,6vw,4.6rem);margin:16px 0;position:relative}
.cta-band>.wrap-in{position:relative}
.cta-band .lead{color:rgba(245,244,239,.7);max-width:520px;font-size:1.1rem}
.contact{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:680px;margin:36px 0 0}
.contact .full{grid-column:1/-1}
.field label{display:block;font-size:.8rem;color:rgba(245,244,239,.6);margin-bottom:8px;font-family:var(--font-mono);letter-spacing:.05em;text-transform:uppercase}
.field input,.field select,.field textarea{width:100%;padding:15px 18px;border-radius:var(--r);border:1px solid rgba(245,244,239,.18);background:rgba(245,244,239,.05);color:var(--bg);font-family:var(--font-body);font-size:1rem;transition:var(--tf)}
.field input::placeholder,.field textarea::placeholder{color:rgba(245,244,239,.4)}
.field select{color:var(--bg)}
.field select option{color:#111}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--volt);background:rgba(245,244,239,.09)}
.field textarea{min-height:130px;resize:vertical}
#asd-msg{margin-top:14px;font-size:.98rem}
#asd-msg.ok{color:var(--volt)} #asd-msg.err{color:var(--flame)}
@media(max-width:680px){.contact{grid-template-columns:1fr}}

/* ============ FOOTER ============ */
.foot{padding:clamp(60px,8vw,110px) 0 36px}
.foot .huge{font-family:var(--font-display);font-weight:800;font-size:clamp(3rem,13vw,11rem);line-height:.85;letter-spacing:-.04em;margin-bottom:clamp(40px,6vw,80px)}
.foot .huge b{color:var(--volt-deep);-webkit-text-stroke:1px var(--ink);color:transparent}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px;padding-top:46px;border-top:1px solid var(--line)}
.foot h4{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2);margin-bottom:16px}
.foot a{display:block;color:var(--muted);padding:6px 0;font-size:.96rem;transition:color var(--tf),transform var(--tf)}
.foot a:hover{color:var(--ink);transform:translateX(4px)}
.foot .desc{color:var(--muted);max-width:300px;font-size:.98rem}
.socials{display:flex;gap:10px;margin-top:18px}
.socials a{width:42px;height:42px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;color:var(--ink);transition:var(--tf)}
.socials a:hover{background:var(--ink);color:var(--volt);transform:translateY(-4px)}
.foot-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:46px;color:var(--muted-2);font-size:.86rem}
@media(max-width:860px){.foot-grid{grid-template-columns:1fr 1fr}}

/* ============ REVEAL ============ */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
[data-stagger]>*{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-stagger].in>*{opacity:1;transform:none}

/* ============ GENERIC PAGE ============ */
.page-hero{padding:clamp(140px,16vw,200px) 0 30px}
.page-hero h1{font-size:clamp(2.4rem,7vw,5rem)}
.page-body{max-width:760px;margin:0 auto;padding:30px clamp(20px,4vw,56px) 100px;font-size:1.08rem}
.page-body h2,.page-body h3{margin:1.5em 0 .5em}
.page-body a{text-decoration:underline;text-decoration-color:var(--volt-deep);text-decoration-thickness:2px}

/* ============ MOBILE NAV ============ */
@media(max-width:900px){
  .nav-links{position:fixed;inset:0;flex-direction:column;justify-content:center;gap:14px;background:var(--bg);transform:translateY(-100%);transition:transform .6s var(--ease);z-index:90}
  .nav-links.open{transform:none}
  .nav-links a:not(.btn){font-size:1.6rem;font-family:var(--font-display);font-weight:700;opacity:1}
  .nav-toggle{display:block;position:relative;z-index:95}
  .nav .inner>.btn{display:none}
  .nav-links .btn{display:inline-flex;margin-top:10px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.001s!important;scroll-behavior:auto!important}
  .reveal,[data-stagger]>*{opacity:1;transform:none}
  .hero h1 .line>span{transform:none}
  body{cursor:auto}.cur,.cur-d{display:none}
}


/* ===== SERVICE DETAIL PAGE ===== */
.svc-hero{padding:clamp(130px,15vw,190px) 0 30px}
.svc-hero h1{font-size:clamp(2.2rem,6.5vw,4.6rem);line-height:1.02;margin:14px 0 18px}
.svc-hero .lead{max-width:680px;color:var(--muted)}
.back-link{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono),monospace;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);text-decoration:none;margin-bottom:22px;transition:color .25s}
.back-link:hover{color:var(--ink)}
.back-link svg{transition:transform .25s}
.back-link:hover svg{transform:translateX(-4px)}
.deliver-list{list-style:none;margin:26px 0 0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:14px 26px}
.deliver-list li{display:flex;gap:12px;align-items:flex-start;font-size:1.02rem}
.deliver-list .tick{flex:0 0 auto;width:22px;height:22px;border-radius:50%;background:var(--volt);color:var(--ink);display:grid;place-items:center;font-size:.74rem;font-weight:700;margin-top:2px}
.svc-bigicon{width:84px;height:84px;color:var(--volt);margin-bottom:18px}
.svc-bigicon svg{width:100%;height:100%}
.ben-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:46px}
.ben-card{background:var(--bg);border:1px solid var(--line);border-radius:20px;padding:30px 26px;position:relative;overflow:hidden;transition:transform .4s var(--ease),border-color .4s}
.ben-card:hover{transform:translateY(-6px);border-color:var(--ink)}
.ben-num{font-family:var(--font-mono),monospace;font-size:.82rem;color:var(--volt);font-weight:700}
.ben-card h3{font-size:1.28rem;margin:14px 0 8px}
.ben-card p{color:var(--muted);font-size:.98rem;line-height:1.55}
.rel-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:40px}
.rel-card{display:flex;flex-direction:column;gap:14px;background:var(--bg);border:1px solid var(--line);border-radius:18px;padding:26px 22px;text-decoration:none;color:var(--ink);position:relative;transition:transform .4s var(--ease),border-color .4s,background .4s}
.rel-card:hover{transform:translateY(-6px);border-color:var(--ink);background:var(--ink);color:#fff}
.rel-ic{width:40px;height:40px;color:var(--volt)}
.rel-ic svg{width:100%;height:100%}
.rel-card b{font-size:1.06rem;line-height:1.25}
.rel-arrow{position:absolute;top:22px;right:20px;opacity:.4;transition:opacity .3s,transform .3s}
.rel-card:hover .rel-arrow{opacity:1;transform:translate(3px,-3px)}
@media(max-width:900px){.deliver-list{grid-template-columns:1fr}.ben-grid{grid-template-columns:1fr}.rel-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.rel-grid{grid-template-columns:1fr}}

/* ==========================================================================
   MOBILE / RESPONSIVE OVERHAUL  v2.2.0
   ========================================================================== */

/* 1) Kill horizontal overflow & swipe-to-empty-space */
html{overflow-x:clip;-webkit-text-size-adjust:100%}
body{overflow-x:clip;max-width:100%;position:relative}
*{min-width:0}                 /* let flex/grid children shrink instead of overflowing */
img,svg,video,canvas,iframe{max-width:100%;height:auto}
.wrap,.page-body{max-width:100%}

/* 2) Touch devices: disable the custom cursor entirely (was floating/glitching) */
@media(hover:none),(pointer:coarse){
  body,a,button,.btn,[data-cursor],[data-magnetic]{cursor:auto !important}
  .cur,.cur-d{display:none !important}
}

/* 3) TABLET  (<=900px) ---------------------------------------------------- */
@media(max-width:900px){
  .feat{grid-template-columns:1fr;gap:34px}
  .feat .panel{order:-1}
  .shead{grid-template-columns:1fr;gap:14px;align-items:start}
  .tgrid{grid-template-columns:1fr 1fr}
  .prices{grid-template-columns:1fr;max-width:460px;margin-left:auto;margin-right:auto}
  .price.pop{transform:none}
  .stats{grid-template-columns:1fr 1fr;gap:24px}
  .steps{grid-template-columns:1fr;gap:18px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px}
}

/* 4) PHONE  (<=640px) ----------------------------------------------------- */
@media(max-width:640px){
  body{font-size:16px}
  .wrap{padding:0 20px}
  .pad{padding:64px 0}

  /* Nav bar: compact + always solid so it never flickers transparent */
  .nav .inner{padding:14px 20px}
  .nav.scrolled{background:var(--bg)}
  .brand{font-size:1rem}
  .brand .mark{width:30px;height:30px;font-size:.95rem}

  /* Hero */
  .hero{padding-top:120px}
  .hero h1{font-size:clamp(2.6rem,13vw,4rem);letter-spacing:-.02em;line-height:1.1}
  .hero .top p{font-size:1rem}
  .hero-foot{flex-direction:column;align-items:flex-start;gap:22px}
  .hero-cta{display:flex;flex-direction:column;width:100%;gap:12px}
  .hero-cta .btn{width:100%;justify-content:center}
  .scrollcue{display:none}

  /* Buttons: full-width, comfortable tap targets */
  .btn{padding:15px 24px;font-size:1rem}
  .page-hero .btn,.svc-hero .btn,.cta-band .btn{width:100%;justify-content:center}
  .svc-hero div[style*="flex"]{flex-direction:column;align-items:stretch !important}

  /* Section headings */
  h2{font-size:clamp(1.9rem,8vw,2.6rem)}
  .page-hero h1,.svc-hero h1{font-size:clamp(2.1rem,10vw,3rem)}
  .lead{font-size:1.02rem}

  /* Grids -> single column */
  .tgrid,.stats,.foot-grid,.rel-grid{grid-template-columns:1fr}
  .stats{gap:10px;text-align:center}
  .stat b{font-size:clamp(2.4rem,14vw,3.4rem)}

  /* Services list rows: stack number/name/desc cleanly */
  .svc-row{grid-template-columns:auto 1fr auto;gap:6px 14px;padding:22px 4px}
  .svc-row .svc-desc{grid-column:1 / -1;font-size:.92rem;opacity:.7}

  /* Service detail */
  .deliver-list{gap:12px}
  .svc-bigicon{width:64px;height:64px}
  .ben-card{padding:26px 22px}

  /* Contact form */
  .contact{grid-template-columns:1fr;margin-top:26px}
  .contact .full,.contact .field.full{grid-column:auto}

  /* CTA band & footer */
  .cta-band{padding:40px 26px;border-radius:24px}
  .foot .huge{font-size:clamp(2.6rem,15vw,4.5rem)}
  .foot-bottom{flex-direction:column;gap:12px;text-align:center}

  /* Marquee a touch smaller */
  .marquee{padding:16px 0}

  /* FAQ tap target */
  .qa button{padding:18px 4px}
}

/* 5) Small phones (<=380px) extra safety */
@media(max-width:380px){
  .hero h1{font-size:11.5vw}
  .brand{font-size:.92rem}
}