/* ============================================================
   Nero Luck Web Developers — custom site design system
   Colors carried over from the original WordPress build.
   ============================================================ */
:root{
  --bg:#0a0e1a;            /* darkest navy */
  --bg-2:#111733;          /* secondary navy */
  --surface:#141b30;       /* cards */
  --surface-2:#1a2238;     /* raised cards */
  --violet:#6d5efc;        /* primary accent */
  --violet-light:#8b7dff;
  --violet-deep:#5546e0;
  --cyan:#22d3ee;          /* secondary accent */
  --text:#eef1f7;
  --muted:#97a3bd;
  --muted-2:#6f7b96;
  --border:rgba(255,255,255,.08);
  --border-strong:rgba(255,255,255,.15);
  --grad:linear-gradient(135deg,var(--violet),var(--cyan));
  --grad-soft:linear-gradient(135deg,rgba(109,94,252,.18),rgba(34,211,238,.14));
  --radius:18px;
  --radius-lg:26px;
  --maxw:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --shadow:0 24px 60px -20px rgba(0,0,0,.65);
  --glow:0 0 0 1px rgba(109,94,252,.35),0 18px 50px -12px rgba(109,94,252,.55);
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:auto;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--bg);color:var(--text);
  line-height:1.6;font-size:16px;
  overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
::selection{background:var(--violet);color:#fff}
h1,h2,h3,h4{font-family:'Space Grotesk',sans-serif;font-weight:700;line-height:1.08;letter-spacing:-.02em}

/* custom scrollbar */
::-webkit-scrollbar{width:10px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:#26304d;border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:var(--violet)}

/* subtle film grain for a premium feel */
body::after{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- layout ---------- */
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
section{position:relative}
.section{padding:120px 0}
.section-sm{padding:80px 0}
.bg-2{background:var(--bg-2)}
.center{text-align:center}
.eyebrow{
  display:inline-block;font-family:'Space Grotesk',sans-serif;font-weight:600;
  font-size:.8rem;letter-spacing:.28em;text-transform:uppercase;color:var(--cyan);
  margin-bottom:18px;
}
.eyebrow::before{content:"";display:inline-block;width:26px;height:1px;background:var(--cyan);vertical-align:middle;margin-right:12px;opacity:.7}
.h-xl{font-size:clamp(2.6rem,6vw,4.6rem)}
.h-lg{font-size:clamp(2rem,4.5vw,3.2rem)}
.h-md{font-size:clamp(1.5rem,3vw,2.1rem)}
.lead{font-size:1.13rem;color:var(--muted);max-width:620px}
.section-head{max-width:680px;margin:0 auto 64px}
.section-head.left{margin-left:0}
.muted{color:var(--muted)}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:.98rem;
  padding:15px 30px;border-radius:60px;transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .3s;
  white-space:nowrap;position:relative;will-change:transform;
}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--violet);color:#fff;box-shadow:0 14px 34px -10px rgba(109,94,252,.7)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 22px 48px -10px rgba(109,94,252,.85);background:var(--violet-light)}
.btn-ghost{background:rgba(255,255,255,.04);color:var(--text);border:1px solid var(--border-strong)}
.btn-ghost:hover{transform:translateY(-3px);border-color:var(--violet);background:rgba(109,94,252,.12)}
.btn-cyan{background:var(--cyan);color:#04222b}
.btn-cyan:hover{transform:translateY(-3px);box-shadow:0 18px 40px -12px rgba(34,211,238,.7)}
.btn-dark{background:#070a12;color:#fff}
.btn-dark:hover{transform:translateY(-3px)}
.btn-block{width:100%;justify-content:center}
.btn-lg{padding:18px 38px;font-size:1.05rem}

/* ---------- nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;transition:background .4s,backdrop-filter .4s,border-color .4s,padding .4s;border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(10,14,26,.82);backdrop-filter:blur(16px);border-color:var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand{display:flex;align-items:center;gap:11px;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.18rem;letter-spacing:-.01em}
.brand .logo{width:34px;height:34px;border-radius:10px;background:var(--grad);display:grid;place-items:center;font-size:1rem;box-shadow:0 8px 20px -6px rgba(109,94,252,.7)}
.brand b{color:var(--cyan);font-weight:700}
.nav-links{display:flex;align-items:center;gap:34px}
.nav-links a{font-size:.95rem;color:var(--muted);font-weight:500;transition:color .25s;position:relative}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--grad);transition:width .3s var(--ease)}
.nav-links a:hover,.nav-links a.active{color:var(--text)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:16px}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:8px}
.nav-toggle span{width:24px;height:2px;background:var(--text);border-radius:2px;transition:.3s}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;padding-top:90px}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.34}
.hero-bg::after{content:"";position:absolute;inset:0;background:
  radial-gradient(60% 60% at 70% 30%,rgba(109,94,252,.25),transparent 70%),
  linear-gradient(180deg,rgba(10,14,26,.7),var(--bg) 92%),
  linear-gradient(90deg,var(--bg) 8%,transparent 60%)}
#hero-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:1;opacity:.8}
.orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5;z-index:0}
.orb-1{width:480px;height:480px;background:rgba(109,94,252,.5);top:-120px;right:-80px;animation:float 14s ease-in-out infinite}
.orb-2{width:380px;height:380px;background:rgba(34,211,238,.35);bottom:-120px;left:-60px;animation:float 18s ease-in-out infinite reverse}
@keyframes float{0%,100%{transform:translate(0,0)}50%{transform:translate(40px,-40px)}}
.hero-inner{position:relative;z-index:3;max-width:880px}
.hero h1{font-size:clamp(2.8rem,7vw,5.3rem);margin:22px 0}
.hero .lead{font-size:1.22rem;max-width:640px;margin-bottom:38px}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}
.hero-badge{display:inline-flex;align-items:center;gap:10px;padding:8px 16px;border-radius:60px;background:rgba(255,255,255,.05);border:1px solid var(--border-strong);font-size:.86rem;color:var(--muted)}
.hero-badge .dot{width:8px;height:8px;border-radius:50%;background:var(--cyan);box-shadow:0 0 12px var(--cyan)}
.scroll-cue{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:3;font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-2);display:flex;flex-direction:column;align-items:center;gap:10px}
.scroll-cue .line{width:1px;height:46px;background:linear-gradient(var(--cyan),transparent);animation:cue 2s ease-in-out infinite}
@keyframes cue{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* ---------- marquee ---------- */
.marquee{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:26px 0;overflow:hidden;white-space:nowrap;background:var(--bg)}
.marquee-track{display:inline-flex;gap:60px;animation:scroll-x 28s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee span{font-family:'Space Grotesk',sans-serif;font-size:1.5rem;font-weight:600;color:var(--muted-2);display:inline-flex;align-items:center;gap:60px}
.marquee span::after{content:"✦";color:var(--violet);font-size:1rem}
@keyframes scroll-x{to{transform:translateX(-50%)}}

/* ---------- stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat{text-align:center;padding:36px 20px;border:1px solid var(--border);border-radius:var(--radius);background:linear-gradient(180deg,var(--surface),transparent)}
.stat .num{font-family:'Space Grotesk',sans-serif;font-size:clamp(2.2rem,4vw,3rem);font-weight:700;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stat .label{font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:8px}

/* ---------- generic grid ---------- */
.grid{display:grid;gap:24px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}

/* feature / service cards */
.card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:38px 32px;transition:transform .4s var(--ease),border-color .4s,background .4s;position:relative;overflow:hidden;
}
.card::before{content:"";position:absolute;inset:0;background:var(--grad-soft);opacity:0;transition:opacity .4s}
.card:hover{transform:translateY(-8px);border-color:var(--border-strong)}
.card:hover::before{opacity:1}
.card>*{position:relative;z-index:1}
.card .ic{width:56px;height:56px;border-radius:15px;display:grid;place-items:center;background:rgba(109,94,252,.14);border:1px solid rgba(109,94,252,.25);margin-bottom:22px;font-size:1.5rem}
.card h3{font-size:1.25rem;margin-bottom:12px}
.card p{color:var(--muted);font-size:.97rem}

/* ---------- showcase / portfolio ---------- */
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.work{border-radius:var(--radius-lg);overflow:hidden;background:var(--surface);border:1px solid var(--border);transition:transform .45s var(--ease),border-color .45s,box-shadow .45s}
.work:hover{transform:translateY(-10px);border-color:var(--border-strong);box-shadow:var(--shadow)}
.browser{background:#0d1424;padding:11px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
.browser .dots{display:flex;gap:6px}
.browser .dots i{width:11px;height:11px;border-radius:50%;display:block}
.browser .dots i:nth-child(1){background:#ff5f57}.browser .dots i:nth-child(2){background:#febc2e}.browser .dots i:nth-child(3){background:#28c840}
.browser .url{flex:1;background:#070b16;border-radius:7px;padding:5px 12px;font-size:.74rem;color:var(--muted-2);text-align:center;border:1px solid var(--border)}
.work-img{position:relative;aspect-ratio:16/10;overflow:hidden}
.work-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.work:hover .work-img img{transform:scale(1.07)}
.work-meta{display:flex;align-items:center;justify-content:space-between;padding:20px 22px}
.work-meta h4{font-size:1.12rem}
.work-meta .tag{font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cyan);background:rgba(34,211,238,.1);border:1px solid rgba(34,211,238,.22);padding:5px 12px;border-radius:30px}

/* ---------- split / about ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.split .media{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border)}
.split .media img{width:100%;aspect-ratio:4/4.4;object-fit:cover}
.split .media::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent,rgba(109,94,252,.18))}
.media-badge{position:absolute;bottom:22px;left:22px;z-index:2;background:rgba(10,14,26,.78);backdrop-filter:blur(10px);border:1px solid var(--border-strong);border-radius:16px;padding:16px 20px}
.media-badge b{font-family:'Space Grotesk',sans-serif;font-size:1.6rem;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.tick-list li{display:flex;gap:13px;align-items:flex-start;margin:14px 0;color:var(--muted)}
.tick-list li b{color:var(--text);font-weight:600}
.tick-list .ck{flex:none;width:24px;height:24px;border-radius:50%;background:rgba(34,211,238,.13);border:1px solid rgba(34,211,238,.3);display:grid;place-items:center;color:var(--cyan);font-size:.8rem;margin-top:2px}

/* ---------- pricing ---------- */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;align-items:start}
.price{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px 32px;transition:transform .4s var(--ease),border-color .4s}
.price:hover{transform:translateY(-8px);border-color:var(--border-strong)}
.price.featured{background:linear-gradient(180deg,rgba(109,94,252,.16),var(--surface));border-color:rgba(109,94,252,.5);box-shadow:var(--glow)}
.price .pop{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--violet);color:#fff;font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:7px 16px;border-radius:30px;white-space:nowrap}
.price h3{font-size:1.3rem;margin-bottom:6px}
.price .sub{color:var(--muted);font-size:.9rem;margin-bottom:24px}
.price .amount{font-family:'Space Grotesk',sans-serif;font-size:3rem;font-weight:700;line-height:1}
.price .amount small{font-size:1rem;color:var(--muted);font-weight:500}
.price .was{color:var(--muted-2);text-decoration:line-through;font-size:1.2rem;margin-right:8px;font-family:'Space Grotesk'}
.price ul{margin:26px 0 30px}
.price ul li{display:flex;gap:11px;align-items:flex-start;margin:13px 0;font-size:.95rem;color:var(--muted)}
.price ul li .ck{flex:none;width:20px;height:20px;border-radius:50%;background:rgba(109,94,252,.16);display:grid;place-items:center;color:var(--violet-light);font-size:.7rem;margin-top:2px}

/* ---------- refund promise band ---------- */
.promise{background:linear-gradient(180deg,var(--bg-2),var(--bg));border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.promise .inner{max-width:760px;margin:0 auto;text-align:center}
.promise .seal{width:74px;height:74px;border-radius:50%;margin:0 auto 24px;display:grid;place-items:center;background:var(--grad-soft);border:1px solid rgba(34,211,238,.3);font-size:1.8rem}

/* ---------- cta band ---------- */
.cta-band{background:var(--grad);color:#04161b;text-align:center;border-radius:0}
.cta-band h2{color:#06121b;font-size:clamp(2rem,4.5vw,3.2rem)}
.cta-band p{color:rgba(6,18,27,.75);font-size:1.1rem;margin:16px auto 32px;max-width:560px}

/* ---------- testimonials ---------- */
.quote{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:34px}
.quote p{font-size:1.04rem;margin-bottom:22px}
.quote .who{display:flex;align-items:center;gap:14px}
.quote .av{width:46px;height:46px;border-radius:50%;background:var(--grad);display:grid;place-items:center;font-weight:700;font-family:'Space Grotesk'}
.quote .who b{display:block;font-size:.96rem}
.quote .who span{font-size:.82rem;color:var(--muted)}
.stars{color:var(--cyan);margin-bottom:16px;letter-spacing:3px}

/* ---------- forms ---------- */
.field{margin-bottom:20px}
.field label{display:block;font-size:.88rem;font-weight:500;margin-bottom:9px;color:var(--text)}
.field input,.field textarea,.field select{
  width:100%;padding:14px 16px;background:var(--bg);border:1px solid var(--border-strong);
  border-radius:13px;color:var(--text);font-family:inherit;font-size:.97rem;transition:border-color .25s,box-shadow .25s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--violet);box-shadow:0 0 0 3px rgba(109,94,252,.18)}
.field textarea{resize:vertical;min-height:130px}
.form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px}
.checkbox{display:flex;gap:13px;align-items:flex-start;cursor:pointer;font-size:.92rem;color:var(--muted)}
.checkbox input{width:20px;height:20px;flex:none;margin-top:2px;accent-color:var(--violet);cursor:pointer}
.checkbox a{color:var(--cyan);text-decoration:underline}

/* ---------- order options ---------- */
.plan-pick{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:10px}
.plan-opt{position:relative;border:1px solid var(--border-strong);border-radius:var(--radius);padding:24px;cursor:pointer;transition:border-color .3s,background .3s}
.plan-opt:hover{border-color:var(--violet)}
.plan-opt input{position:absolute;opacity:0}
.plan-opt.sel{border-color:var(--violet);background:rgba(109,94,252,.1);box-shadow:var(--glow)}
.plan-opt .pname{font-family:'Space Grotesk';font-weight:600;font-size:1.1rem}
.plan-opt .pprice{font-size:1.7rem;font-family:'Space Grotesk';font-weight:700;margin:6px 0}
.plan-opt .pprice small{font-size:.85rem;color:var(--muted)}

/* ---------- checkout ---------- */
.checkout-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:40px;align-items:start}
.summary{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:34px;position:sticky;top:100px}
.summary .row{display:flex;justify-content:space-between;padding:13px 0;border-bottom:1px solid var(--border);font-size:.96rem}
.summary .row.total{border:none;font-size:1.3rem;font-family:'Space Grotesk';font-weight:700;padding-top:18px}
.summary .row.total .grad-text{font-size:1.6rem}
#paypal-buttons{margin-top:22px;min-height:50px}
.pay-note{font-size:.82rem;color:var(--muted-2);margin-top:16px;text-align:center;display:flex;align-items:center;justify-content:center;gap:8px}
.disabled-pay{opacity:.4;pointer-events:none;filter:grayscale(.4)}

/* ---------- legal / prose ---------- */
.prose{max-width:820px;margin:0 auto}
.prose h2{font-size:1.5rem;margin:42px 0 14px}
.prose h3{font-size:1.15rem;margin:28px 0 10px;color:var(--text)}
.prose p,.prose li{color:var(--muted);margin-bottom:14px;font-size:1rem}
.prose ul{margin:0 0 18px 4px}
.prose ul li{display:flex;gap:11px}
.prose ul li::before{content:"—";color:var(--violet-light);flex:none}
.prose strong{color:var(--text)}
.prose a{color:var(--cyan);text-decoration:underline}
.legal-meta{color:var(--muted-2);font-size:.9rem;margin-bottom:30px;padding-bottom:24px;border-bottom:1px solid var(--border)}
.notice{background:rgba(34,211,238,.07);border:1px solid rgba(34,211,238,.22);border-radius:14px;padding:18px 22px;margin:24px 0;font-size:.92rem;color:var(--muted)}

/* page hero (inner pages) */
.page-hero{padding:160px 0 70px;text-align:center;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;top:-200px;left:50%;transform:translateX(-50%);width:700px;height:500px;background:radial-gradient(circle,rgba(109,94,252,.22),transparent 70%);z-index:0}
.page-hero>*{position:relative;z-index:1}
.breadcrumb{font-size:.85rem;color:var(--muted-2);margin-top:16px}
.breadcrumb a:hover{color:var(--cyan)}

/* ---------- footer ---------- */
.footer{background:#070a12;border-top:1px solid var(--border);padding:80px 0 36px}
.footer-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:54px}
.footer .brand{margin-bottom:18px}
.footer-col h5{font-family:'Space Grotesk';font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2);margin-bottom:18px}
.footer-col a{display:block;color:var(--muted);font-size:.95rem;margin-bottom:12px;transition:color .25s,padding .25s}
.footer-col a:hover{color:var(--cyan);padding-left:4px}
.footer-about p{color:var(--muted);font-size:.95rem;max-width:300px;margin-bottom:20px}
.socials{display:flex;gap:12px}
.socials a{width:40px;height:40px;border-radius:11px;border:1px solid var(--border-strong);display:grid;place-items:center;color:var(--muted);transition:.3s}
.socials a:hover{background:var(--violet);color:#fff;border-color:var(--violet);transform:translateY(-3px)}
.footer-bottom{border-top:1px solid var(--border);padding-top:28px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;color:var(--muted-2);font-size:.88rem}
.footer-bottom a{color:var(--muted)}
.footer-bottom a:hover{color:var(--cyan)}

/* ---------- reveal animations ---------- */
.reveal{opacity:0;transform:translateY(38px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.1s}.reveal[data-d="2"]{transition-delay:.2s}
.reveal[data-d="3"]{transition-delay:.3s}.reveal[data-d="4"]{transition-delay:.4s}
.reveal[data-d="5"]{transition-delay:.5s}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}*{animation:none!important}}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .nav-links,.nav-cta .btn{display:none}
  .nav-toggle{display:flex}
  .nav.open .nav-links{display:flex;position:absolute;top:78px;left:0;right:0;flex-direction:column;background:rgba(10,14,26,.97);backdrop-filter:blur(16px);padding:26px 24px;gap:20px;border-bottom:1px solid var(--border)}
  .nav.open .nav-links a{font-size:1.1rem}
  .split,.checkout-grid{grid-template-columns:1fr;gap:40px}
  .summary{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:720px){
  .section{padding:84px 0}
  .grid-3,.grid-4,.work-grid,.pricing,.plan-pick{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .price.featured{transform:none}
  .footer-grid{grid-template-columns:1fr}
  .hero .lead{font-size:1.08rem}
  .cta-band .btn,.hero-actions .btn{width:100%;justify-content:center}
}

/* ============================================================
   v2 — equal pricing · decorative backgrounds · premium polish
   ============================================================ */

/* --- pricing: left & right equal height, featured pops out --- */
.pricing{align-items:stretch}
.price{display:flex;flex-direction:column}
.price ul{margin:26px 0 28px}
.price>.btn{margin-top:auto}
@media(min-width:721px){
  .price.featured{transform:scale(1.05);z-index:2}
  .price.featured:hover{transform:scale(1.05) translateY(-8px)}
}

/* --- decorative layers: drop a <div class="deco"> inside any section --- */
.has-deco{overflow:hidden}
.deco{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.section>.container,.section-sm>.container,.promise>.container{position:relative;z-index:2}
.glow-orb{position:absolute;border-radius:50%;filter:blur(110px)}
.glow-orb.v{background:radial-gradient(circle,rgba(109,94,252,.55),transparent 62%)}
.glow-orb.c{background:radial-gradient(circle,rgba(34,211,238,.42),transparent 62%)}
.glow-orb.pulse{animation:pulse 9s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:.85;transform:scale(1.15)}}
.deco-dots{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.08) 1px,transparent 1px);background-size:30px 30px;-webkit-mask-image:radial-gradient(ellipse 60% 60% at 50% 50%,#000,transparent 78%);mask-image:radial-gradient(ellipse 60% 60% at 50% 50%,#000,transparent 78%)}
.deco-grid{position:absolute;inset:-1px;background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);background-size:66px 66px;-webkit-mask-image:linear-gradient(180deg,transparent,#000 25%,#000 75%,transparent);mask-image:linear-gradient(180deg,transparent,#000 25%,#000 75%,transparent)}
.ring{position:absolute;border-radius:50%;border:1px solid rgba(139,125,255,.16)}
.ring.spin{animation:spin 38s linear infinite}
.ring.spin.rev{animation-direction:reverse}
.ring::after{content:"";position:absolute;width:7px;height:7px;border-radius:50%;background:var(--cyan);top:-4px;left:calc(50% - 4px);box-shadow:0 0 16px 2px var(--cyan)}
@keyframes spin{to{transform:rotate(360deg)}}
.cross{position:absolute;color:rgba(139,125,255,.28);font-size:1.1rem;animation:floaty 11s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-26px) rotate(45deg)}}
.aurora{position:absolute;inset:0;background:radial-gradient(42% 52% at 12% 18%,rgba(109,94,252,.20),transparent 60%),radial-gradient(42% 52% at 88% 82%,rgba(34,211,238,.17),transparent 60%);animation:auroramove 16s ease-in-out infinite alternate}
@keyframes auroramove{0%{transform:translate3d(0,0,0) scale(1)}100%{transform:translate3d(0,-3%,0) scale(1.08)}}

/* --- premium polish --- */
.stat{backdrop-filter:blur(6px);transition:transform .4s var(--ease),border-color .4s,box-shadow .4s}
.stat::after{content:"";position:absolute;top:0;left:20%;right:20%;height:1px;background:var(--grad);opacity:.7}
.stat:hover{transform:translateY(-5px);border-color:rgba(109,94,252,.4);box-shadow:0 22px 50px -26px rgba(109,94,252,.6)}
.card{backdrop-filter:blur(5px)}
.card .ic{transition:transform .4s var(--ease),box-shadow .4s}
.card:hover .ic{transform:translateY(-3px) scale(1.06);box-shadow:0 14px 30px -10px rgba(109,94,252,.6)}
.work,.price,.quote{backdrop-filter:blur(5px)}
.hairline{height:1px;background:linear-gradient(90deg,transparent,var(--border-strong) 50%,transparent);max-width:var(--maxw);margin:0 auto}

/* --- testimonials --- */
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}

/* --- FAQ (services) --- */
.faq{max-width:820px;margin:0 auto}
.faq-item{border:1px solid var(--border);border-radius:16px;background:var(--surface);margin-bottom:14px;overflow:hidden;transition:border-color .3s}
.faq-item[open]{border-color:rgba(109,94,252,.45)}
.faq-item summary{padding:22px 26px;cursor:pointer;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:1.05rem;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";color:var(--violet-light);font-size:1.6rem;line-height:1;transition:transform .3s}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item .a{padding:0 26px 24px;color:var(--muted)}

/* --- deliverables grid (services) --- */
.deliver{display:grid;grid-template-columns:repeat(2,1fr);gap:0 36px}
.deliver li{display:flex;gap:12px;align-items:flex-start;color:var(--muted);padding:14px 0;border-bottom:1px solid var(--border)}
.deliver li .ck{flex:none;width:22px;height:22px;border-radius:50%;background:rgba(34,211,238,.13);border:1px solid rgba(34,211,238,.3);display:grid;place-items:center;color:var(--cyan);font-size:.72rem;margin-top:1px}
.deliver li b{color:var(--text)}

@media(max-width:720px){.tgrid,.deliver{grid-template-columns:1fr}}

/* ============================================================
   v3 — clickable showcase · floating button · newsletter
   ============================================================ */

/* showcase cards become clickable with a hover button */
.work{display:block}
.work-img{position:relative}
.work-view{position:absolute;inset:0;display:grid;place-items:center;opacity:0;transition:opacity .45s var(--ease);background:linear-gradient(0deg,rgba(8,11,20,.85),rgba(8,11,20,.22))}
.work:hover .work-view{opacity:1}
.work-view .pill{display:inline-flex;align-items:center;gap:8px;background:var(--violet);color:#fff;padding:12px 26px;border-radius:40px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.92rem;transform:translateY(12px);transition:transform .45s var(--ease);box-shadow:0 12px 30px -8px rgba(109,94,252,.85)}
.work:hover .work-view .pill{transform:translateY(0)}
.browser .url .lk{color:var(--cyan);margin-right:4px}

/* floating "see samples" button — always visible */
.fab{position:fixed;right:26px;bottom:26px;z-index:900;display:inline-flex;align-items:center;gap:9px;background:var(--violet);color:#fff;padding:14px 24px;border-radius:50px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.92rem;box-shadow:0 16px 44px -10px rgba(109,94,252,.85);animation:fabbob 2.8s ease-in-out infinite;transition:transform .3s var(--ease)}
.fab:hover{transform:translateY(-3px) scale(1.05);animation-play-state:paused}
.fab::before{content:"";position:absolute;inset:0;border-radius:50px;border:2px solid var(--violet-light);opacity:.6;animation:fabring 2.4s ease-out infinite;pointer-events:none}
@keyframes fabbob{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
@keyframes fabring{0%{transform:scale(1);opacity:.55}100%{transform:scale(1.45);opacity:0}}
@media(max-width:720px){.fab{right:16px;bottom:16px;padding:12px 18px;font-size:.84rem}}

/* newsletter */
.news{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-lg);padding:56px 48px;text-align:center;position:relative;overflow:hidden;max-width:900px;margin:0 auto;z-index:2}
.news h2{font-size:clamp(1.7rem,3.5vw,2.4rem);margin-bottom:12px}
.news p{color:var(--muted);margin:0 auto 28px;max-width:500px}
.news form{display:flex;gap:12px;max-width:500px;margin:0 auto}
.news input{flex:1;padding:15px 22px;background:var(--bg);border:1px solid var(--border-strong);border-radius:50px;color:var(--text);font-family:inherit;font-size:.97rem;transition:border-color .25s,box-shadow .25s}
.news input:focus{outline:none;border-color:var(--violet);box-shadow:0 0 0 3px rgba(109,94,252,.18)}
.news .ok{color:var(--cyan);margin-top:18px;font-weight:600}
@media(max-width:560px){.news{padding:40px 24px}.news form{flex-direction:column}.news .btn{width:100%;justify-content:center}}

/* trust badges (refund promise) */
.badges{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:36px}
.badge{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border-strong);border-radius:50px;padding:12px 22px;font-size:.9rem;font-weight:500}
.badge .bi{color:var(--cyan);font-size:1.05rem}

/* cta band floating shapes */
.cta-band{position:relative;overflow:hidden}
.cta-shape{position:absolute;border-radius:24px;background:rgba(255,255,255,.13);pointer-events:none;animation:floaty 9s ease-in-out infinite}

/* ============================================================
   v4 — web-design themed showcase side decorations
   ============================================================ */
.ui-chip{position:absolute;width:174px;background:var(--surface);border:1px solid var(--border-strong);border-radius:13px;box-shadow:0 26px 54px -22px rgba(0,0,0,.75);padding:10px;opacity:.62;animation:floaty 13s ease-in-out infinite;pointer-events:none}
.ui-chip .bar{display:flex;gap:5px;margin-bottom:8px}
.ui-chip .bar i{width:7px;height:7px;border-radius:50%;background:#3a445f;display:block}
.ui-chip .img{height:48px;border-radius:8px;background:linear-gradient(120deg,rgba(109,94,252,.5),rgba(34,211,238,.3));margin-bottom:9px}
.ui-chip .ln{height:7px;border-radius:5px;background:#2b3552;margin:6px 0}
.ui-chip .ln.a{background:linear-gradient(90deg,var(--violet-light),transparent);width:72%}
.ui-chip .ln.b{width:92%}.ui-chip .ln.c{width:48%}
.glyph{position:absolute;font-family:'Space Grotesk',sans-serif;font-weight:700;color:rgba(139,125,255,.20);animation:floaty 12s ease-in-out infinite;pointer-events:none;line-height:1}
@media(max-width:1400px){.ui-chip{display:none}}
@media(max-width:980px){.glyph{display:none}}

/* toast (coming-soon notices) */
.toast{position:fixed;left:50%;bottom:34px;transform:translateX(-50%) translateY(22px);background:var(--surface);border:1px solid var(--border-strong);color:var(--text);padding:14px 26px;border-radius:50px;font-weight:600;font-size:.93rem;box-shadow:0 24px 50px -16px rgba(0,0,0,.7);z-index:3000;opacity:0;transition:opacity .35s var(--ease),transform .35s var(--ease);pointer-events:none;max-width:90vw;text-align:center}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
