/* ============================================================
   BUZZ NOW SOLUTIONS — SHARED DESIGN SYSTEM
   Brand: Violet/Purple gradient (#9333EA → #6D28D9)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

/* === CSS VARIABLES === */
:root {
  --brand:       #9333EA;
  --brand-light: #A855F7;
  --brand-dark:  #7C3AED;
  --brand-deep:  #5B21B6;
  --brand-glow:  rgba(147,51,234,0.35);
  --brand-border:rgba(147,51,234,0.28);

  /* Dark tokens */
  --dark-bg:      #08080F;
  --dark-surf:    #0E0D1E;
  --dark-surf2:   #15142A;
  --dark-surf3:   #1D1B38;
  --dark-border:  rgba(255,255,255,0.07);
  --dark-border2: rgba(255,255,255,0.12);
  --dark-fg:      #F0EEFF;
  --dark-muted:   #9896BC;
  --dark-dim:     #5E5C88;

  /* Light tokens */
  --light-bg:     #FAFAFA;
  --light-surf:   #FFFFFF;
  --light-surf2:  #F5F3FF;
  --light-border: #E8E6F0;
  --light-border2:#D4D0E8;
  --light-fg:     #0D0C1A;
  --light-muted:  #6B698A;

  /* Semantic */
  --success: #10B981;
  --warning: #F59E0B;
  --info:    #0EA5E9;
  --danger:  #EF4444;

  /* Gradients */
  --grad-brand: linear-gradient(135deg,#C084FC 0%,#9333EA 40%,#6D28D9 70%,#4C1D95 100%);
  --grad-brand-h: linear-gradient(90deg,#C084FC 0%,#9333EA 50%,#6D28D9 100%);
  --grad-glow-top: radial-gradient(ellipse 80% 50% at 50% -10%,rgba(147,51,234,.2) 0%,transparent 65%);
  --grad-glow-bot: radial-gradient(ellipse 80% 50% at 50% 110%,rgba(147,51,234,.15) 0%,transparent 65%);
  --grad-card:  linear-gradient(135deg,rgba(255,255,255,.05) 0%,rgba(255,255,255,.02) 100%);

  /* Typography */
  --font: 'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  --mono: 'JetBrains Mono','Fira Code',ui-monospace,Menlo,monospace;

  /* Radius */
  --r-xs:4px; --r-sm:8px; --r-md:12px; --r-lg:16px;
  --r-xl:20px; --r-2xl:28px; --r-full:9999px;

  /* Shadows */
  --sh-sm:  0 1px 3px rgba(0,0,0,.25);
  --sh-md:  0 4px 16px rgba(0,0,0,.35);
  --sh-lg:  0 10px 40px rgba(0,0,0,.45);
  --sh-xl:  0 20px 60px rgba(0,0,0,.55);
  --sh-glow:0 0 30px rgba(147,51,234,.45),0 0 60px rgba(147,51,234,.15);
  --sh-card-dark: 0 4px 32px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.07);
  --sh-card-light:0 4px 24px rgba(0,0,0,.08),0 1px 4px rgba(0,0,0,.04);

  /* Transitions */
  --t-fast:  .15s cubic-bezier(.4,0,.2,1);
  --t-base:  .25s cubic-bezier(.4,0,.2,1);
  --t-slow:  .4s  cubic-bezier(.4,0,.2,1);
  --t-spring:.5s  cubic-bezier(.34,1.56,.64,1);
}

/* === FOOTER LOGO FIX === */
.footer-logo img{filter:brightness(0) invert(1)}

/* === RESET === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font);color:var(--dark-fg);background:var(--dark-bg);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img,svg,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,textarea,select{font-family:inherit}
ul,ol{list-style:none}

/* === SCROLL PROGRESS === */
.scroll-progress{position:fixed;top:0;left:0;width:0%;height:3px;background:var(--grad-brand-h);z-index:9999;transition:width .05s linear}

/* === NAVIGATION === */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:0 24px;height:68px;display:flex;align-items:center;transition:all var(--t-base)}
.nav.scrolled{background:rgba(8,8,15,.93);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--dark-border);box-shadow:0 4px 32px rgba(0,0,0,.4)}
.nav-inner{width:100%;max-width:1300px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-logo{display:flex;align-items:center;gap:8px;flex-shrink:0}
.nav-logo img{height:38px;width:auto;filter:brightness(0) invert(1);transition:filter var(--t-base)}
.nav-logo:hover img{filter:brightness(0) invert(1) drop-shadow(0 0 8px rgba(147,51,234,0.6))}
.nav-links{display:flex;align-items:center;gap:2px;flex:1;justify-content:center}
.nav-link{padding:7px 13px;border-radius:var(--r-sm);font-size:14px;font-weight:500;color:var(--dark-muted);transition:all var(--t-fast);white-space:nowrap}
.nav-link:hover,.nav-link.active{color:var(--dark-fg);background:rgba(255,255,255,.06)}
.nav-dropdown{position:relative}
.nav-dropdown-toggle{display:flex;align-items:center;gap:4px}
.nav-dropdown-toggle .chev{width:12px;height:12px;transition:transform var(--t-fast)}
.nav-dropdown:hover .chev{transform:rotate(180deg)}
.nav-dropdown-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%);background:var(--dark-surf2);border:1px solid var(--dark-border2);border-radius:var(--r-lg);padding:8px;padding-top:18px;min-width:230px;opacity:0;visibility:hidden;pointer-events:none;transition:all var(--t-base);box-shadow:var(--sh-xl);backdrop-filter:blur(20px);display:grid;grid-template-columns:1fr}
.nav-dropdown:hover .nav-dropdown-menu{opacity:1;visibility:visible;pointer-events:all}
.nav-dd-item{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:var(--r-sm);color:var(--dark-muted);font-size:13px;font-weight:500;transition:all var(--t-fast)}
.nav-dd-item:hover{color:var(--dark-fg);background:rgba(255,255,255,.06)}
.nav-dd-icon{width:30px;height:30px;border-radius:6px;background:rgba(147,51,234,.14);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--brand-light)}
.nav-dd-icon svg{width:14px;height:14px}
.nav-dd-label{font-size:12px;font-weight:600;color:var(--dark-fg);line-height:1.3}
.nav-dd-sub{font-size:11px;color:var(--dark-dim);line-height:1.2}
.nav-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--dark-fg);border-radius:2px;transition:all var(--t-base)}
.nav-mobile{position:fixed;top:68px;left:0;right:0;bottom:0;background:var(--dark-bg);z-index:999;padding:24px;overflow-y:auto;transform:translateX(100%);transition:transform var(--t-base)}
.nav-mobile.open{transform:translateX(0)}
.nav-mobile-link{display:flex;align-items:center;padding:14px 0;border-bottom:1px solid var(--dark-border);font-size:16px;font-weight:600;color:var(--dark-fg)}

/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--r-md);font-size:14px;font-weight:600;line-height:1;cursor:pointer;transition:all var(--t-base);white-space:nowrap;position:relative;overflow:hidden;text-decoration:none;border:none}
.btn svg{width:16px;height:16px;flex-shrink:0}
.btn-primary{background:var(--grad-brand);color:#fff;box-shadow:0 4px 20px rgba(147,51,234,.4)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 30px rgba(147,51,234,.55)}
.btn-outline{background:transparent;color:var(--dark-fg);border:1px solid var(--dark-border2)}
.btn-outline:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.2)}
.btn-ghost{background:transparent;color:var(--dark-muted)}
.btn-ghost:hover{color:var(--dark-fg);background:rgba(255,255,255,.06)}
.btn-light{background:#fff;color:var(--light-fg);box-shadow:var(--sh-sm)}
.btn-light:hover{transform:translateY(-1px);box-shadow:var(--sh-md)}
.btn-sm{padding:7px 14px;font-size:13px;border-radius:var(--r-sm)}
.btn-lg{padding:14px 28px;font-size:16px;border-radius:var(--r-lg)}
.btn-xl{padding:17px 36px;font-size:17px;border-radius:var(--r-lg)}

/* === LAYOUT === */
.container{width:100%;max-width:1300px;margin:0 auto;padding:0 24px}
.container-sm{width:100%;max-width:960px;margin:0 auto;padding:0 24px}
.container-xs{width:100%;max-width:720px;margin:0 auto;padding:0 24px}
.section{padding:100px 0}
.section-sm{padding:64px 0}
.section-lg{padding:140px 0}
.section-dark{background:var(--dark-bg);color:var(--dark-fg);position:relative}
.section-dark2{background:var(--dark-surf);color:var(--dark-fg);position:relative}
.section-dark3{background:var(--dark-surf2);color:var(--dark-fg);position:relative}
.section-light{background:var(--light-bg);color:var(--light-fg);position:relative}
.section-light2{background:var(--light-surf);color:var(--light-fg);position:relative}

/* === TYPOGRAPHY === */
.display-1{font-size:clamp(48px,7vw,92px);font-weight:800;line-height:1.04;letter-spacing:-.04em}
.display-2{font-size:clamp(40px,5.5vw,72px);font-weight:800;line-height:1.07;letter-spacing:-.035em}
.h1{font-size:clamp(32px,4vw,56px);font-weight:700;line-height:1.1;letter-spacing:-.03em}
.h2{font-size:clamp(26px,3.5vw,44px);font-weight:700;line-height:1.15;letter-spacing:-.025em}
.h3{font-size:clamp(20px,2.5vw,32px);font-weight:700;line-height:1.2;letter-spacing:-.02em}
.h4{font-size:clamp(16px,2vw,22px);font-weight:600;line-height:1.3;letter-spacing:-.01em}
.body-lg{font-size:18px;line-height:1.7}
.body{font-size:16px;line-height:1.65}
.body-sm{font-size:14px;line-height:1.6}
.caption{font-size:13px;line-height:1.5}
.overline{font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase}
.text-brand{color:var(--brand)}
.text-brand-light{color:var(--brand-light)}
.text-muted{color:var(--dark-muted)}
.text-dim{color:var(--dark-dim)}
.text-gradient{background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* === SECTION HEADER === */
.section-header{text-align:center;margin-bottom:64px}
.section-tag{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--r-full);background:rgba(147,51,234,.1);border:1px solid var(--brand-border);color:var(--brand-light);font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-bottom:20px}
.tag-dot{width:6px;height:6px;border-radius:50%;background:var(--brand);animation:pulse 2s infinite}
.section-title{font-size:clamp(28px,4vw,48px);font-weight:800;line-height:1.1;letter-spacing:-.03em;margin-bottom:16px}
.section-sub{font-size:18px;line-height:1.7;max-width:600px;margin:0 auto}
.section-dark .section-sub,.section-dark2 .section-sub,.section-dark3 .section-sub{color:var(--dark-muted)}
.section-light .section-sub,.section-light2 .section-sub{color:var(--light-muted)}

/* === GRIDS === */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}

/* === CARDS === */
.card-dark{background:var(--dark-surf);border:1px solid var(--dark-border);border-radius:var(--r-xl);padding:28px;transition:all var(--t-base)}
.card-dark:hover{border-color:var(--brand-border);transform:translateY(-3px);box-shadow:var(--sh-card-dark)}
.card-glass{background:rgba(255,255,255,.04);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-xl);padding:28px;transition:all var(--t-base)}
.card-glass:hover{background:rgba(255,255,255,.07);border-color:rgba(147,51,234,.25);transform:translateY(-3px)}
.card-light{background:var(--light-surf);border:1px solid var(--light-border);border-radius:var(--r-xl);padding:28px;box-shadow:var(--sh-card-light);transition:all var(--t-base)}
.card-light:hover{border-color:var(--brand-border);transform:translateY(-3px);box-shadow:0 8px 40px rgba(0,0,0,.1),0 0 0 1px rgba(147,51,234,.2)}

/* === SERVICE ICON === */
.svc-icon{width:52px;height:52px;border-radius:var(--r-md);background:rgba(147,51,234,.12);border:1px solid var(--brand-border);display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:var(--brand-light);transition:all var(--t-base);flex-shrink:0}
.svc-icon svg{width:24px;height:24px}
.card-dark:hover .svc-icon,.card-glass:hover .svc-icon{background:rgba(147,51,234,.22);box-shadow:0 0 20px rgba(147,51,234,.3)}

/* === BADGES === */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--r-full);font-size:12px;font-weight:600}
.badge-brand{background:rgba(147,51,234,.15);color:var(--brand-light);border:1px solid var(--brand-border)}
.badge-success{background:rgba(16,185,129,.12);color:#34D399;border:1px solid rgba(16,185,129,.2)}
.badge-warning{background:rgba(245,158,11,.12);color:#FCD34D;border:1px solid rgba(245,158,11,.2)}
.badge-info{background:rgba(14,165,233,.12);color:#38BDF8;border:1px solid rgba(14,165,233,.2)}

/* === METRICS === */
.metric-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:var(--r-full);font-size:13px;font-weight:700}
.metric-up{background:rgba(16,185,129,.12);color:#34D399;border:1px solid rgba(16,185,129,.2)}
.metric-down{background:rgba(239,68,68,.12);color:#FCA5A5;border:1px solid rgba(239,68,68,.2)}

/* === STAT COUNTER === */
.stat-card{text-align:center;padding:32px 24px}
.stat-value{font-size:clamp(36px,5vw,60px);font-weight:800;letter-spacing:-.04em;line-height:1;margin-bottom:8px}
.stat-label{font-size:14px;font-weight:500}

/* === GLOW ORBS === */
.orb{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;z-index:0}
.orb-brand{background:rgba(147,51,234,.22)}
.orb-blue{background:rgba(59,130,246,.12)}
.orb-cyan{background:rgba(6,182,212,.12)}

/* === TAGS === */
.tag{display:inline-flex;align-items:center;padding:4px 12px;border-radius:var(--r-full);font-size:12px;font-weight:500;background:var(--dark-surf2);color:var(--dark-muted);border:1px solid var(--dark-border)}
.tag-brand{background:rgba(147,51,234,.1);color:var(--brand-light);border-color:var(--brand-border)}

/* === FORMS === */
.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.form-label{font-size:14px;font-weight:500;color:var(--dark-fg)}
.form-label.light{color:var(--light-fg)}
.form-input{background:var(--dark-surf2);border:1px solid var(--dark-border);border-radius:var(--r-md);padding:12px 16px;font-size:15px;color:var(--dark-fg);transition:all var(--t-fast);width:100%}
.form-input::placeholder{color:var(--dark-dim)}
.form-input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-glow)}
.form-input.light{background:#fff;border-color:var(--light-border);color:var(--light-fg)}
.form-input.light::placeholder{color:var(--light-muted)}
.form-input.light:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(147,51,234,.15)}
textarea.form-input{resize:vertical;min-height:120px}
.form-select{appearance:none;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='%239896BC' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}
.form-error{font-size:12px;color:var(--danger);display:none;margin-top:4px}
.form-input.error{border-color:var(--danger)}

/* === LOGO STRIP === */
.logo-strip{overflow:hidden;position:relative}
.logo-strip-inner{display:flex;align-items:center;gap:48px;animation:scrollLogo 24s linear infinite;width:max-content}
.logo-item{font-size:17px;font-weight:700;color:var(--dark-muted);opacity:.4;white-space:nowrap;letter-spacing:-.02em;flex-shrink:0}

/* === TESTIMONIAL === */
.testi-card{padding:32px;border-radius:var(--r-xl);position:relative}
.testi-stars{display:flex;gap:3px;margin-bottom:16px;color:var(--warning)}
.testi-stars svg{width:16px;height:16px;fill:currentColor}
.testi-quote{font-size:15px;line-height:1.75;margin-bottom:24px;font-style:italic}
.testi-author{display:flex;align-items:center;gap:12px}
.testi-avatar{width:44px;height:44px;border-radius:50%;background:var(--grad-brand);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:15px;flex-shrink:0}
.testi-name{font-weight:600;font-size:14px;line-height:1.2}
.testi-role{font-size:12px;color:var(--dark-muted)}

/* === FAQ === */
.faq-item{border-bottom:1px solid var(--dark-border)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;padding:20px 0;font-size:16px;font-weight:600;color:var(--dark-fg);cursor:pointer;text-align:left;gap:16px}
.faq-q svg{width:20px;height:20px;flex-shrink:0;transition:transform var(--t-base);color:var(--brand)}
.faq-item.open .faq-q svg{transform:rotate(45deg)}
.faq-ans{font-size:15px;line-height:1.7;color:var(--dark-muted);max-height:0;overflow:hidden;transition:max-height var(--t-slow),padding var(--t-slow)}
.faq-item.open .faq-ans{max-height:400px;padding-bottom:20px}
.section-light .faq-item,.section-light2 .faq-item{border-color:var(--light-border)}
.section-light .faq-q,.section-light2 .faq-q{color:var(--light-fg)}
.section-light .faq-ans,.section-light2 .faq-ans{color:var(--light-muted)}

/* === PROCESS STEP === */
.step{display:flex;gap:24px;align-items:flex-start}
.step-num{width:48px;height:48px;border-radius:50%;background:rgba(147,51,234,.12);border:1px solid var(--brand-border);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;color:var(--brand-light);flex-shrink:0}
.step-line{width:2px;flex:1;background:var(--brand-border);margin:8px 0;border-radius:2px}

/* === TABS === */
.tab-list{display:flex;gap:4px;border-bottom:1px solid var(--dark-border);margin-bottom:32px}
.tab-btn{padding:11px 18px;border-radius:var(--r-sm) var(--r-sm) 0 0;font-size:14px;font-weight:600;color:var(--dark-muted);cursor:pointer;transition:all var(--t-fast);border-bottom:2px solid transparent;margin-bottom:-1px}
.tab-btn.active{color:var(--brand-light);border-bottom-color:var(--brand)}
.tab-btn:hover:not(.active){color:var(--dark-fg)}
.tab-panel{display:none}.tab-panel.active{display:block}
.tabs-light .tab-list{border-color:var(--light-border)}
.tabs-light .tab-btn{color:var(--light-muted)}
.tabs-light .tab-btn.active{color:var(--brand)}
.tabs-light .tab-btn:hover:not(.active){color:var(--light-fg)}

/* === PRICING === */
.pricing-card{border-radius:var(--r-xl);padding:36px;position:relative;transition:all var(--t-base)}
.pricing-card.featured{border:1px solid var(--brand-border);background:linear-gradient(135deg,rgba(147,51,234,.1) 0%,rgba(109,40,217,.05) 100%);box-shadow:0 0 40px rgba(147,51,234,.15)}
.pricing-popular{position:absolute;top:-13px;left:50%;transform:translateX(-50%);padding:4px 16px;border-radius:var(--r-full);background:var(--grad-brand);font-size:12px;font-weight:700;color:#fff;white-space:nowrap}
.pricing-name{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--brand-light);margin-bottom:8px}
.pricing-amount{display:flex;align-items:baseline;gap:4px;margin:16px 0}
.pricing-currency{font-size:20px;font-weight:700;color:var(--dark-muted)}
.pricing-price{font-size:52px;font-weight:800;letter-spacing:-.04em;line-height:1}
.pricing-period{font-size:14px;color:var(--dark-muted)}
.pricing-features{display:flex;flex-direction:column;gap:11px;margin:24px 0 32px}
.pf{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--dark-muted)}
.pf-check{width:20px;height:20px;border-radius:50%;background:rgba(16,185,129,.12);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#10B981}
.pf-check svg{width:10px;height:10px}

/* === CASE STUDY === */
.case-img{height:220px;background:var(--dark-surf2);position:relative;overflow:hidden;border-radius:var(--r-xl) var(--r-xl) 0 0}
.case-body{padding:24px}
.case-metric{display:flex;flex-direction:column;gap:3px}
.case-metric-val{font-size:28px;font-weight:800;letter-spacing:-.03em;line-height:1}
.case-metric-lbl{font-size:12px;color:var(--dark-muted)}

/* === INDUSTRY CARD === */
.industry-card{padding:28px;border-radius:var(--r-xl);text-align:center;cursor:pointer;transition:all var(--t-base)}
.industry-icon{width:64px;height:64px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:26px}

/* === BLOG CARD === */
.blog-card{border-radius:var(--r-xl);overflow:hidden;transition:all var(--t-base)}
.blog-card:hover{transform:translateY(-3px)}
.blog-img{height:200px;overflow:hidden;position:relative}
.blog-body{padding:24px}
.blog-meta{display:flex;align-items:center;gap:12px;font-size:13px;margin-bottom:12px;color:var(--dark-muted)}
.blog-cat{background:rgba(147,51,234,.12);color:var(--brand-light);padding:2px 10px;border-radius:var(--r-full);font-weight:600}

/* === PORTFOLIO === */
.port-card{border-radius:var(--r-xl);overflow:hidden;position:relative}
.port-preview{height:260px;overflow:hidden;position:relative;background:var(--dark-surf2)}
.port-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(8,8,15,.95) 0%,transparent 60%);opacity:0;transition:opacity var(--t-base);display:flex;align-items:flex-end;padding:24px}
.port-card:hover .port-overlay{opacity:1}

/* === TEAM CARD === */
.team-card{text-align:center;padding:28px 20px}
.team-avatar{width:80px;height:80px;border-radius:50%;margin:0 auto 16px;background:var(--grad-brand);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:800;color:#fff;border:3px solid rgba(147,51,234,.3)}

/* === PAGE HEADER === */
.page-hero{padding:140px 0 80px;text-align:center;position:relative;overflow:hidden;background:var(--dark-bg)}
.page-hero::before{content:'';position:absolute;inset:0;background:var(--grad-glow-top);pointer-events:none}

/* === FLOATING CTA === */
.floating-cta{position:fixed;bottom:28px;right:28px;z-index:998;display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.float-btn{display:flex;align-items:center;gap:10px;padding:13px 20px;border-radius:var(--r-full);background:var(--grad-brand);color:#fff;font-size:14px;font-weight:700;box-shadow:0 8px 32px rgba(147,51,234,.5);cursor:pointer;border:none;transition:all var(--t-base);white-space:nowrap}
.float-btn:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(147,51,234,.65)}
.float-btn svg{width:18px;height:18px}

/* === HERO === */
.hero{min-height:100vh;display:flex;align-items:center;padding-top:68px;position:relative;overflow:hidden;background:var(--dark-bg)}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--r-full);background:rgba(147,51,234,.1);border:1px solid var(--brand-border);font-size:13px;font-weight:600;color:var(--brand-light);margin-bottom:28px}
.hero-badge-dot{width:7px;height:7px;border-radius:50%;background:var(--brand);animation:pulse 2s infinite}
.hero-cta-row{display:flex;align-items:center;gap:12px;margin-top:36px;flex-wrap:wrap}
.hero-trust{margin-top:64px;padding-top:40px;border-top:1px solid var(--dark-border)}
.hero-trust-lbl{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--dark-dim);margin-bottom:20px}
.hero-stats{display:flex;gap:40px;flex-wrap:wrap}
.hero-stat-val{font-size:30px;font-weight:800;letter-spacing:-.03em;line-height:1;margin-bottom:4px}
.hero-stat-lbl{font-size:13px;color:var(--dark-muted)}

/* === NOTIF CARDS (hero floating) === */
.notif-card{background:rgba(21,20,42,.9);border:1px solid var(--dark-border2);border-radius:var(--r-md);padding:12px 16px;display:flex;align-items:center;gap:12px;box-shadow:var(--sh-xl);backdrop-filter:blur(20px)}
.notif-icon{width:34px;height:34px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px}
.notif-title{font-size:13px;font-weight:700;color:var(--dark-fg);line-height:1.2}
.notif-sub{font-size:11px;color:var(--dark-muted);line-height:1.3}

/* === BAR CHART (CSS) === */
.bar-chart{display:flex;align-items:flex-end;gap:6px;height:80px}
.bar{flex:1;background:var(--grad-brand);border-radius:3px 3px 0 0;height:0%;opacity:.85;transition:height 1s var(--t-spring)}

/* === REVEAL === */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.rd1{transition-delay:.1s}.rd2{transition-delay:.2s}.rd3{transition-delay:.3s}.rd4{transition-delay:.4s}.rd5{transition-delay:.5s}

/* === KEYFRAMES === */
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes floatSlow{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-18px) rotate(2deg)}}
@keyframes scrollLogo{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}
@keyframes gradShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes spinSlow{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes glowPulse{0%,100%{box-shadow:0 0 20px rgba(147,51,234,.3)}50%{box-shadow:0 0 40px rgba(147,51,234,.6)}}
@keyframes lineGrow{from{transform:scaleX(0)}to{transform:scaleX(1)}}

/* === UTILS === */
.flex{display:flex}.flex-col{display:flex;flex-direction:column}
.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}
.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.gap-8{gap:32px}
.text-center{text-align:center}.relative{position:relative}.overflow-hidden{overflow:hidden}
.w-full{width:100%}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mt-8{margin-top:32px}
.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mb-8{margin-bottom:32px}

/* === FOOTER === */
.footer{background:#050508;border-top:1px solid var(--dark-border);padding:80px 0 40px;color:var(--dark-fg)}
.footer-grid{display:grid;grid-template-columns:1.6fr repeat(4,1fr);gap:48px;padding-bottom:56px;border-bottom:1px solid var(--dark-border)}
.footer-brand p{margin-top:16px;font-size:14px;line-height:1.75;color:var(--dark-muted);max-width:280px}
.footer-logo{display:flex;align-items:center;gap:8px}
.footer-logo img{height:34px;width:auto}
.footer-logo-name{font-size:15px;font-weight:800;letter-spacing:-.02em;line-height:1}
.footer-logo-sub{font-size:9px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--dark-dim)}
.footer-certs{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap}
.cert-badge{display:flex;align-items:center;gap:5px;padding:5px 11px;border-radius:var(--r-sm);background:var(--dark-surf2);border:1px solid var(--dark-border);font-size:11px;font-weight:600;color:var(--dark-muted)}
.cert-badge svg{width:13px;height:13px;color:var(--warning)}
.footer-socials{display:flex;gap:8px;margin-top:20px}
.social-btn{width:36px;height:36px;border-radius:var(--r-sm);background:var(--dark-surf2);border:1px solid var(--dark-border);display:flex;align-items:center;justify-content:center;color:var(--dark-muted);transition:all var(--t-fast)}
.social-btn:hover{background:rgba(147,51,234,.15);border-color:var(--brand-border);color:var(--brand-light)}
.social-btn svg{width:15px;height:15px}
.footer-col h4{font-size:13px;font-weight:700;color:var(--dark-fg);margin-bottom:18px;letter-spacing:.03em;text-transform:uppercase}
.footer-links{display:flex;flex-direction:column;gap:9px}
.footer-link{font-size:14px;color:var(--dark-muted);transition:color var(--t-fast)}
.footer-link:hover{color:var(--dark-fg)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:32px;font-size:13px;color:var(--dark-dim)}
.footer-bottom-links{display:flex;gap:20px}

/* === BEFORE/AFTER SLIDER === */
.ba-wrap{position:relative;border-radius:var(--r-xl);overflow:hidden;cursor:ew-resize;user-select:none}
.ba-after{width:100%;display:block}
.ba-before{position:absolute;inset:0;overflow:hidden}
.ba-slider{position:absolute;top:0;bottom:0;width:3px;background:white;cursor:ew-resize;z-index:3;transform:translateX(-50%)}
.ba-handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px;border-radius:50%;background:white;box-shadow:0 2px 12px rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center}

/* ============================================================
   WEB 3.0 ANIMATION LAYER
   ============================================================ */

/* --- Cursor Glow --- */
.cursor-glow{position:fixed;pointer-events:none;z-index:9997;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(147,51,234,.11) 0%,rgba(109,40,217,.05) 40%,transparent 70%);transform:translate(-50%,-50%);mix-blend-mode:screen;will-change:left,top;transition:opacity .4s}

/* --- 3D Tilt --- */
.tilt-card{transition:transform .15s ease,box-shadow .15s ease;transform-style:preserve-3d;will-change:transform}

/* --- Morphing Blob --- */
@keyframes morphBlob{0%,100%{border-radius:62% 38% 44% 56%/38% 54% 46% 62%}25%{border-radius:40% 60% 66% 34%/50% 40% 60% 50%}50%{border-radius:55% 45% 37% 63%/53% 67% 33% 47%}75%{border-radius:38% 62% 55% 45%/44% 38% 62% 56%}}
.blob-anim{animation:morphBlob 9s ease-in-out infinite}
.blob-anim-rev{animation:morphBlob 11s ease-in-out 2s infinite reverse}

/* --- Animated Gradient Border --- */
@keyframes rotateBorder{from{--bangle:0deg}to{--bangle:360deg}}
@property --bangle{syntax:'<angle>';initial-value:0deg;inherits:false}
.animated-border{--bangle:0deg;border:1.5px solid transparent;background:linear-gradient(var(--dark-surf),var(--dark-surf)) padding-box,conic-gradient(from var(--bangle),transparent 20%,rgba(147,51,234,.8),rgba(168,85,247,1),rgba(6,182,212,.6),transparent 80%) border-box;animation:rotateBorder 4s linear infinite}
.animated-border:hover{animation-duration:1.5s}

/* --- Data Grid Texture --- */
.data-grid{position:relative}
.data-grid::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(147,51,234,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(147,51,234,.04) 1px,transparent 1px);background-size:52px 52px;pointer-events:none;z-index:0}
.data-grid>*{position:relative;z-index:1}

/* --- Shimmer sweep --- */
@keyframes shimmerSweep{0%{transform:translateX(-100%) skewX(-12deg)}100%{transform:translateX(200%) skewX(-12deg)}}
.shimmer-card{position:relative;overflow:hidden}
.shimmer-card::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.07) 50%,transparent 100%);transform:translateX(-100%) skewX(-12deg);animation:shimmerSweep 4s ease infinite}

/* --- Glitch Text --- */
@keyframes glitch1{0%,100%{clip-path:inset(0 0 96% 0);transform:translateX(-2px)}20%{clip-path:inset(25% 0 55% 0);transform:translateX(2px)}40%{clip-path:inset(75% 0 5% 0);transform:translateX(-1px)}60%{clip-path:inset(45% 0 35% 0);transform:translateX(2px)}80%{clip-path:inset(8% 0 68% 0);transform:translateX(-2px)}}
@keyframes glitch2{0%,100%{clip-path:inset(78% 0 3% 0);transform:translateX(2px)}25%{clip-path:inset(8% 0 72% 0)}50%{clip-path:inset(2% 0 80% 0);transform:translateX(-2px)}75%{clip-path:inset(40% 0 42% 0);transform:translateX(2px)}}
.glitch-wrap{position:relative;display:inline-block}
.glitch-wrap::before,.glitch-wrap::after{content:attr(data-text);position:absolute;inset:0;background:inherit;-webkit-background-clip:text;background-clip:text}
.glitch-wrap::before{-webkit-text-fill-color:rgba(168,85,247,.7);animation:glitch1 4s step-end infinite .4s}
.glitch-wrap::after{-webkit-text-fill-color:rgba(6,182,212,.6);animation:glitch2 4s step-end infinite .8s}

/* --- Neon Pulse CTA --- */
@keyframes neonPulse{0%,100%{box-shadow:0 4px 20px rgba(147,51,234,.4),0 0 0 0 rgba(147,51,234,0)}50%{box-shadow:0 8px 35px rgba(147,51,234,.6),0 0 40px rgba(147,51,234,.15)}}
.btn-neon{animation:neonPulse 2.8s ease infinite}

/* --- Holographic card sheen --- */
@keyframes holoShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.holo-card{background:linear-gradient(135deg,rgba(147,51,234,.1) 0%,rgba(109,40,217,.06) 25%,rgba(6,182,212,.08) 50%,rgba(147,51,234,.1) 75%,rgba(109,40,217,.06) 100%);background-size:300% 300%;animation:holoShift 7s ease infinite}

/* --- Float helpers --- */
.float-1{animation:float 5.5s ease-in-out infinite}
.float-2{animation:float 7s ease-in-out 1.2s infinite}
.float-3{animation:float 8.5s ease-in-out 2.4s infinite}
.float-slow{animation:floatSlow 12s ease-in-out infinite}

/* --- Orb ambient motion --- */
@keyframes orbDrift1{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(40px,-28px) scale(1.08)}66%{transform:translate(-18px,36px) scale(.96)}}
@keyframes orbDrift2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-44px,24px) scale(1.12)}}
.orb-1{animation:orbDrift1 14s ease-in-out infinite}
.orb-2{animation:orbDrift2 17s ease-in-out 2s infinite}

/* --- Scan lines (subtle Web3 mood) --- */
.scanlines::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.025) 2px,rgba(0,0,0,.025) 4px);pointer-events:none;z-index:1;border-radius:inherit}

/* --- Stagger reveal --- */
.stagger-reveal .reveal:nth-child(1){transition-delay:.04s}
.stagger-reveal .reveal:nth-child(2){transition-delay:.11s}
.stagger-reveal .reveal:nth-child(3){transition-delay:.18s}
.stagger-reveal .reveal:nth-child(4){transition-delay:.25s}
.stagger-reveal .reveal:nth-child(5){transition-delay:.32s}
.stagger-reveal .reveal:nth-child(6){transition-delay:.39s}

/* --- Premium Team Persona Cards --- */
.team-persona{border-radius:var(--r-xl);overflow:hidden;background:var(--dark-surf);border:1px solid var(--dark-border);transition:border-color var(--t-base),transform var(--t-base),box-shadow var(--t-base);position:relative}
.team-persona:hover{border-color:rgba(147,51,234,.35);transform:translateY(-6px);box-shadow:0 24px 64px rgba(0,0,0,.5),0 0 0 1px rgba(147,51,234,.18)}
.tp-visual{height:210px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.tp-orb-1{position:absolute;width:160px;height:160px;border-radius:50%;filter:blur(55px);opacity:.6;top:-40px;left:-30px;z-index:0}
.tp-orb-2{position:absolute;width:120px;height:120px;border-radius:50%;filter:blur(45px);opacity:.4;bottom:-25px;right:-15px;z-index:0}
.tp-grid-overlay{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:28px 28px;z-index:1}
.tp-monogram-bg{font-size:110px;font-weight:900;letter-spacing:-.05em;color:rgba(255,255,255,.05);position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:2;user-select:none;line-height:1}
.tp-monogram{font-size:52px;font-weight:900;letter-spacing:-.04em;position:relative;z-index:3}
.tp-stat-pill{position:absolute;top:14px;left:14px;padding:5px 13px;border-radius:var(--r-full);font-size:12px;font-weight:800;background:rgba(0,0,0,.55);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.9);z-index:4;letter-spacing:-.01em}
.tp-role-pill{position:absolute;bottom:14px;right:14px;padding:4px 12px;border-radius:var(--r-full);font-size:11px;font-weight:700;background:rgba(0,0,0,.55);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.75);z-index:4;letter-spacing:.03em;text-transform:uppercase}
.tp-body{padding:22px}
.tp-name{font-size:16px;font-weight:800;letter-spacing:-.02em;margin-bottom:3px}
.tp-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;margin-bottom:12px}
.tp-bio{font-size:13px;color:var(--dark-muted);line-height:1.7;margin-bottom:14px}
.tp-tags{display:flex;gap:6px;flex-wrap:wrap}
.tp-tag{padding:3px 9px;border-radius:var(--r-full);font-size:11px;font-weight:600}

/* === RESPONSIVE === */
@media(max-width:1200px){
  .footer-grid{grid-template-columns:1fr repeat(3,1fr)}
  .footer-grid>:nth-child(2){grid-column:1}
  .footer-grid>:last-child{grid-column:span 2}
}
@media(max-width:1024px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .nav-links{display:none}
  .nav-hamburger{display:flex}
}
@media(max-width:768px){
  .grid-2,.grid-3{grid-template-columns:1fr}
  .section{padding:72px 0}
  .section-lg{padding:96px 0}
  .section-header{margin-bottom:48px}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .footer-bottom{flex-direction:column;gap:14px;text-align:center}
  .float-btn span{display:none}
  .hero-stats{gap:28px}
}
@media(max-width:480px){
  .container{padding:0 16px}
  .section{padding:60px 0}
  .btn-xl{padding:14px 22px;font-size:15px}
  .hero-cta-row .btn-xl{padding:14px 22px;font-size:15px}
}

/* Team persona responsive */
@media(max-width:1024px){
  [style*="grid-template-columns:repeat(4,1fr)"].stagger-reveal{grid-template-columns:repeat(2,1fr)!important}
}
@media(max-width:600px){
  [style*="grid-template-columns:repeat(4,1fr)"].stagger-reveal{grid-template-columns:1fr!important}
  .cursor-glow{display:none}
  .animated-border{border:1.5px solid rgba(147,51,234,.35);background:var(--dark-surf)}
}

/* ============================================================
   PREMIUM POLISH & MOBILE ENHANCEMENT — v2
   Parts 1 + 2 of upgrade
   ============================================================ */

/* --- Ensure no horizontal overflow globally --- */
html { overflow-x: hidden; }

/* --- Enhanced focus states for forms --- */
.form-group.focused .form-label { color: var(--brand-light); }
.form-group.focused .form-input { border-color: var(--brand); box-shadow: 0 0 0 3px var(--brand-glow); }

/* --- Premium card hover shimmer (all dark cards) --- */
.card-dark,.card-glass,.svc-card,.cs-card,.blog-inner,.port-inner {
  position: relative; overflow: hidden;
}
.card-dark::before,.card-glass::before,.svc-card::before { 
  content:''; position:absolute; inset:0; opacity:0;
  background: linear-gradient(135deg, rgba(147,51,234,.07) 0%, rgba(6,182,212,.04) 100%);
  transition: opacity var(--t-base); pointer-events: none; border-radius: inherit; z-index: 0;
}
.card-dark:hover::before,.card-glass:hover::before,.svc-card:hover::before { opacity:1; }
.card-dark > *,.card-glass > *,.svc-card > * { position: relative; z-index: 1; }

/* --- Better section rhythm at tablet --- */
@media(max-width:1200px) {
  .section-lg { padding: 110px 0; }
  .hero-inner { gap: 48px; }
}

/* --- Tablet portrait (1024px) improvements --- */
@media(max-width:1024px) {
  .section { padding: 80px 0; }
  .section-lg { padding: 100px 0; }
  .section-header { margin-bottom: 52px; }
  .section-sub { font-size: 16px; }
  /* Grids */
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  /* Results / stats */
  .results-grid { grid-template-columns: repeat(2, 1fr) !important; }
  /* Industries */
  .ind-grid { grid-template-columns: repeat(3, 1fr) !important; }
  /* Process */
  .process-timeline { grid-template-columns: repeat(2, 1fr) !important; }
  .process-timeline::before { display: none !important; }
  /* Port + CS + Testi */
  .port-grid,.cs-slider,.testi-grid,.blog-grid { grid-template-columns: repeat(2, 1fr) !important; }
  /* Team */
  .team-grid { grid-template-columns: repeat(2, 1fr) !important; }
  /* Pricing */
  .pricing-grid { grid-template-columns: repeat(2, 1fr) !important; }
  /* Stat strip */
  .stat-strip { grid-template-columns: repeat(2, 1fr) !important; }
  /* Story grid */
  .story-grid { grid-template-columns: 1fr !important; gap: 48px !important; }
  /* Contact */
  .contact-grid { grid-template-columns: 1fr !important; gap: 40px !important; }
  /* Footer grid */
  .footer-grid { grid-template-columns: 1fr 1fr 1fr !important; gap: 36px !important; }
  /* Dash hidden */
  .hero-dash { display: none !important; }
  /* Hero stack */
  .hero-inner { grid-template-columns: 1fr !important; text-align: center; }
  .hero-sub { margin: 0 auto; }
  .hero-cta-row { justify-content: center; }
  .hero-stats { justify-content: center; }
}

/* --- Tablet portrait (768px) --- */
@media(max-width:768px) {
  .section { padding: 64px 0; }
  .section-sm { padding: 48px 0; }
  .section-lg { padding: 80px 0; }
  .section-header { margin-bottom: 40px; }
  .section-title { font-size: clamp(24px, 6vw, 36px); }
  .section-sub { font-size: 15px; }
  /* All grids become 1 col */
  .grid-2,.grid-3,.grid-4,.grid-auto { grid-template-columns: 1fr !important; }
  .port-grid,.cs-slider,.testi-grid,.blog-grid { grid-template-columns: 1fr !important; }
  .team-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .process-timeline { grid-template-columns: 1fr !important; }
  .process-timeline::before { display: none !important; }
  .ind-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .results-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .pricing-grid { grid-template-columns: 1fr !important; }
  .stat-strip { grid-template-columns: repeat(2, 1fr) !important; }
  .cta-grid { grid-template-columns: 1fr !important; margin: 32px 0 !important; }
  /* Footer */
  .footer-grid { grid-template-columns: 1fr !important; gap: 28px !important; }
  .footer-bottom { flex-direction: column; gap: 12px; text-align: center; }
  /* Hero */
  .hero-inner { grid-template-columns: 1fr !important; gap: 40px !important; text-align: center; }
  .hero-headline { font-size: clamp(34px, 8vw, 52px) !important; }
  .hero-sub { font-size: 16px !important; margin: 0 auto; max-width: 480px; }
  .hero-cta-row { justify-content: center; flex-direction: column; align-items: center; width: 100%; }
  .hero-cta-row .btn { width: 100%; max-width: 340px; justify-content: center; }
  .hero-stats { justify-content: center; gap: 24px !important; flex-wrap: wrap; }
  .hero-trust { margin-top: 40px; padding-top: 28px; }
  /* Floating CTA label hidden on mobile */
  .float-btn span { display: none; }
  /* Nav mobile */
  .nav-links,.nav-actions { display: none !important; }
  .nav-hamburger { display: flex !important; }
  /* Page hero */
  .page-hero { padding: 110px 0 60px !important; }
  /* About hero */
  .about-hero { padding: 110px 0 60px !important; }
}

/* --- Mobile (430px) --- */
@media(max-width:430px) {
  .container,.container-sm,.container-xs { padding: 0 16px; }
  .section { padding: 52px 0; }
  .section-title { font-size: clamp(22px, 7vw, 30px); }
  .hero-headline { font-size: clamp(28px, 9vw, 44px) !important; }
  .hero-sub { font-size: 14px !important; }
  .btn-xl { padding: 14px 22px; font-size: 15px; }
  .hero-cta-row .btn { max-width: 100%; }
  .team-grid { grid-template-columns: 1fr !important; }
  .ind-grid { grid-template-columns: repeat(2, 1fr) !important; }
  /* Forms full width */
  .form-input, .form-select, textarea.form-input { font-size: 16px !important; }
  /* Pricing card */
  .pricing-card { padding: 24px !important; }
  .pricing-price { font-size: 40px !important; }
  /* Stat strip */
  .stat-strip { grid-template-columns: 1fr 1fr !important; }
  .stat-strip-item { padding: 28px 16px !important; }
  /* Case study card */
  .cs-metrics { grid-template-columns: 1fr 1fr 1fr !important; gap: 8px !important; }
  .cs-mv { font-size: 20px !important; }
  /* Badge row overflow fix */
  .hero-badge { font-size: 12px !important; padding: 6px 12px !important; }
  /* Nav */
  .nav { padding: 0 16px; }
}

/* --- Small mobile (390px) --- */
@media(max-width:390px) {
  .hero-headline { font-size: clamp(26px, 8.5vw, 38px) !important; }
  .cs-metrics { grid-template-columns: repeat(3, 1fr) !important; }
  .hero-stats { flex-direction: column; gap: 16px !important; }
}

/* --- Very small (360px) --- */
@media(max-width:360px) {
  .container,.container-sm,.container-xs { padding: 0 12px; }
  .hero-headline { font-size: clamp(24px, 8vw, 34px) !important; }
  .btn-xl { padding: 12px 18px; font-size: 14px; }
}

/* --- Fix forms on mobile --- */
@media(max-width:768px) {
  .grid-2 .form-group, .form-grid { grid-template-columns: 1fr !important; }
  .form-row { flex-direction: column !important; gap: 0; }
  .contact-grid .form-input, .audit-grid .form-input { font-size: 16px; }
}

/* --- Premium section dividers --- */
.section-dark + .section-light::before,
.section-dark2 + .section-light::before,
.section-light + .section-dark::before,
.section-light + .section-dark2::before {
  content: '';
  display: block;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--brand-border), transparent);
}

/* --- Premium button active states --- */
.btn-primary:active { transform: translateY(0) scale(0.98); }
.btn-outline:active { background: rgba(255,255,255,.1); }

/* --- Card gradient accent on hover (brand glow strip at top) --- */
.card-dark:hover, .card-glass:hover {
  box-shadow: var(--sh-card-dark), 0 0 0 1px rgba(147,51,234,.2);
}

/* --- Premium form container --- */
.form-section-wrap {
  background: var(--dark-surf);
  border: 1px solid var(--dark-border2);
  border-radius: var(--r-2xl);
  padding: 40px;
  box-shadow: 0 20px 60px rgba(0,0,0,.3);
}
@media(max-width:768px) {
  .form-section-wrap { padding: 24px 20px; }
}

/* --- Trust badges strip --- */
.trust-row {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 20px;
}
.trust-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--dark-muted);
}
.trust-item svg { width: 16px; height: 16px; color: var(--success); flex-shrink: 0; }

/* --- Next steps callout (lead gen) --- */
.next-steps-box {
  background: linear-gradient(135deg, rgba(147,51,234,.08) 0%, rgba(109,40,217,.04) 100%);
  border: 1px solid var(--brand-border);
  border-radius: var(--r-xl);
  padding: 28px 32px;
  margin-top: 28px;
}
.next-steps-box h4 { font-size: 15px; font-weight: 700; color: var(--brand-light); margin-bottom: 12px; }
.next-steps-list { display: flex; flex-direction: column; gap: 10px; }
.nsl-item { display: flex; align-items: center; gap: 10px; font-size: 14px; color: var(--dark-muted); }
.nsl-num { width: 24px; height: 24px; border-radius: 50%; background: rgba(147,51,234,.15); 
  border: 1px solid var(--brand-border); display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 800; color: var(--brand-light); flex-shrink: 0; }

/* --- Mobile sticky CTA (bottom bar) --- */
.mobile-cta-bar {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 997;
  background: rgba(8,8,15,.97);
  backdrop-filter: blur(20px);
  border-top: 1px solid var(--dark-border2);
  padding: 12px 16px;
  gap: 10px;
}
@media(max-width:768px) {
  .mobile-cta-bar { display: flex !important; }
  .mobile-cta-bar .btn { flex: 1; justify-content: center; font-size: 13px; padding: 11px 12px; }
  body { padding-bottom: 68px; }
}

/* --- Reassurance microcopy near forms --- */
.form-reassurance {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--dark-dim);
  margin-top: 0;
  white-space: nowrap;
}
.form-reassurance svg {
  width: 20px !important;
  height: 20px !important;
  min-width: 20px;
  max-width: 20px;
  min-height: 20px;
  max-height: 20px;
  color: var(--success);
  flex-shrink: 0;
  display: block;
}
.form-trust-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  flex-wrap: wrap;
  margin-top: 14px;
}
@media (max-width: 768px) {
  .form-reassurance svg {
    width: 16px !important;
    height: 16px !important;
    min-width: 16px;
    max-width: 16px;
    min-height: 16px;
    max-height: 16px;
  }
  .form-trust-row { gap: 12px; }
}

/* --- Better btn hover on light sections --- */
.section-light .btn-primary:hover, .section-light2 .btn-primary:hover {
  box-shadow: 0 10px 35px rgba(147,51,234,.45);
}

/* --- CTA urgency strip --- */
.urgency-strip {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 20px;
  background: rgba(245,158,11,.1);
  border: 1px solid rgba(245,158,11,.2);
  border-radius: var(--r-full);
  font-size: 13px;
  font-weight: 600;
  color: #FCD34D;
  margin-bottom: 24px;
  flex-wrap: wrap;
  text-align: center;
}

/* --- SEO image sizes (fixes layout shift) --- */
img { height: auto; }

/* --- Lazy load fade-in --- */
img[loading="lazy"] { opacity: 0; transition: opacity .4s ease; }
img[loading="lazy"].loaded { opacity: 1; }

/* --- Nav mobile dropdown --- */
@media(max-width:1024px) {
  .nav-mobile-services { padding-left: 16px; }
  .nav-mobile-services .nav-mobile-link { font-size: 14px; font-weight: 500; color: var(--dark-muted); }
}

/* --- Print / PDF optimize --- */
@media print {
  .nav,.floating-cta,.scroll-progress,.cursor-glow,.mobile-cta-bar { display: none !important; }
  body { background: #fff !important; color: #000 !important; }
}

/* ============================================================
   PRODUCTION POLISH v3 — Premium spacing, tablet, mobile UX
   ============================================================ */

/* --- Global baseline --- */
*, *::before, *::after { box-sizing: border-box; }
html { overflow-x: hidden; scroll-behavior: smooth; }
body { overflow-x: hidden; }

/* --- Section spacing consistency --- */
.section { padding: clamp(64px, 8vw, 120px) 0; }
.section-sm { padding: clamp(40px, 5vw, 72px) 0; }

/* --- Container max-widths --- */
.container { max-width: 1240px; margin: 0 auto; padding: 0 clamp(16px, 4vw, 48px); width: 100%; }

/* --- Typography fluid scale --- */
.hero-title { font-size: clamp(32px, 5.5vw, 72px); line-height: 1.1; letter-spacing: -0.025em; }
.section-title { font-size: clamp(26px, 3.5vw, 48px); }
.section-sub { font-size: clamp(15px, 1.8vw, 19px); line-height: 1.7; max-width: 640px; }

/* --- Card polish --- */
.card, [class*="-card"] {
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  will-change: transform;
}
.card:hover, [class*="-card"]:hover {
  transform: translateY(-3px);
  box-shadow: 0 20px 60px rgba(147,51,234,.18), 0 4px 16px rgba(0,0,0,.25);
}

/* --- Button consistency --- */
.btn { min-height: 44px; display: inline-flex; align-items: center; justify-content: center; }
.btn-lg { min-height: 52px; }
.btn-sm { min-height: 38px; }

/* --- Form polish --- */
.form-input, .form-textarea, .form-select {
  width: 100%;
  padding: 14px 18px;
  font-size: 15px;
  line-height: 1.5;
  border-radius: var(--r-md, 10px);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.form-input:focus, .form-textarea:focus, .form-select:focus {
  outline: none;
  border-color: var(--brand-purple, #9333EA);
  box-shadow: 0 0 0 3px rgba(147,51,234,.15);
}
.form-group { margin-bottom: 20px; }
.form-label { display: block; margin-bottom: 7px; font-size: 14px; font-weight: 600; }

/* --- Footer polish --- */
footer { border-top: 1px solid var(--dark-border, rgba(255,255,255,.08)); }
.footer-inner { gap: clamp(24px, 4vw, 64px); }
.footer-col h4 { font-size: 13px; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 16px; }
.footer-link { font-size: 14px; line-height: 2; opacity: .8; transition: opacity .2s; }
.footer-link:hover { opacity: 1; }

/* --- Trust signals --- */
.trust-badges { display: flex; gap: 16px; flex-wrap: wrap; align-items: center; }
.trust-badge { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 500; }

/* --- Floating CTA button --- */
.floating-cta { bottom: clamp(80px, 12vw, 100px); right: clamp(16px, 3vw, 32px); }

/* ============================================================
   TABLET — 1024px
   ============================================================ */
@media (max-width: 1024px) {
  .grid-4 { grid-template-columns: repeat(2, 1fr) !important; }
  .grid-3 { grid-template-columns: repeat(2, 1fr) !important; }
  .hero-inner, .hero-split { flex-direction: column !important; gap: 40px; }
  .hero-content { text-align: center; }
  .hero-cta { justify-content: center; flex-wrap: wrap; }
  .hero-visual { max-width: 600px; margin: 0 auto; }
  .nav-links { gap: 18px; }
  .nav-link { font-size: 14px; }
  .section-header { text-align: center; }
  .section-header .section-sub { margin: 0 auto; }
  .two-col, .split-grid { grid-template-columns: 1fr !important; }
  .process-steps { grid-template-columns: repeat(2, 1fr) !important; }
  .stats-grid { grid-template-columns: repeat(2, 1fr) !important; }
}

/* ============================================================
   MOBILE — 768px
   ============================================================ */
@media (max-width: 768px) {
  .grid-2 { grid-template-columns: 1fr !important; }
  .grid-3, .grid-4 { grid-template-columns: 1fr !important; }
  .process-steps { grid-template-columns: 1fr !important; }
  .stats-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .footer-grid { grid-template-columns: 1fr 1fr !important; gap: 32px; }
  .hero-title { font-size: clamp(28px, 8vw, 44px); }
  .nav-actions .btn:not(.btn-primary) { display: none; }
  .section-title { text-align: center; }
  form { width: 100%; }
  input, textarea, select { font-size: 16px !important; } /* prevent iOS zoom */
  .cta-buttons, .hero-cta { flex-direction: column; width: 100%; }
  .cta-buttons .btn, .hero-cta .btn { width: 100%; justify-content: center; }
  .tabs-list { overflow-x: auto; -webkit-overflow-scrolling: touch; flex-wrap: nowrap; padding-bottom: 4px; }
  table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
}

/* ============================================================
   SMALL MOBILE — 430px
   ============================================================ */
@media (max-width: 430px) {
  .stats-grid { grid-template-columns: 1fr 1fr !important; gap: 12px; }
  .footer-grid { grid-template-columns: 1fr !important; }
  .nf-links { flex-direction: column; }
  .nf-links .btn { width: 100%; }
  .hero-title { font-size: clamp(26px, 7vw, 36px); }
  .container { padding: 0 16px; }
  .section { padding: 48px 0; }
  .card-grid, .services-grid, .features-grid { gap: 16px; }
}

/* ============================================================
   EXTRA SMALL — 360px
   ============================================================ */
@media (max-width: 360px) {
  .hero-title { font-size: 24px; }
  .btn-lg { padding: 12px 20px; font-size: 14px; }
  .section { padding: 40px 0; }
  .container { padding: 0 14px; }
}

/* ============================================================
   CTA CLARITY — sticky mobile bottom bar polish
   ============================================================ */
@media (max-width: 768px) {
  .floating-cta { display: none !important; }
}

/* ============================================================
   PREMIUM GRADIENT ACCENTS
   ============================================================ */
.section-dark .section-title,
.hero-section .hero-title { text-wrap: balance; }

.gradient-text {
  background: linear-gradient(135deg, #9333EA 0%, #3B82F6 50%, #06B6D4 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* Premium card glow on hover */
.service-card:hover,
.pricing-card:hover,
.case-card:hover {
  box-shadow: 0 0 0 1px rgba(147,51,234,.3), 0 24px 64px rgba(147,51,234,.2);
}

/* Subtle divider lines */
.section + .section { position: relative; }

/* Image responsiveness */
img { max-width: 100%; height: auto; display: block; }

/* Scroll bar thin on webkit */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(147,51,234,.35); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: rgba(147,51,234,.6); }

/* ============================================================
   NAV MOBILE POLISH
   ============================================================ */
.nav-mobile { padding: 16px 20px 20px; gap: 4px; }
.nav-mobile-link { padding: 12px 16px; border-radius: 10px; font-size: 15px; }
.nav-mobile-link:hover { background: rgba(147,51,234,.08); }

/* ============================================================
   FORM FULL-WIDTH ON MOBILE
   ============================================================ */
@media (max-width: 768px) {
  .contact-form-wrap, .audit-form-wrap { padding: 24px 20px !important; }
  .form-row { grid-template-columns: 1fr !important; }
  .form-submit-wrap { width: 100%; }
  .form-submit-wrap .btn { width: 100%; justify-content: center; }
}

/* ================================================================
   ROOT-CAUSE OVERFLOW FIX — 2026-05-21
   Targets inline-style grids that CSS class rules cannot reach.
   Each selector matches the EXACT style string causing overflow.
   ================================================================ */

/* Safety net */
html, body { max-width: 100%; overflow-x: hidden; }
*, *::before, *::after { box-sizing: border-box; }

/* FIX 1: Large 2-col splits (gap:80px / gap:64px) — stack at ≤1024px
   Root: index.html "Why Choose Us", "SEO Results" sections;
         ai-automation.html hero, workflow, ROI sections.
   These outer 1fr 1fr columns become ~130px wide at 390px, making
   the inner 2-col stat grids (~57px each) unable to hold 48px numbers. */
@media (max-width: 1024px) {
  [style*="grid-template-columns:1fr 1fr;gap:80px"],
  [style*="grid-template-columns:1fr 1fr;gap:64px"] {
    grid-template-columns: 1fr !important;
    gap: 40px !important;
  }
}

/* FIX 2: Medium 2-col split (gap:48px) — stack at ≤768px
   Root: pricing.html ROI calculator left/right panel. */
@media (max-width: 768px) {
  [style*="grid-template-columns:1fr 1fr;gap:48px"] {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
}

/* FIX 3: 6-column stat strip — services.html
   Root: 6 equal columns at 390px = ~57px each. "Core Services" at
   12px needs ~90px; stat numbers at 28px need ~70px. Grid overflows. */
@media (max-width: 1024px) {
  [style*="grid-template-columns:repeat(6,1fr)"] {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}
@media (max-width: 600px) {
  [style*="grid-template-columns:repeat(6,1fr)"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* FIX 4: 4-col footer-style grid (2fr 1fr 1fr 1fr) — services.html, ai-automation.html */
@media (max-width: 1024px) {
  [style*="grid-template-columns:2fr 1fr 1fr 1fr"] {
    grid-template-columns: 1fr 1fr !important;
    gap: 32px !important;
  }
}
@media (max-width: 600px) {
  [style*="grid-template-columns:2fr 1fr 1fr 1fr"] {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }
}

/* FIX 5: 3-col inline grids not covered by .grid-3 class
   Root: index.html stagger-reveal blog/feature rows,
         ai-automation.html case study stat rows */
@media (max-width: 1024px) {
  [style*="grid-template-columns:repeat(3,1fr)"].stagger-reveal,
  [style*="grid-template-columns:repeat(3,1fr);gap:20px"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 600px) {
  [style*="grid-template-columns:repeat(3,1fr)"].stagger-reveal,
  [style*="grid-template-columns:repeat(3,1fr);gap:20px"],
  [style*="grid-template-columns:repeat(3,1fr);gap:16px"],
  [style*="grid-template-columns:repeat(3,1fr);gap:10px"] {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }
}

/* FIX 6: Contact form name-row inline grid
   Root: contact.html First Name / Last Name side-by-side */
@media (max-width: 600px) {
  [style*="grid-template-columns:1fr 1fr;gap:16px"] {
    grid-template-columns: 1fr !important;
  }
}

/* FIX 7: Floating CTA body clearance — prevent last section content
   from hiding behind the fixed bottom button on mobile */
@media (max-width: 768px) {
  body { padding-bottom: 88px; }
}

/* FIX 8: Ensure all containers and sections never exceed viewport */
.container, .container-sm, .container-xs,
section, main, header, footer {
  min-width: 0;
  max-width: 100%;
}
