/*
Theme Name: QuickData VTU Ghana
Theme URI: https://quickdata.shop
Author: QuickData
Description: Premium Ghana VTU theme. Sells MTN, AirtelTigo, and Telecel data bundles.
Version: 8.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License: GNU General Public License v2 or later
Text Domain: quickdata-vtu
Tags: woocommerce, vtu, ghana, data-bundles, mtn, airteltigo, telecel
*/

/* ============================================================
   DESIGN TOKENS — Electric Midnight × Neon Coral
   ============================================================ */
:root {
  /* Surfaces */
  --bg:        #07080F;
  --bg-2:      #0D0F1A;
  --bg-3:      #111425;
  --bg-4:      #161930;
  --card-bg:   #0E1020;
  --card-border: rgba(255,255,255,.06);

  /* Primary Electric Blue */
  --blue:      #3B82F6;
  --blue-lt:   #60A5FA;
  --blue-dk:   #1D4ED8;
  --blue-glow: rgba(59,130,246,.3);
  --blue-trace:rgba(59,130,246,.08);

  /* Coral / Accent */
  --coral:     #FF6B6B;
  --coral-lt:  #FF8E8E;
  --coral-glow:rgba(255,107,107,.3);

  /* Emerald success */
  --em:        #10B981;
  --em-lt:     #34D399;
  --em-glow:   rgba(16,185,129,.25);

  /* Network colors — more vibrant */
  --mtn:       #FFCA28;
  --mtn-deep:  #E65100;
  --mtn-glow:  rgba(255,202,40,.32);
  --mtn-txt:   #1A0800;

  --at:        #FF3366;
  --at-deep:   #B00020;
  --at-glow:   rgba(255,51,102,.3);

  --tc:        #2979FF;
  --tc-deep:   #0039CB;
  --tc-glow:   rgba(41,121,255,.3);

  /* Text */
  --t1:   #F1F5FF;
  --t2:   #94A3C4;
  --t3:   #4B5680;
  --t-inv:#ffffff;

  /* Borders */
  --b:    rgba(255,255,255,.07);
  --b2:   rgba(59,130,246,.25);
  --b3:   rgba(255,255,255,.04);

  /* Semantic */
  --ok:   #10B981;
  --err:  #EF4444;
  --warn: #F59E0B;

  /* Radii */
  --r1: 8px;
  --r2: 14px;
  --r3: 20px;
  --r4: 28px;
  --rp: 999px;

  /* Shadows */
  --sh-card: 0 1px 0 rgba(255,255,255,.04), 0 4px 20px rgba(0,0,0,.6);
  --sh-lift: 0 20px 60px rgba(0,0,0,.7), 0 0 1px rgba(255,255,255,.06);

  --mw:   1220px;
  --nh:   68px;
}

/* ============================================================
   RESET + BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}

body {
  background: var(--bg);
  color: var(--t1);
  font-family: 'Outfit', 'Nunito', system-ui, sans-serif;
  font-size: 15px;
  line-height: 1.65;
  min-height: 100vh;
  overflow-x: hidden;
}

/* Subtle noise texture */
body::before {
  content:'';
  position:fixed;inset:0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");
  pointer-events:none;
  z-index:9999;
  opacity:.4;
}

a{color:var(--blue-lt);text-decoration:none;transition:color .2s}
a:hover{color:var(--t1)}
img{max-width:100%;display:block}
ul,ol{list-style:none}
h1,h2,h3,h4,h5,h6{
  font-family:'Outfit','Nunito',sans-serif;
  font-weight:800;line-height:1.1;color:var(--t1);
}
p{color:var(--t2)}
.container{max-width:var(--mw);margin:0 auto;padding:0 1.5rem}

/* ============================================================
   HEADER
   ============================================================ */
.site-header {
  position:sticky;top:0;z-index:200;
  height:var(--nh);
  background:rgba(7,8,15,.8);
  backdrop-filter:blur(28px) saturate(180%);
  border-bottom:1px solid var(--b);
  transition:all .3s;
}
.site-header.scrolled {
  border-bottom-color:rgba(59,130,246,.2);
  box-shadow:0 4px 40px rgba(0,0,0,.8);
}
.header-inner {
  max-width:var(--mw);margin:0 auto;padding:0 1.5rem;
  height:100%;display:flex;align-items:center;
  justify-content:space-between;gap:2rem;
}

/* Logo */
.site-branding{display:flex;align-items:center;gap:.75rem;text-decoration:none;flex-shrink:0}
.logo-mark{
  width:40px;height:40px;border-radius:12px;
  background:linear-gradient(135deg, #3B82F6 0%, #8B5CF6 100%);
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;flex-shrink:0;
  box-shadow:0 0 24px rgba(59,130,246,.4), inset 0 1px 0 rgba(255,255,255,.25);
}
.logo-text{
  font-family:'Outfit',sans-serif;
  font-weight:800;font-size:1.25rem;color:var(--t1);
  letter-spacing:-.03em;
}
.logo-text span{
  background:linear-gradient(90deg,var(--blue),var(--coral));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}

/* Nav */
.main-navigation ul{display:flex;gap:.15rem}
.main-navigation a{
  color:var(--t2);font-size:.875rem;font-weight:600;
  padding:.44rem .9rem;border-radius:var(--r1);
  transition:all .18s;letter-spacing:.01em;
}
.main-navigation a:hover,.main-navigation .current-menu-item>a{
  background:rgba(59,130,246,.1);color:var(--blue-lt);
}

/* Header right */
.header-right{display:flex;align-items:center;gap:.6rem}
.btn-nav-cart{
  display:flex;align-items:center;gap:.4rem;
  background:rgba(255,255,255,.04);border:1px solid var(--b);
  color:var(--t2);padding:.38rem .8rem;border-radius:var(--r1);
  font-size:.82rem;font-weight:600;cursor:pointer;
  transition:all .2s;text-decoration:none;
}
.btn-nav-cart:hover{border-color:var(--b2);color:var(--blue-lt)}
.cart-bubble{
  background:var(--coral);color:#fff;
  border-radius:999px;width:18px;height:18px;
  font-size:.62rem;font-weight:800;
  display:flex;align-items:center;justify-content:center;
}
.btn-nav-login{
  background:linear-gradient(135deg,var(--blue),var(--blue-dk));
  color:#fff;border:none;padding:.5rem 1.15rem;
  border-radius:var(--r1);font-size:.84rem;font-weight:700;
  cursor:pointer;font-family:inherit;transition:all .22s;
  text-decoration:none;display:inline-flex;align-items:center;
  box-shadow:0 0 20px var(--blue-glow);letter-spacing:.01em;
}
.btn-nav-login:hover{opacity:.9;color:#fff;transform:translateY(-1px);box-shadow:0 6px 28px var(--blue-glow)}
.menu-toggle{
  display:none;background:rgba(255,255,255,.05);border:1px solid var(--b);
  color:var(--t1);padding:.38rem .62rem;border-radius:var(--r1);
  font-size:1.1rem;cursor:pointer;
}

/* ============================================================
   HERO
   ============================================================ */
.vtu-hero {
  position:relative;overflow:hidden;
  background:var(--bg);
  padding:6rem 1.5rem 5rem;
  text-align:center;
  min-height:600px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
}

/* Mesh gradient background */
.vtu-hero::before {
  content:'';
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 70% 60% at 15% 50%, rgba(59,130,246,.12) 0%, transparent 60%),
    radial-gradient(ellipse 50% 50% at 85% 30%, rgba(139,92,246,.1) 0%, transparent 55%),
    radial-gradient(ellipse 60% 40% at 50% 90%, rgba(255,107,107,.07) 0%, transparent 60%);
  pointer-events:none;
}

.hero-grid {
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(59,130,246,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(59,130,246,.04) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 90% 70% at 50% 30%,black 0%,transparent 100%);
  pointer-events:none;
}

/* Floating glows */
.hero-orb{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}
.hero-orb-1{width:500px;height:500px;background:radial-gradient(circle,rgba(59,130,246,.18),transparent);top:-200px;left:-10%;animation:floatOrb 12s ease-in-out infinite}
.hero-orb-2{width:400px;height:400px;background:radial-gradient(circle,rgba(139,92,246,.14),transparent);top:-100px;right:-5%;animation:floatOrb 16s ease-in-out infinite reverse}
.hero-orb-3{width:350px;height:350px;background:radial-gradient(circle,rgba(255,107,107,.1),transparent);bottom:0;left:20%;animation:floatOrb 20s ease-in-out infinite}
@keyframes floatOrb{0%,100%{transform:translate(0,0)}50%{transform:translate(30px,-40px)}}

/* Hero eyebrow */
.hero-eyebrow {
  position:relative;z-index:2;
  display:inline-flex;align-items:center;gap:.55rem;
  background:rgba(59,130,246,.1);
  border:1px solid rgba(59,130,246,.3);
  color:var(--blue-lt);border-radius:var(--rp);
  padding:.38rem 1.15rem;font-size:.73rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;margin-bottom:1.75rem;
  animation:riseIn .5s ease both;
  backdrop-filter:blur(8px);
}
.hero-eyebrow .pulse-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--em-lt);
  box-shadow:0 0 10px var(--em-lt);
  animation:pulse 2s ease infinite;
}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.6}}

/* Hero title */
.hero-title {
  position:relative;z-index:2;
  font-family:'Outfit',sans-serif;font-weight:900;
  font-size:clamp(2.8rem,6.5vw,4.8rem);
  color:var(--t1);line-height:1.03;
  margin-bottom:1.4rem;letter-spacing:-.04em;
  animation:riseIn .55s .08s ease both;
}
.hero-title .grad-1{
  background:linear-gradient(135deg,#60A5FA 0%,#818CF8 50%,#A78BFA 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero-title .grad-2{
  background:linear-gradient(135deg,#FB923C 0%,#F43F5E 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

.hero-sub {
  position:relative;z-index:2;
  color:var(--t2);max-width:510px;margin:0 auto 2.75rem;
  font-size:1.05rem;line-height:1.75;
  animation:riseIn .55s .16s ease both;
}

/* Hero CTA buttons */
.hero-ctas {
  position:relative;z-index:2;
  display:flex;justify-content:center;gap:.9rem;flex-wrap:wrap;
  margin-bottom:3.5rem;
  animation:riseIn .55s .24s ease both;
}
.hero-cta-primary {
  background:linear-gradient(135deg,var(--blue),var(--blue-dk));
  color:#fff;border:none;padding:.72rem 1.75rem;
  border-radius:var(--rp);font-size:.95rem;font-weight:700;
  cursor:pointer;font-family:inherit;
  box-shadow:0 0 30px var(--blue-glow);
  display:inline-flex;align-items:center;gap:.5rem;
  text-decoration:none;letter-spacing:.01em;
  transition:all .22s;
}
.hero-cta-primary:hover{transform:translateY(-2px);box-shadow:0 8px 40px var(--blue-glow);color:#fff}
.hero-cta-secondary {
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.12);
  color:var(--t1);padding:.72rem 1.75rem;
  border-radius:var(--rp);font-size:.95rem;font-weight:600;
  cursor:pointer;font-family:inherit;
  display:inline-flex;align-items:center;gap:.5rem;
  text-decoration:none;letter-spacing:.01em;
  transition:all .22s;backdrop-filter:blur(8px);
}
.hero-cta-secondary:hover{border-color:rgba(255,255,255,.25);color:#fff;transform:translateY(-2px)}

/* Network pills */
.hero-networks{
  position:relative;z-index:2;
  display:flex;justify-content:center;gap:.55rem;flex-wrap:wrap;
  margin-bottom:3.5rem;
  animation:riseIn .55s .24s ease both;
}
.net-pill{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.09);
  border-radius:var(--rp);padding:.36rem 1rem;
  font-size:.78rem;font-weight:700;
  display:flex;align-items:center;gap:.4rem;
  backdrop-filter:blur(6px);transition:all .2s;
  letter-spacing:.02em;
}
.net-pill:hover{border-color:rgba(255,255,255,.18);transform:translateY(-1px)}
.net-pill-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* Stats */
.hero-stats{
  position:relative;z-index:2;
  display:flex;justify-content:center;flex-wrap:wrap;
  animation:riseIn .55s .32s ease both;
  gap:0;
  background:rgba(255,255,255,.03);
  border:1px solid var(--b);
  border-radius:var(--r3);
  overflow:hidden;
  max-width:560px;margin:0 auto;
  backdrop-filter:blur(10px);
}
.hero-stat{
  padding:.95rem 2rem;
  border-right:1px solid var(--b);
  text-align:center;flex:1;
}
.hero-stat:last-child{border-right:none}
.hero-stat-num{
  font-family:'Outfit',sans-serif;font-weight:900;
  font-size:1.85rem;line-height:1;letter-spacing:-.04em;
  background:linear-gradient(135deg,#F1F5FF,#94A3C4);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.hero-stat-label{font-size:.68rem;color:var(--t3);margin-top:.3rem;letter-spacing:.07em;text-transform:uppercase}

@keyframes riseIn{
  from{opacity:0;transform:translateY(22px)}
  to{opacity:1;transform:translateY(0)}
}

/* ============================================================
   ORDER WIDGET
   ============================================================ */
.shop-widget-section{
  max-width:580px;margin:-2rem auto 4rem;
  padding:0 1.5rem;position:relative;z-index:10;
}
.shop-widget{
  background:var(--bg-3);
  border:1px solid var(--b2);
  border-radius:var(--r4);
  box-shadow:0 30px 80px rgba(0,0,0,.7), 0 0 0 1px rgba(59,130,246,.05), inset 0 1px 0 rgba(255,255,255,.06);
  overflow:hidden;
}
/* Gradient line at top */
.shop-widget::before{
  content:'';display:block;height:3px;
  background:linear-gradient(90deg,var(--blue),#8B5CF6,var(--coral),#8B5CF6,var(--blue));
  background-size:200%;
  animation:shimmerLine 4s linear infinite;
}
@keyframes shimmerLine{to{background-position:200%}}

.widget-header{
  padding:1.1rem 1.6rem;
  display:flex;align-items:center;gap:.75rem;
  border-bottom:1px solid var(--b);
}
.widget-header-icon{
  width:34px;height:34px;border-radius:10px;
  background:linear-gradient(135deg,var(--blue),var(--blue-dk));
  display:flex;align-items:center;justify-content:center;
  font-size:.95rem;flex-shrink:0;
  box-shadow:0 0 16px var(--blue-glow);
}
.widget-header h3{color:var(--t1);font-size:.97rem;font-weight:800;letter-spacing:-.01em}
.widget-header-sub{font-size:.73rem;color:var(--t3);font-weight:500;margin-top:.08rem}
.widget-body{padding:1.6rem}

/* Network tabs */
.network-tabs{display:flex;gap:.45rem;margin-bottom:1.5rem}
.net-tab{
  flex:1;padding:.6rem .35rem;
  border:1.5px solid var(--b);border-radius:var(--r2);
  background:rgba(255,255,255,.025);cursor:pointer;
  text-align:center;font-size:.75rem;font-weight:800;
  transition:all .22s;display:flex;flex-direction:column;
  align-items:center;gap:.3rem;color:var(--t3);
  font-family:'Outfit',sans-serif;
}
.net-tab:hover{border-color:rgba(255,255,255,.12);color:var(--t2)}
.net-tab.active-mtn{border-color:var(--mtn);background:rgba(255,202,40,.09);color:var(--mtn);box-shadow:0 0 16px rgba(255,202,40,.15),inset 0 1px 0 rgba(255,202,40,.08)}
.net-tab.active-at {border-color:var(--at); background:rgba(255,51,102,.09);color:var(--at); box-shadow:0 0 16px rgba(255,51,102,.15),inset 0 1px 0 rgba(255,51,102,.08)}
.net-tab.active-tc {border-color:var(--tc); background:rgba(41,121,255,.09);color:var(--tc); box-shadow:0 0 16px rgba(41,121,255,.15),inset 0 1px 0 rgba(41,121,255,.08)}
.tab-logo{
  width:30px;height:30px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:.74rem;font-weight:900;
  font-family:'Outfit',sans-serif;
}
.net-tab[data-net="mtn"] .tab-logo{background:var(--mtn);color:var(--mtn-txt)}
.net-tab[data-net="at"]  .tab-logo{background:var(--at); color:#fff}
.net-tab[data-net="tc"]  .tab-logo{background:var(--tc); color:#fff}

/* Plan select */
.plan-selector-wrap{margin-bottom:1.1rem}
.plan-selector-label{
  display:flex;align-items:center;gap:.35rem;
  font-size:.73rem;font-weight:700;color:var(--t3);
  margin-bottom:.4rem;letter-spacing:.06em;text-transform:uppercase;
}
.plan-select{
  width:100%;background:var(--bg-2);
  border:1.5px solid rgba(255,255,255,.1);color:var(--t1);
  padding:.72rem 2.5rem .72rem 1rem;border-radius:var(--r2);
  font-family:'Outfit',sans-serif;font-size:.9rem;font-weight:600;
  cursor:pointer;outline:none;transition:all .2s;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%233B82F6' stroke-width='2.5'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .9rem center;
}
.plan-select:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(59,130,246,.12)}
.plan-select option{background:var(--bg-2);color:var(--t1)}

/* Price bar */
.selected-price-bar{
  background:linear-gradient(135deg,rgba(59,130,246,.1),rgba(139,92,246,.06));
  border:1px solid rgba(59,130,246,.25);border-radius:var(--r2);
  padding:.75rem 1.15rem;
  display:none;align-items:center;justify-content:space-between;
  margin-bottom:1.15rem;backdrop-filter:blur(6px);
}
.selected-price-bar.visible{display:flex}
.price-label{font-size:.7rem;color:var(--blue-lt);font-weight:700;letter-spacing:.07em;text-transform:uppercase}
.price-amount{
  font-family:'Outfit',sans-serif;font-weight:900;
  font-size:1.4rem;color:var(--t1);letter-spacing:-.03em;
}
.validity-chip{
  background:rgba(16,185,129,.12);color:var(--em-lt);
  border:1px solid rgba(16,185,129,.25);
  padding:.2rem .65rem;border-radius:var(--rp);
  font-size:.7rem;font-weight:800;letter-spacing:.03em;
}

/* Inputs */
.form-row{margin-bottom:1rem}
.form-row label{
  display:block;font-size:.72rem;font-weight:700;color:var(--t3);
  margin-bottom:.38rem;letter-spacing:.07em;text-transform:uppercase;
}
.form-row input{
  width:100%;background:var(--bg-2);
  border:1.5px solid rgba(255,255,255,.08);color:var(--t1);
  padding:.7rem 1rem;border-radius:var(--r2);
  font-family:inherit;font-size:.9rem;outline:none;transition:all .2s;
}
.form-row input::placeholder{color:var(--t3)}
.form-row input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(59,130,246,.1)}
.form-row .hint{font-size:.7rem;color:var(--t3);margin-top:.28rem;display:flex;align-items:center;gap:.3rem}

/* CTA button */
.btn-order{
  width:100%;
  background:linear-gradient(135deg,var(--blue) 0%,var(--blue-dk) 100%);
  color:#fff;border:none;padding:.92rem 1rem;
  border-radius:var(--r2);font-family:'Outfit',sans-serif;
  font-weight:800;font-size:1rem;cursor:pointer;
  transition:all .22s;letter-spacing:.01em;
  display:flex;align-items:center;justify-content:center;gap:.5rem;
  box-shadow:0 0 32px var(--blue-glow),inset 0 1px 0 rgba(255,255,255,.15);
  position:relative;overflow:hidden;
}
.btn-order::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);
  transform:translateX(-100%);
  transition:transform .5s;
}
.btn-order:hover::after{transform:translateX(100%)}
.btn-order:hover{transform:translateY(-2px);box-shadow:0 10px 40px var(--blue-glow)}
.btn-order:active{transform:translateY(0)}
.btn-order:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}

/* ============================================================
   TRUST STRIP
   ============================================================ */
.trust-section{
  padding:2.75rem 1.5rem;
  background:var(--bg-2);
  border-top:1px solid var(--b);
  border-bottom:1px solid var(--b);
}
.trust-grid{
  max-width:var(--mw);margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.25rem;
}
.trust-item{
  display:flex;align-items:center;gap:1rem;
  padding:1rem 1.25rem;
  background:rgba(255,255,255,.025);
  border:1px solid var(--b);
  border-radius:var(--r2);
  transition:all .22s;
}
.trust-item:hover{border-color:var(--b2);transform:translateY(-2px)}
.trust-icon{
  width:46px;height:46px;border-radius:12px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:1.35rem;
  background:rgba(255,255,255,.04);
  border:1px solid var(--b);
}
.trust-text h4{font-size:.88rem;font-weight:700;color:var(--t1);margin-bottom:.12rem}
.trust-text p{font-size:.77rem;color:var(--t3);line-height:1.4}

/* ============================================================
   SECTION HEADINGS
   ============================================================ */
.section-head{text-align:center;margin-bottom:2.75rem}
.section-head h2{margin-bottom:.55rem;font-size:clamp(1.7rem,3.5vw,2.5rem);letter-spacing:-.03em}
.section-head p{max-width:460px;margin:0 auto;font-size:.9rem;color:var(--t2);line-height:1.75}
.section-tag{
  display:inline-flex;align-items:center;gap:.4rem;
  background:rgba(59,130,246,.1);
  color:var(--blue-lt);border:1px solid rgba(59,130,246,.25);
  border-radius:var(--rp);padding:.26rem 1rem;
  font-size:.71rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;
  margin-bottom:.85rem;
}

/* ============================================================
   FILTER BAR
   ============================================================ */
.bundle-filter-bar{
  display:flex;align-items:center;justify-content:center;
  gap:.45rem;margin-bottom:2.5rem;flex-wrap:wrap;
}
.bfilter-btn{
  border:1.5px solid var(--b);background:rgba(255,255,255,.025);
  color:var(--t3);padding:.46rem 1.25rem;border-radius:var(--rp);
  font-size:.82rem;font-weight:700;cursor:pointer;transition:all .22s;
  font-family:'Outfit',sans-serif;
  display:flex;align-items:center;gap:.45rem;
}
.bfilter-btn:hover{border-color:rgba(255,255,255,.14);color:var(--t1)}
.bfilter-btn.f-all.active{background:rgba(59,130,246,.12);border-color:var(--blue);color:var(--blue-lt);box-shadow:0 0 14px rgba(59,130,246,.15)}
.bfilter-btn.f-mtn.active{background:rgba(255,202,40,.11);border-color:var(--mtn);color:var(--mtn);box-shadow:0 0 14px var(--mtn-glow)}
.bfilter-btn.f-at.active {background:rgba(255,51,102,.11);border-color:var(--at);color:var(--at);box-shadow:0 0 14px var(--at-glow)}
.bfilter-btn.f-tc.active {background:rgba(41,121,255,.11);border-color:var(--tc);color:var(--tc);box-shadow:0 0 14px var(--tc-glow)}

/* ============================================================
   BUNDLES SECTION
   ============================================================ */
.bundles-section{
  padding:4rem 1.5rem 6rem;
  max-width:var(--mw);margin:0 auto;
}
.bundles-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(195px,1fr));
  gap:1.25rem;
}

/* ============================================================
   BUNDLE CARDS ★ — Ultra Premium Redesign
   ============================================================ */
.bundle-card {
  position:relative;
  border-radius:var(--r3);
  border:1px solid rgba(255,255,255,.07);
  background:var(--card-bg);
  display:flex;flex-direction:column;
  cursor:pointer;
  overflow:hidden;

  transition:
    transform .35s cubic-bezier(.22,.68,0,1.35),
    box-shadow .35s ease,
    border-color .25s ease;

  animation:cardIn .4s ease both;
  box-shadow:var(--sh-card);
}

/* Animated edge shimmer on hover */
.bundle-card::before {
  content:'';
  position:absolute;
  inset:-1px;
  border-radius:calc(var(--r3) + 1px);
  padding:1px;
  background:conic-gradient(from var(--angle), transparent 30%, var(--net-color, rgba(255,255,255,.15)) 60%, transparent 90%);
  -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
  opacity:0;
  transition:opacity .3s;
  --angle:0deg;
  animation:borderSpin 3s linear infinite paused;
}
.bundle-card:hover::before { opacity:1; animation-play-state:running; }
@property --angle { syntax:'<angle>'; initial-value:0deg; inherits:false; }
@keyframes borderSpin { to { --angle:360deg; } }

.bundle-card[data-net="mtn"] { --net-color:var(--mtn); }
.bundle-card[data-net="airteltigo"] { --net-color:var(--at); }
.bundle-card[data-net="telecel"] { --net-color:var(--tc); }

.bundle-card[data-net="mtn"]:hover{
  border-color:rgba(255,202,40,.35);
  box-shadow:0 24px 60px rgba(0,0,0,.7), 0 0 50px rgba(255,202,40,.15);
  transform:translateY(-10px) scale(1.02);
}
.bundle-card[data-net="airteltigo"]:hover{
  border-color:rgba(255,51,102,.35);
  box-shadow:0 24px 60px rgba(0,0,0,.7), 0 0 50px rgba(255,51,102,.15);
  transform:translateY(-10px) scale(1.02);
}
.bundle-card[data-net="telecel"]:hover{
  border-color:rgba(41,121,255,.35);
  box-shadow:0 24px 60px rgba(0,0,0,.7), 0 0 50px rgba(41,121,255,.15);
  transform:translateY(-10px) scale(1.02);
}

.bundle-card.out-of-stock{opacity:.3;pointer-events:none}

/* ── Card Header ── */
.card-stripe{
  position:relative;overflow:hidden;flex-shrink:0;
  height:105px;
  border-radius:calc(var(--r3) - 1px) calc(var(--r3) - 1px) 0 0;
}
/* Geometric accent shapes */
.card-stripe::before{
  content:'';position:absolute;
  right:-35px;top:-35px;
  width:130px;height:130px;
  background:rgba(255,255,255,.08);
  border-radius:50%;
}
.card-stripe::after{
  content:'';position:absolute;
  right:18px;bottom:-20px;
  width:75px;height:75px;
  background:rgba(255,255,255,.06);
  border-radius:50%;
}

.mtn-stripe { background:linear-gradient(145deg, #E65100 0%, #FF8F00 45%, #FFCA28 100%); }
.at-stripe  { background:linear-gradient(145deg, #B00020 0%, #E91E63 50%, #FF6B6B 100%); }
.tc-stripe  { background:linear-gradient(145deg, #0039CB 0%, #1565C0 50%, #2979FF 100%); }

/* Diagonal pattern overlay */
.card-stripe-pattern {
  position:absolute;inset:0;
  background:repeating-linear-gradient(
    -48deg,
    rgba(255,255,255,0) 0, rgba(255,255,255,0) 14px,
    rgba(255,255,255,.04) 14px, rgba(255,255,255,.04) 16px
  );
}

/* Network badge */
.card-net-badge{
  position:absolute;top:10px;left:10px;z-index:2;
  background:rgba(0,0,0,.25);
  backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.2);
  padding:.18rem .6rem;border-radius:6px;
  font-size:.67rem;font-weight:900;
  color:#fff;letter-spacing:.08em;text-transform:uppercase;
}

/* Bundle size — the hero number */
.card-size-display{
  position:absolute;
  bottom:9px;left:12px;z-index:2;
  font-family:'Outfit',sans-serif;font-weight:900;
  font-size:2rem;color:#fff;line-height:1;
  text-shadow:0 2px 12px rgba(0,0,0,.35);
  letter-spacing:-.05em;
}

/* Validity badge */
.card-validity-display{
  position:absolute;bottom:13px;right:10px;z-index:2;
  background:rgba(0,0,0,.3);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.16);
  padding:.15rem .5rem;border-radius:var(--rp);
  font-size:.63rem;font-weight:700;color:rgba(255,255,255,.9);
  letter-spacing:.02em;
}

/* Popular badge */
.card-popular-badge {
  position:absolute;top:10px;right:10px;z-index:3;
  background:linear-gradient(135deg,#FF6B6B,#FF3366);
  color:#fff;font-size:.6rem;font-weight:900;
  padding:.15rem .5rem;border-radius:5px;
  letter-spacing:.07em;text-transform:uppercase;
  box-shadow:0 4px 12px rgba(255,51,102,.4);
  animation:badgePop .4s cubic-bezier(.22,.68,0,1.5) both;
}
@keyframes badgePop{from{transform:scale(0)}to{transform:scale(1)}}

/* ── Card Body ── */
.card-body{
  padding:1rem 1.1rem .7rem;
  flex:1;display:flex;flex-direction:column;
  background:linear-gradient(180deg, rgba(255,255,255,.025) 0%, rgba(255,255,255,.01) 100%);
  border-top:1px solid rgba(255,255,255,.04);
}
.card-network-name{
  font-size:.68rem;color:var(--t3);font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;margin-bottom:.3rem;
}
.card-price{
  font-family:'Outfit',sans-serif;font-weight:900;
  font-size:1.55rem;line-height:1;letter-spacing:-.04em;
  margin-bottom:.1rem;
}
.mtn-price{color:var(--mtn)}
.at-price {color:var(--at)}
.tc-price {color:var(--tc)}
.card-desc{
  font-size:.7rem;color:var(--t3);letter-spacing:.02em;
}

/* ── Card Footer ── */
.card-footer{
  padding:.6rem 1.1rem .95rem;
}
.btn-details{
  width:100%;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  color:var(--t2);
  padding:.55rem .6rem;border-radius:var(--r2);
  font-size:.78rem;font-weight:700;cursor:pointer;
  font-family:'Outfit',sans-serif;
  transition:all .22s;text-align:center;
  letter-spacing:.02em;
  position:relative;overflow:hidden;
}
.bundle-card[data-net="mtn"] .btn-details:hover{
  background:rgba(255,202,40,.12);border-color:rgba(255,202,40,.4);color:var(--mtn);
}
.bundle-card[data-net="airteltigo"] .btn-details:hover{
  background:rgba(255,51,102,.12);border-color:rgba(255,51,102,.4);color:var(--at);
}
.bundle-card[data-net="telecel"] .btn-details:hover{
  background:rgba(41,121,255,.12);border-color:rgba(41,121,255,.4);color:var(--tc);
}

/* ── Card Drawer ── */
.card-drawer{
  background:rgba(5,6,12,.95);
  border-top:1px solid rgba(255,255,255,.06);
  padding:0;max-height:0;overflow:hidden;
  transition:max-height .4s cubic-bezier(.4,0,.2,1),padding .3s ease;
  backdrop-filter:blur(20px);
}
.card-drawer.open{max-height:390px;padding:1.1rem 1.1rem 1rem}
.drawer-title{
  font-size:.75rem;font-weight:800;color:var(--blue-lt);
  margin-bottom:.85rem;letter-spacing:.06em;text-transform:uppercase;
  display:flex;align-items:center;gap:.35rem;
}
.drawer-field{margin-bottom:.65rem}
.drawer-field label{
  display:block;font-size:.67rem;font-weight:700;
  color:var(--t3);margin-bottom:.26rem;
  letter-spacing:.07em;text-transform:uppercase;
}
.drawer-field input{
  width:100%;border:1.5px solid rgba(255,255,255,.08);background:var(--bg);
  color:var(--t1);padding:.52rem .75rem;border-radius:var(--r1);
  font-family:inherit;font-size:.85rem;outline:none;transition:all .2s;
}
.drawer-field input::placeholder{color:var(--t3)}
.drawer-field input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(59,130,246,.1)}
.drawer-hint{font-size:.66rem;color:var(--t3);margin-top:.2rem}
.btn-get-bundle{
  width:100%;border:none;padding:.65rem .5rem;
  border-radius:var(--r2);font-size:.83rem;font-weight:800;
  cursor:pointer;font-family:'Outfit',sans-serif;
  transition:all .22s;margin-top:.55rem;
  display:flex;align-items:center;justify-content:center;gap:.35rem;
  color:#fff;letter-spacing:.01em;
  position:relative;overflow:hidden;
}
.btn-get-bundle::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);
  transform:translateX(-100%);
  transition:transform .5s;
}
.btn-get-bundle:hover::after{transform:translateX(100%)}
.bundle-card[data-net="mtn"] .btn-get-bundle{
  background:linear-gradient(135deg,var(--mtn),var(--mtn-deep));
  color:var(--mtn-txt);
  box-shadow:0 6px 24px rgba(255,202,40,.3);
}
.bundle-card[data-net="airteltigo"] .btn-get-bundle{
  background:linear-gradient(135deg,var(--at),var(--at-deep));
  box-shadow:0 6px 24px rgba(255,51,102,.3);
}
.bundle-card[data-net="telecel"] .btn-get-bundle{
  background:linear-gradient(135deg,var(--tc),var(--tc-deep));
  box-shadow:0 6px 24px rgba(41,121,255,.3);
}
.btn-get-bundle:hover{transform:translateY(-2px);filter:brightness(1.08)}
.btn-get-bundle:disabled{opacity:.5;cursor:not-allowed;transform:none;filter:none}

/* ============================================================
   HOW IT WORKS SECTION
   ============================================================ */
.how-section{
  padding:5rem 1.5rem;
  background:var(--bg-2);
  border-top:1px solid var(--b);
  border-bottom:1px solid var(--b);
}
.how-grid{
  max-width:900px;margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:2rem;position:relative;
}
.how-step{text-align:center}
.how-step-num{
  width:52px;height:52px;border-radius:50%;
  background:linear-gradient(135deg,var(--bg-3),var(--bg-4));
  border:1px solid var(--b2);
  display:flex;align-items:center;justify-content:center;
  font-family:'Outfit',sans-serif;font-weight:900;
  font-size:1.2rem;color:var(--blue-lt);
  margin:0 auto 1rem;
  box-shadow:0 0 20px rgba(59,130,246,.12);
}
.how-step h3{font-size:.95rem;margin-bottom:.4rem}
.how-step p{font-size:.82rem;color:var(--t3);line-height:1.6}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{
  background:var(--bg-2);
  border-top:1px solid var(--b);
  padding:4.5rem 1.5rem 2rem;
}
.footer-grid{
  max-width:var(--mw);margin:0 auto;
  display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:3rem;
  margin-bottom:3rem;
}
.footer-brand p{font-size:.82rem;margin-top:.85rem;line-height:1.8;color:var(--t3)}
.footer-col h4{
  color:var(--t1);font-size:.76rem;font-weight:800;
  margin-bottom:1.1rem;letter-spacing:.1em;text-transform:uppercase;
}
.footer-col ul{display:flex;flex-direction:column;gap:.55rem}
.footer-col a{color:var(--t3);font-size:.82rem;transition:color .15s}
.footer-col a:hover{color:var(--blue-lt)}
.footer-bottom{
  max-width:var(--mw);margin:0 auto;
  border-top:1px solid var(--b);padding-top:1.5rem;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:1rem;font-size:.77rem;color:var(--t3);
}
.footer-bottom a{color:var(--t3)}.footer-bottom a:hover{color:var(--blue-lt)}
.footer-nets{display:flex;gap:.5rem;margin-top:1rem}
.footer-net-chip{
  padding:.18rem .6rem;border-radius:var(--rp);
  font-size:.69rem;font-weight:800;letter-spacing:.04em;
}
.fnc-mtn{background:rgba(255,202,40,.1);color:var(--mtn);border:1px solid rgba(255,202,40,.2)}
.fnc-at {background:rgba(255,51,102,.1);color:var(--at); border:1px solid rgba(255,51,102,.2)}
.fnc-tc {background:rgba(41,121,255,.1);color:var(--tc); border:1px solid rgba(41,121,255,.2)}

/* Footer social */
.footer-social{
  display:flex;gap:.5rem;margin-top:1.2rem;
}
.social-btn{
  width:34px;height:34px;border-radius:9px;
  background:rgba(255,255,255,.04);border:1px solid var(--b);
  display:flex;align-items:center;justify-content:center;
  font-size:.9rem;transition:all .2s;text-decoration:none;
}
.social-btn:hover{background:rgba(59,130,246,.1);border-color:var(--b2)}

/* ============================================================
   WOOCOMMERCE
   ============================================================ */
.woocommerce-page{max-width:var(--mw);margin:0 auto;padding:2.5rem 1.5rem}
.woocommerce-message,.woocommerce-error,.woocommerce-info{
  background:var(--bg-3);border:1px solid var(--blue);
  border-left:3px solid var(--blue);border-radius:var(--r2);
  padding:1rem 1.25rem;margin-bottom:1.25rem;list-style:none;color:var(--t1);
}
.woocommerce-error{border-color:var(--err);border-left-color:var(--err)}
.woocommerce-info {border-color:var(--warn);border-left-color:var(--warn)}
.woocommerce a.button,.woocommerce button.button,.woocommerce input.button{
  background:linear-gradient(135deg,var(--blue),var(--blue-dk)) !important;
  color:#fff !important;border-radius:var(--r1) !important;
  font-weight:800 !important;border:none !important;
  padding:.65rem 1.3rem !important;transition:opacity .15s !important;
  font-family:'Outfit',sans-serif !important;
}
.price{font-family:'Outfit',sans-serif;font-weight:800;color:var(--blue-lt)}

/* Breadcrumb */
.breadcrumb-wrap{
  background:var(--bg-2);border-bottom:1px solid var(--b);padding:.62rem 1.5rem;
}
.breadcrumb-wrap .woocommerce-breadcrumb{
  max-width:var(--mw);margin:0 auto;font-size:.77rem;color:var(--t3);
}
.breadcrumb-wrap .woocommerce-breadcrumb a{color:var(--blue-lt)}

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes cardIn{
  from{opacity:0;transform:translateY(20px) scale(.96)}
  to{opacity:1;transform:translateY(0) scale(1)}
}

.bundle-card:nth-child(1) {animation-delay:.03s}
.bundle-card:nth-child(2) {animation-delay:.06s}
.bundle-card:nth-child(3) {animation-delay:.09s}
.bundle-card:nth-child(4) {animation-delay:.12s}
.bundle-card:nth-child(5) {animation-delay:.15s}
.bundle-card:nth-child(6) {animation-delay:.18s}
.bundle-card:nth-child(7) {animation-delay:.21s}
.bundle-card:nth-child(8) {animation-delay:.24s}
.bundle-card:nth-child(9) {animation-delay:.27s}
.bundle-card:nth-child(10){animation-delay:.30s}
.bundle-card:nth-child(n+11){animation-delay:.33s}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:960px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .main-navigation{display:none}
  .main-navigation.toggled{
    display:block;position:absolute;top:var(--nh);left:0;right:0;
    background:rgba(7,8,15,.97);backdrop-filter:blur(20px);
    border-bottom:1px solid var(--b);padding:1.25rem 1.5rem;z-index:999;
  }
  .main-navigation.toggled ul{flex-direction:column;gap:.2rem}
  .menu-toggle{display:block}
  .trust-item{flex-direction:column;text-align:center}
}
@media(max-width:600px){
  .hero-stat{padding:.85rem 1.2rem}
  .bundles-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.9rem}
  .footer-grid{grid-template-columns:1fr;gap:1.75rem}
  .network-tabs{gap:.35rem}
  .vtu-hero{padding:4rem 1.25rem 3.5rem}
  .hero-ctas{flex-direction:column;align-items:center}
  .how-grid{grid-template-columns:1fr;gap:1.5rem}
}

/* Custom logo support — Appearance → Customise → Site Identity */
.logo-img-wrap { display:flex; align-items:center; }
.logo-img-wrap img,
.custom-logo { max-height:38px; width:auto; display:block; }
.site-footer .logo-img-wrap img,
.site-footer .custom-logo { max-height:32px; }

/* ============================================================
   DISABLED STATES
   ============================================================ */
.btn-order:disabled,.btn-get-bundle:disabled{
  cursor:not-allowed;opacity:.45 !important;
  transform:none !important;box-shadow:none !important;filter:none !important;
}
