/* Game Vault 999 — Responsive Casino Site CSS */
:root{
  --gv-gold:#FFD700;
  --gv-purple-deep:#1a0a2e;
  --gv-purple:#231741;
  --gv-purple-mid:#5a1b71;
  --gv-purple-bright:#a820c4;
  --gv-pink:#c428e0;
  --gv-red:#dc143c;
  --gv-green:#00ff88;
  --gv-white:#ffffff;
  --gv-bg:#0e0820;
  --gv-bg-2:#15102b;
  --gv-text:#e9e6f4;
  --gv-text-mute:#a8a3c2;
  --gv-card:#1c1437;
  --gv-card-2:#231741;
  --gv-border:rgba(255,255,255,0.08);
  --gv-radius:16px;
  --gv-shadow:0 10px 40px rgba(0,0,0,.35);
  --gv-max:1200px;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{margin:0;font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--gv-bg);color:var(--gv-text);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;-webkit-text-size-adjust:100%;text-size-adjust:100%}
img{max-width:100%;height:auto;display:block}
a{color:var(--gv-gold);text-decoration:none}
a:hover{color:#fff}
h1,h2,h3,h4{color:#fff;line-height:1.2;margin:0 0 .6em}
.gv-container{max-width:var(--gv-max);margin:0 auto;padding:0 20px}

/* Header */
.gv-header{position:sticky;top:0;z-index:100;background:linear-gradient(180deg,#0e0820 0%,#15102b 100%);box-shadow:0 4px 20px rgba(0,0,0,.5)}
.gv-nav-wrap{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:14px 20px}
.gv-logo{display:inline-flex;align-items:center;gap:10px;color:#fff;font-weight:800}
.gv-logo:hover{color:#fff}
.gv-logo-mark{width:clamp(34px,6vw,42px);height:clamp(34px,6vw,42px);border-radius:12px;background:linear-gradient(135deg,var(--gv-purple-bright),var(--gv-pink));display:grid;place-items:center;font-weight:900;letter-spacing:1px;box-shadow:0 6px 20px rgba(168,32,196,.5)}
.gv-logo-text{font-size:clamp(.88rem,2.5vw,1.15rem);letter-spacing:.5px;white-space:nowrap}
.gv-logo-text strong{color:var(--gv-gold)}
.gv-nav{display:flex;gap:6px;flex-wrap:nowrap}
.gv-nav a{color:var(--gv-text);padding:9px 10px;border-radius:10px;font-weight:600;font-size:.88rem;transition:all .2s;white-space:nowrap}
.gv-nav a:hover{background:rgba(255,255,255,.06);color:#fff}
.gv-nav a.active{background:rgba(168,32,196,.18);color:#fff}
.gv-nav-actions{display:flex;align-items:center;gap:10px}
.gv-burger{display:none;flex-direction:column;gap:5px;background:transparent;border:0;cursor:pointer;padding:8px}
.gv-burger span{width:24px;height:2px;background:#fff;border-radius:2px;transition:.3s}

/* Buttons */
.gv-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;border-radius:50px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border:0;cursor:pointer;font-size:.95rem;transition:all .3s cubic-bezier(.175,.885,.32,1.275);text-align:center;line-height:1.2}
.gv-btn-sm{padding:10px 18px;font-size:.85rem}
.gv-btn-large{padding:18px 38px;font-size:1.05rem}
.gv-btn-primary{background:linear-gradient(135deg,#a820c4 0%,#7a1a8f 100%);color:#fff;box-shadow:0 10px 30px rgba(168,32,196,.5);border:2px solid rgba(255,255,255,.18)}
.gv-btn-primary:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 18px 40px rgba(168,32,196,.7);border-color:var(--gv-gold);color:#fff}
.gv-btn-secondary{background:rgba(255,255,255,.08);color:#fff;border:2px solid rgba(255,255,255,.5);backdrop-filter:blur(8px)}
.gv-btn-secondary:hover{background:#fff;color:var(--gv-purple);border-color:#fff}
.gv-btn-bonus{background:linear-gradient(135deg,#fff 0%,#f0f0f0 100%);color:#5a1b71;border:3px solid #FFD700;font-weight:900;padding:14px 28px;text-transform:uppercase}
.gv-btn-bonus:hover{transform:translateY(-2px);color:#231741}
.gv-pulse{animation:gv-pulse 2.4s infinite}
@keyframes gv-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.04)}}

/* Hero */
.gv-hero{position:relative;min-height:78vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a0a2e 0%,#3a1959 50%,#16213e 100%);overflow:hidden}
.gv-hero-overlay{position:absolute;inset:0;background-image:radial-gradient(circle at 30% 50%,rgba(168,32,196,.45) 0%,transparent 60%),radial-gradient(circle at 80% 70%,rgba(255,215,0,.2) 0%,transparent 50%);z-index:1}
.gv-hero-content{position:relative;z-index:2;text-align:center;padding:60px 20px;animation:gv-fadeUp .8s ease}
@keyframes gv-fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.gv-badge{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;background:rgba(136,21,150,.4);border:2px solid var(--gv-gold);border-radius:50px;color:var(--gv-gold);font-weight:700;margin-bottom:22px;box-shadow:0 4px 14px rgba(0,0,0,.4)}
.gv-title{font-size:clamp(2.4rem,7vw,5rem);font-weight:900;margin:0 0 16px;text-shadow:0 0 40px rgba(168,32,196,.7),0 4px 20px rgba(0,0,0,.7)}
.gv-title-sub{display:block;font-size:clamp(.75rem,1.8vw,1.1rem);font-weight:600;letter-spacing:4px;text-transform:uppercase;color:rgba(255,255,255,.65);margin-top:6px;-webkit-text-fill-color:rgba(255,255,255,.65)}
.gv-highlight{color:#fff;letter-spacing:3px;text-transform:uppercase;background:linear-gradient(135deg,#fff,var(--gv-gold) 60%,#fff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
/* Base override: home page always pure white */
body[data-page="home"] .gv-highlight,
body[data-page="home"] .gv-title .gv-highlight{
  color:#fff !important;
  background:none !important;
  background-image:none !important;
  -webkit-background-clip:initial !important;
  background-clip:initial !important;
  -webkit-text-fill-color:#fff !important;
  display:inline-block;
}
.gv-subtitle{font-size:clamp(1.1rem,2.6vw,1.7rem);color:#fff;font-weight:700;margin:0 0 14px;text-shadow:0 2px 10px rgba(0,0,0,.7)}
.gv-description{font-size:clamp(1rem,1.6vw,1.15rem);max-width:720px;margin:0 auto 36px;color:rgba(255,255,255,.92);line-height:1.7}
.gv-cta-group{display:flex;gap:14px;justify-content:center;align-items:center;flex-wrap:wrap;margin-bottom:30px}
.gv-trust-badges{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin:0 0 22px}
.gv-trust-item{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;background:rgba(0,0,0,.35);border-radius:50px;color:#fff;font-size:.9rem;border:1px solid rgba(255,255,255,.1)}
.gv-rating-wrapper{margin-bottom:22px}
.gv-trustpilot-badge{display:inline-flex;align-items:center;gap:10px;padding:10px 18px;background:#191919;border-radius:6px;color:#fff;font-weight:600;text-decoration:none}
.gv-tp-logo{display:inline-flex;align-items:center;gap:6px;border-right:1px solid rgba(255,255,255,.25);padding-right:10px}
.gv-tp-logo-star{width:18px;height:18px;background:#00B67A;border-radius:2px}
.gv-tp-stars{display:inline-flex;gap:2px;color:#00B67A}
.gv-tp-text{font-size:.85rem;color:rgba(255,255,255,.92)}
.gv-features-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.gv-feature-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:50px;color:#fff;font-size:.88rem;backdrop-filter:blur(8px)}

/* Bonus banner */
.gv-bonus-banner{background:linear-gradient(135deg,rgba(35,23,65,.95) 0%,rgba(90,27,113,.92) 100%);padding:24px 0;color:#fff;border-bottom:3px solid rgba(255,215,0,.3);position:relative;overflow:hidden}
.gv-bonus-flex{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap}
.gv-bonus-icon{width:54px;height:54px;background:rgba(255,215,0,.1);color:#FFD700;border-radius:50%;display:grid;place-items:center;font-size:1.4rem;border:2px solid rgba(255,215,0,.4)}
.gv-bonus-text h2{margin:0;font-size:1.15rem;color:#fff}
.gv-bonus-text p{margin:0;color:rgba(255,255,255,.9);font-weight:600}

/* Sections */
.gv-section{padding:80px 0;position:relative}
.gv-section-gray{background:linear-gradient(180deg,#0e0820 0%,#160e30 100%)}
.gv-section-header{text-align:center;max-width:760px;margin:0 auto 50px}
.gv-section-header h2{font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:12px}
.gv-section-header p{color:var(--gv-text-mute);font-size:1.05rem}
.gv-section-cta{text-align:center;margin-top:40px}
.gv-section-title{text-align:center;font-size:1.8rem;margin-bottom:30px}
.gv-badge-sm{display:inline-block;padding:6px 14px;background:rgba(168,32,196,.18);color:var(--gv-gold);border-radius:50px;font-size:.78rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:14px}

/* Grids */
.gv-grid-3,.gv-grid-4{display:grid;gap:24px}
.gv-grid-3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.gv-grid-4{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}

/* Cards */
.gv-card{background:var(--gv-card);border:1px solid var(--gv-border);border-radius:var(--gv-radius);padding:30px 24px;text-align:center;transition:all .3s;position:relative}
.gv-card:hover{transform:translateY(-6px);box-shadow:var(--gv-shadow);border-color:rgba(168,32,196,.5)}
.gv-card-featured{background:linear-gradient(180deg,rgba(168,32,196,.15) 0%,var(--gv-card) 100%);border-color:rgba(168,32,196,.5)}
.gv-featured-tag{position:absolute;top:14px;right:14px;background:linear-gradient(135deg,#FFD700,#ff8c00);color:#231741;padding:5px 12px;border-radius:50px;font-size:.7rem;font-weight:800;text-transform:uppercase}
.gv-icon-circle{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--gv-purple-bright),var(--gv-pink));display:grid;place-items:center;color:#fff;font-size:1.6rem;margin:0 auto 18px;box-shadow:0 8px 20px rgba(168,32,196,.4)}
.gv-card h3{font-size:1.2rem;margin-bottom:10px}
.gv-card p{color:var(--gv-text-mute);font-size:.95rem;margin:0 0 14px}
.gv-check-list{list-style:none;padding:0;margin:0;text-align:left}
.gv-check-list li{padding:6px 0;color:var(--gv-text-mute);font-size:.9rem}
.gv-check-list li i{color:var(--gv-green);margin-right:8px}

/* Steps */
.gv-steps{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap}
.gv-step{flex:1;min-width:220px;max-width:300px;text-align:center;padding:30px 20px;background:var(--gv-card);border-radius:var(--gv-radius);border:1px solid var(--gv-border);position:relative}
.gv-step-number{position:absolute;top:-22px;left:50%;transform:translateX(-50%);width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#FFD700,#ff8c00);color:#231741;display:grid;place-items:center;font-weight:900;font-size:1.2rem}
.gv-step-icon{width:64px;height:64px;border-radius:50%;background:rgba(168,32,196,.18);color:var(--gv-gold);display:grid;place-items:center;font-size:1.4rem;margin:18px auto 14px}
.gv-step-arrow{color:var(--gv-purple-bright);font-size:1.4rem}

/* Game cards */
.gv-game-card{background:var(--gv-card);border-radius:var(--gv-radius);overflow:hidden;border:1px solid var(--gv-border);transition:.3s}
.gv-game-card:hover{transform:translateY(-4px);box-shadow:var(--gv-shadow);border-color:rgba(168,32,196,.5)}
.gv-game-thumb{aspect-ratio:16/10;background:linear-gradient(135deg,var(--gv-purple-mid),var(--gv-purple));overflow:hidden;position:relative}
.gv-game-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}
.gv-game-card:hover .gv-game-thumb img{transform:scale(1.05)}
.gv-game-flag{position:absolute;top:10px;left:10px;background:#dc143c;color:#fff;padding:4px 10px;border-radius:50px;font-size:.7rem;font-weight:800;letter-spacing:1px}
.gv-game-rtp{position:absolute;top:10px;right:10px;background:rgba(0,0,0,.6);color:#FFD700;padding:4px 10px;border-radius:50px;font-size:.72rem;font-weight:700}
.gv-game-info{padding:16px}
.gv-game-info h3{font-size:1.05rem;margin:0 0 4px}
.gv-game-info p{color:var(--gv-text-mute);font-size:.85rem;margin:0 0 10px}

/* Filter bar */
.gv-filter-bar{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:30px}
.gv-filter-bar button{background:var(--gv-card);border:1px solid var(--gv-border);color:var(--gv-text);padding:10px 18px;border-radius:50px;cursor:pointer;font-weight:600;transition:.2s}
.gv-filter-bar button:hover,.gv-filter-bar button.active{background:linear-gradient(135deg,var(--gv-purple-bright),var(--gv-pink));color:#fff;border-color:transparent}

/* Promotions */
.gv-promo-card{background:var(--gv-card);border:1px solid var(--gv-border);border-radius:var(--gv-radius);padding:28px;position:relative;overflow:hidden;transition:.3s}
.gv-promo-card:hover{transform:translateY(-4px);box-shadow:var(--gv-shadow);border-color:rgba(255,215,0,.4)}
.gv-promo-tag{display:inline-block;background:rgba(255,215,0,.15);color:var(--gv-gold);padding:4px 12px;border-radius:50px;font-size:.7rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:12px}
.gv-promo-card h3{font-size:1.4rem;margin-bottom:10px}
.gv-promo-card p{color:var(--gv-text-mute);margin-bottom:18px}

/* VIP */
.gv-vip-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.gv-vip-tier{background:var(--gv-card);border:1px solid var(--gv-border);border-radius:var(--gv-radius);padding:26px;text-align:center}
.gv-vip-tier.featured{background:linear-gradient(180deg,rgba(255,215,0,.1) 0%,var(--gv-card) 100%);border-color:rgba(255,215,0,.4)}
.gv-vip-tier h3{color:var(--gv-gold);font-size:1.4rem}
.gv-vip-tier ul{list-style:none;padding:0;margin:14px 0 0;text-align:left}
.gv-vip-tier li{padding:6px 0;color:var(--gv-text-mute);font-size:.9rem;border-bottom:1px dashed var(--gv-border)}

/* Contact cards */
.gv-contact-card{display:block;background:var(--gv-card);border:1px solid var(--gv-border);border-radius:var(--gv-radius);padding:34px 26px;text-align:center;color:var(--gv-text);transition:.3s;position:relative}
.gv-contact-card:hover{transform:translateY(-6px);box-shadow:var(--gv-shadow);color:#fff}
.gv-contact-icon{width:74px;height:74px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:1.8rem;margin:0 auto 16px}
.gv-messenger .gv-contact-icon{background:linear-gradient(135deg,#0078ff,#0058c4)}
.gv-telegram .gv-contact-icon{background:linear-gradient(135deg,#0088cc,#005f8e)}
.gv-whatsapp .gv-contact-icon{background:linear-gradient(135deg,#25d366,#128c7e)}
.gv-contact-badge{display:inline-block;background:var(--gv-gold);color:#231741;padding:4px 12px;border-radius:50px;font-size:.7rem;font-weight:800;text-transform:uppercase;margin:10px 0}
.gv-contact-btn{display:inline-flex;align-items:center;gap:6px;color:var(--gv-gold);font-weight:700;margin-top:10px}

/* FAQ */
.gv-faq-container{max-width:820px;margin:0 auto}
.gv-faq-item{background:var(--gv-card);border:1px solid var(--gv-border);border-radius:12px;margin-bottom:12px;overflow:hidden}
.gv-faq-item[open]{border-color:rgba(168,32,196,.5)}
.gv-faq-question{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;cursor:pointer;list-style:none}
.gv-faq-question::-webkit-details-marker{display:none}
.gv-faq-question h3{font-size:1.05rem;margin:0;flex:1;min-width:0}
.gv-faq-question i{color:var(--gv-gold);transition:.3s}
.gv-faq-item[open] .gv-faq-question i{transform:rotate(45deg)}
.gv-faq-answer{padding:0 22px 18px;color:var(--gv-text-mute)}

/* CTA */
.gv-cta-section{padding:80px 0;background:linear-gradient(135deg,#3a1959,#1a0a2e);text-align:center}
.gv-cta-content h2{font-size:clamp(1.8rem,3.5vw,2.6rem)}
.gv-cta-content p{color:rgba(255,255,255,.85);font-size:1.05rem}
.gv-cta-buttons{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin:24px 0}
.gv-cta-note{color:var(--gv-gold);font-weight:600}

/* Page hero */
.gv-page-hero{padding:90px 20px 60px;text-align:center;background:linear-gradient(135deg,#1a0a2e,#3a1959)}
.gv-page-hero h1{font-size:clamp(2rem,4.5vw,3.4rem);margin-bottom:14px}
.gv-page-hero p{color:rgba(255,255,255,.85);max-width:720px;margin:0 auto}

/* Prose */
.gv-prose{max-width:820px;margin:0 auto;font-size:1.02rem}
.gv-post-hero-img{width:100%;border-radius:14px;overflow:hidden;margin-bottom:28px;aspect-ratio:16/9}
.gv-post-hero-img img{width:100%;height:100%;object-fit:cover;display:block}
.gv-prose h2{font-size:1.6rem;margin:36px 0 14px;color:#fff}
.gv-prose p,.gv-prose li{color:#cfcad9}
.gv-prose .gv-lead{font-size:1.15rem;color:#fff}
.gv-feature-list{list-style:none;padding:0}
.gv-feature-list li{padding:10px 0;border-bottom:1px dashed var(--gv-border)}
.gv-feature-list li i{color:var(--gv-gold);margin-right:10px}
.gv-callout{background:rgba(168,32,196,.1);border:1px solid rgba(168,32,196,.4);border-radius:12px;padding:18px 22px;margin-top:24px;color:#fff}
.gv-callout-cta{text-align:center}
.gv-callout-cta h3{margin-bottom:6px}

/* Blog */
.gv-blog-card{background:var(--gv-card);border:1px solid var(--gv-border);border-radius:var(--gv-radius);overflow:hidden;display:flex;flex-direction:column;transition:.3s}
.gv-blog-card:hover{transform:translateY(-4px);box-shadow:var(--gv-shadow)}
.gv-blog-thumb{display:block;aspect-ratio:16/9;overflow:hidden;background:linear-gradient(135deg,var(--gv-purple-mid),var(--gv-purple))}
.gv-blog-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
.gv-blog-card:hover .gv-blog-thumb img{transform:scale(1.04)}
.gv-blog-meta{padding:14px 18px 0;font-size:.8rem;color:var(--gv-text-mute);text-transform:uppercase;letter-spacing:.5px}
.gv-blog-card h3{padding:6px 18px;font-size:1.1rem;line-height:1.35}
.gv-blog-card h3 a{color:#fff}
.gv-blog-card>p{padding:0 18px;color:var(--gv-text-mute);flex:1}
.gv-blog-author{padding:0 18px;font-size:.85rem;color:var(--gv-text-mute)}
.gv-blog-readmore{display:inline-flex;align-items:center;gap:6px;padding:14px 18px;font-weight:700;color:var(--gv-gold)}
.gv-breadcrumb{font-size:.85rem;color:var(--gv-text-mute);margin-bottom:14px}
.gv-breadcrumb a{color:var(--gv-text-mute)}
.gv-breadcrumb a:hover{color:var(--gv-gold)}
.gv-article-meta{margin:8px 0 24px}
.gv-author-chip{display:inline-flex;align-items:center;gap:10px;padding:8px 14px;background:var(--gv-card);border:1px solid var(--gv-border);border-radius:50px;color:var(--gv-text);font-size:.9rem}
.gv-author-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--gv-purple-bright),var(--gv-pink));display:grid;place-items:center;color:#fff;font-weight:800;font-size:.85rem}
.gv-avatar-lg{width:60px;height:60px;font-size:1.1rem;margin:0 auto 12px}
.gv-avatar-xl{width:96px;height:96px;font-size:1.6rem}
.gv-author-card{display:block;background:var(--gv-card);border:1px solid var(--gv-border);border-radius:var(--gv-radius);padding:28px;text-align:center;color:var(--gv-text);transition:.3s}
.gv-author-card:hover{transform:translateY(-4px);box-shadow:var(--gv-shadow);color:#fff}
.gv-author-role{color:var(--gv-gold);font-weight:600;font-size:.9rem;margin-bottom:8px}
.gv-author-hero{display:flex;align-items:center;gap:24px;justify-content:center;flex-wrap:wrap;text-align:left}
.gv-author-hero h1{margin-bottom:4px}
.gv-author-social{display:flex;gap:12px;margin-top:14px}
.gv-author-social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);display:grid;place-items:center;color:#fff}

/* Modal */
.gv-modal{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;padding:20px}
.gv-modal.active{display:flex}
.gv-modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(6px)}
.gv-modal-content{position:relative;background:var(--gv-card-2);border:1px solid var(--gv-border);border-radius:20px;max-width:480px;width:100%;padding:34px 26px;text-align:center;animation:gv-fadeUp .3s ease}
.gv-modal-close{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.08);border:0;color:#fff;cursor:pointer}
.gv-modal-icon-main{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--gv-purple-bright),var(--gv-pink));display:grid;place-items:center;color:#fff;font-size:1.5rem;margin:0 auto 14px}
.gv-modal-title{font-size:1.3rem;margin-bottom:6px}
.gv-modal-subtitle{color:var(--gv-text-mute);margin-bottom:18px}
.gv-modal-contact-options{display:flex;flex-direction:column;gap:10px;margin-bottom:18px}
.gv-contact-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 18px;border-radius:12px;color:#fff;font-weight:700;text-decoration:none}
.gv-contact-whatsapp{background:linear-gradient(135deg,#25d366,#128c7e)}
.gv-contact-telegram{background:linear-gradient(135deg,#0088cc,#005f8e)}
.gv-contact-messenger{background:linear-gradient(135deg,#0078ff,#0058c4)}
.gv-modal-note{color:var(--gv-text-mute);font-size:.85rem;margin-bottom:14px}
.gv-btn-modal-close{background:transparent;border:1px solid var(--gv-border);color:var(--gv-text);padding:10px 22px;border-radius:50px;cursor:pointer;font-weight:700}

/* Floating contact */
.gv-floating-contact{position:fixed;bottom:24px;right:20px;z-index:90}
.gv-float-btn{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--gv-purple-bright),var(--gv-pink));color:#fff;border:0;cursor:pointer;font-size:1.3rem;box-shadow:0 8px 24px rgba(168,32,196,.5)}
.gv-float-menu{display:flex;flex-direction:column;gap:10px;margin-bottom:12px;opacity:0;transform:translateY(10px);pointer-events:none;transition:.3s}
.gv-floating-contact.open .gv-float-menu{opacity:1;transform:translateY(0);pointer-events:auto}
.gv-float-option{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:50px;color:#fff;font-weight:700;font-size:.85rem;text-decoration:none;box-shadow:0 6px 20px rgba(0,0,0,.4)}
.gv-messenger-opt{background:linear-gradient(135deg,#0078ff,#0058c4)}
.gv-telegram-opt{background:linear-gradient(135deg,#0088cc,#005f8e)}
.gv-whatsapp-opt{background:linear-gradient(135deg,#25d366,#128c7e)}

/* Footer */
.gv-footer{background:#08041a;color:var(--gv-text);padding:60px 0 30px;border-top:1px solid var(--gv-border)}
.gv-footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;margin-bottom:40px}
.gv-footer-about{color:var(--gv-text-mute);font-size:.92rem;margin:14px 0}
.gv-footer-social{display:flex;gap:10px}
.gv-footer-social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.06);display:grid;place-items:center;color:#fff}
.gv-footer-social a:hover{background:linear-gradient(135deg,var(--gv-purple-bright),var(--gv-pink))}
.gv-footer-col h3{font-size:.95rem;letter-spacing:1.2px;text-transform:uppercase;color:var(--gv-gold);margin-bottom:14px}
.gv-footer-col ul{list-style:none;padding:0;margin:0}
.gv-footer-col li{margin-bottom:8px}
.gv-footer-col a{color:var(--gv-text-mute);font-size:.92rem}
.gv-footer-col a:hover{color:#fff}
.gv-footer-compliance{border-top:1px solid var(--gv-border);padding-top:18px;margin-bottom:16px}
.gv-compliance-row{display:flex;gap:14px;align-items:flex-start}
.gv-age-badge{flex-shrink:0;width:44px;height:44px;border-radius:10px;background:#dc143c;color:#fff;display:grid;place-items:center;font-weight:900;font-size:1rem}
.gv-compliance-badges{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}
.gv-compliance-row p{color:#c8c4df;font-size:.8rem;line-height:1.6;margin:0}.gv-compliance-row p a{color:#e9e6f4;text-decoration:underline}.gv-compliance-row p a:hover{color:#fff}
.gv-ci-badge{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;font-weight:600;padding:3px 8px;border-radius:20px;border:1px solid rgba(255,255,255,.1);color:var(--gv-text-mute);white-space:nowrap}
.gv-footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;border-top:1px solid var(--gv-border);padding-top:18px;color:var(--gv-text-mute);font-size:.85rem}

/* Responsive */
@media (max-width:1024px){
  .gv-footer-grid{grid-template-columns:1fr 1fr}
  .gv-nav{display:none;position:absolute;top:100%;left:0;right:0;background:linear-gradient(180deg,#15102b 0%,#0e0820 100%);padding:8px 0 16px;flex-direction:column;border-top:2px solid rgba(168,32,196,.7);border-bottom:3px solid rgba(255,215,0,.25);box-shadow:0 18px 50px rgba(0,0,0,.85);z-index:200}
  .gv-nav.open{display:flex}
  .gv-burger{display:flex}
  /* Hide Get Started button on mobile/tablet — burger only */
  .gv-nav-actions .gv-btn{display:none !important}
  .gv-nav-wrap{gap:12px}
}
@media (max-width:640px){
  .gv-section{padding:54px 0}
  .gv-page-hero{padding:60px 16px 40px}
  .gv-bonus-flex{flex-direction:column;text-align:center}
  .gv-footer-grid{grid-template-columns:1fr}
  .gv-cta-buttons{flex-direction:column;align-items:center}
  .gv-cta-buttons .gv-btn{width:100%;max-width:340px}
  .gv-step-arrow{transform:rotate(90deg)}
  .gv-author-hero{text-align:center}
}
@media (prefers-reduced-motion: reduce){
}

/* =====================================================================
   HOMEPAGE — color grading from gamevaultdesign.html (Game Vault 999)
   Scoped to body[data-page="home"] so other pages keep dark theme.
   ===================================================================== */
body[data-page="home"]{
  --hp-gold:#FFD700;
  --hp-purple-brand:#881596;
  --hp-dark:#231741;
  --hp-purple:#5a1b71;
  --hp-purple-deep:#1a0a2e;
  --hp-purple-mid:#16213e;
  --hp-gray:#6c757d;
  --hp-gray-light:#f8f9fa;
}
body[data-page="home"] h1,
body[data-page="home"] h2,
body[data-page="home"] h3{font-family:'Poppins','Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-weight:900;letter-spacing:.3px}

/* HERO — exact design grading */
body[data-page="home"] .gv-hero{
  background:linear-gradient(135deg,#1a0a2e 0%,#16213e 100%);
  min-height:80vh;
}
body[data-page="home"] .gv-hero-overlay{
  background-image:
    radial-gradient(circle at 30% 50%,rgba(136,21,150,.45) 0%,transparent 60%),
    linear-gradient(135deg,rgba(35,23,65,.85) 0%,rgba(90,27,113,.75) 100%);
}
body[data-page="home"] .gv-badge{
  background:rgba(136,21,150,.35);
  border:2px solid #FFD700;
  color:#FFD700;
  box-shadow:0 4px 15px rgba(136,21,150,.5),0 0 22px rgba(255,215,0,.3);
  text-shadow:0 2px 10px rgba(0,0,0,.6);
}
body[data-page="home"] .gv-title{
  font-size:clamp(2.6rem,7.4vw,5.2rem);
  text-shadow:0 0 40px rgba(136,21,150,.85),0 0 80px rgba(136,21,150,.5),0 4px 20px rgba(0,0,0,.85);
}
body[data-page="home"] .gv-highlight{
  color:#fff !important;
  background:none !important;
  -webkit-text-fill-color:#fff !important;
  letter-spacing:3px;
  text-transform:uppercase;
}
body[data-page="home"] .gv-subtitle{
  text-shadow:0 4px 20px rgba(0,0,0,.95),0 2px 10px rgba(0,0,0,.8),0 0 30px rgba(136,21,150,.6);
  letter-spacing:.5px;
}
body[data-page="home"] .gv-description{
  color:rgba(255,255,255,.95);
  text-shadow:0 3px 15px rgba(0,0,0,.9);
  line-height:1.8;
}

/* PRIMARY BUTTON — exact design glow */
body[data-page="home"] .gv-btn-primary{
  background:linear-gradient(135deg,#a820c4 0%,#7a1a8f 100%);
  box-shadow:0 10px 40px rgba(168,32,196,.7),0 4px 20px rgba(0,0,0,.4),0 0 30px rgba(168,32,196,.5);
  border:2px solid rgba(255,255,255,.3);
  text-transform:uppercase;letter-spacing:1px;
  position:relative;overflow:hidden;
}
body[data-page="home"] .gv-btn-primary::before{
  content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;
  background:linear-gradient(45deg,transparent,rgba(255,255,255,.2),transparent);
  animation:hp-shimmer 3s infinite;pointer-events:none;
}
@keyframes hp-shimmer{0%{transform:translateX(-100%) translateY(-100%) rotate(45deg)}100%{transform:translateX(100%) translateY(100%) rotate(45deg)}}
body[data-page="home"] .gv-btn-primary:hover{
  transform:translateY(-6px) scale(1.06);
  background:linear-gradient(135deg,#c428e0 0%,#8f1faa 100%);
  box-shadow:0 25px 60px rgba(168,32,196,.9),0 10px 30px rgba(0,0,0,.5),0 0 50px rgba(255,215,0,.5);
  border-color:#FFD700;
}

/* TRUST BADGES + FEATURE BADGES (hero) */
body[data-page="home"] .gv-trust-item,
body[data-page="home"] .gv-feature-badge{
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.3);
  backdrop-filter:blur(10px);
  box-shadow:0 4px 15px rgba(0,0,0,.2);
}
body[data-page="home"] .gv-feature-badge i{
  color:#FFD700;filter:drop-shadow(0 0 8px rgba(255,215,0,.6));
}

/* BONUS BANNER — dark purple sticky w/ sparkle (design) */
body[data-page="home"] .gv-bonus-banner{
  background:linear-gradient(135deg,rgba(35,23,65,.96) 0%,rgba(90,27,113,.92) 100%);
  padding:26px 0;color:#fff;border-bottom:3px solid rgba(136,21,150,.45);
  box-shadow:0 8px 25px rgba(0,0,0,.6);position:relative;overflow:hidden;
}
body[data-page="home"] .gv-bonus-banner::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(circle 3px at 18% 30%,rgba(255,215,0,.95),transparent),
    radial-gradient(circle 2px at 60% 70%,rgba(255,215,0,.8),transparent),
    radial-gradient(circle 3px at 80% 18%,rgba(255,215,0,.95),transparent),
    radial-gradient(circle 3px at 33% 80%,rgba(255,215,0,.95),transparent),
    radial-gradient(circle 2px at 92% 60%,rgba(255,255,255,.85),transparent),
    radial-gradient(circle 3px at 48% 22%,rgba(255,215,0,.7),transparent);
  background-size:200% 200%;animation:hp-sparkle 3s linear infinite;
}
@keyframes hp-sparkle{0%{opacity:.5;background-position:0% 0%}50%{opacity:1;background-position:100% 100%}100%{opacity:.5;background-position:200% 200%}}
body[data-page="home"] .gv-bonus-icon{
  width:auto;height:auto;background:transparent;color:#FFD700;font-size:3rem;
  filter:drop-shadow(0 0 18px rgba(255,215,0,.9));
}
body[data-page="home"] .gv-bonus-text h2{color:#fff;font-size:1.6rem;text-shadow:0 2px 14px rgba(0,0,0,.7)}
body[data-page="home"] .gv-bonus-text p{color:rgba(255,255,255,.95);font-size:1.05rem}
body[data-page="home"] .gv-bonus-text strong{
  color:#FFD700;font-weight:900;
  text-shadow:0 0 25px rgba(255,215,0,.95),0 0 45px rgba(255,215,0,.6),0 3px 18px rgba(0,0,0,1);
  letter-spacing:.8px;
}
body[data-page="home"] .gv-btn-bonus{
  background:linear-gradient(135deg,#fff 0%,#f0f0f0 100%);
  color:#5a1b71;border:3px solid #FFD700;font-weight:900;text-transform:uppercase;
  box-shadow:0 8px 30px rgba(255,215,0,.6),0 0 25px rgba(255,255,255,.7);
  padding:16px 40px;
}
body[data-page="home"] .gv-btn-bonus:hover{
  background:linear-gradient(135deg,#a820c4 0%,#7a1a8f 100%);color:#fff;
  transform:scale(1.08);box-shadow:0 15px 50px rgba(255,215,0,.8),0 0 40px rgba(168,32,196,.9);
}

/* SECTIONS — purple gradient w/ white cards (design system) */
body[data-page="home"] .gv-section{
  background:linear-gradient(135deg,rgba(35,23,65,.95) 0%,rgba(90,27,113,.9) 100%);
  position:relative;overflow:hidden;padding:90px 0;
}
body[data-page="home"] .gv-section::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at top right,rgba(136,21,150,.22) 0%,transparent 60%);
}
body[data-page="home"] .gv-section-gray{
  background:linear-gradient(135deg,rgba(35,23,65,.96) 0%,rgba(90,27,113,.92) 100%);
}
body[data-page="home"] .gv-section-header h2{
  color:#fff;font-size:clamp(2rem,4.2vw,3rem);
  text-shadow:0 3px 20px rgba(0,0,0,.7),0 1px 10px rgba(0,0,0,.5);
}
body[data-page="home"] .gv-section-header p{
  color:rgba(255,255,255,.92);font-size:1.1rem;
  text-shadow:0 2px 10px rgba(0,0,0,.5);
}
body[data-page="home"] .gv-badge-sm{
  background:linear-gradient(135deg,#881596 0%,#5a1b71 100%);
  color:#fff;padding:8px 22px;font-size:.85rem;font-weight:700;
  box-shadow:0 6px 18px rgba(136,21,150,.4);
}

/* WHITE CARDS on dark sections */
body[data-page="home"] .gv-section .gv-card{
  background:rgba(255,255,255,.98);color:#231741;
  border:2px solid rgba(136,21,150,.15);border-radius:24px;
  box-shadow:0 10px 30px rgba(0,0,0,.18),0 4px 12px rgba(136,21,150,.15);
  padding:36px 28px;backdrop-filter:blur(20px);
}
body[data-page="home"] .gv-section .gv-card:hover{
  transform:translateY(-12px) scale(1.02);
  box-shadow:0 25px 50px rgba(136,21,150,.35),0 15px 30px rgba(0,0,0,.25),0 0 40px rgba(136,21,150,.2);
  border-color:#FFD700;
}
body[data-page="home"] .gv-section .gv-card h3{color:#231741;font-size:1.45rem}
body[data-page="home"] .gv-section .gv-card p{color:#6c757d}
body[data-page="home"] .gv-section .gv-card .gv-check-list li{color:#231741}
body[data-page="home"] .gv-section .gv-card .gv-check-list i{
  color:#00c853;filter:drop-shadow(0 0 6px rgba(0,255,136,.6));
}
body[data-page="home"] .gv-section .gv-card-featured{
  background:linear-gradient(135deg,#5a1b71 0%,#881596 100%);
  color:#fff;border-color:#FFD700;
  box-shadow:0 15px 40px rgba(136,21,150,.55),0 6px 20px rgba(0,0,0,.3),0 0 35px rgba(255,215,0,.3);
}
body[data-page="home"] .gv-section .gv-card-featured h3,
body[data-page="home"] .gv-section .gv-card-featured p,
body[data-page="home"] .gv-section .gv-card-featured .gv-check-list li{color:#fff}
body[data-page="home"] .gv-section .gv-card-featured .gv-check-list i{color:#FFD700;filter:drop-shadow(0 0 8px rgba(255,215,0,.8))}
body[data-page="home"] .gv-featured-tag{
  background:linear-gradient(135deg,#FFD700,#FFA500);color:#1a0a2e;
  font-weight:900;padding:8px 22px;border:2px solid rgba(255,215,0,.9);
  box-shadow:0 8px 25px rgba(255,215,0,.7),0 0 25px rgba(255,215,0,.5);
  top:-12px;left:50%;right:auto;transform:translateX(-50%);
}
body[data-page="home"] .gv-section .gv-icon-circle{
  width:84px;height:84px;font-size:2.2rem;
  background:linear-gradient(135deg,#881596 0%,#5a1b71 100%);
  box-shadow:0 8px 25px rgba(136,21,150,.45),0 0 22px rgba(136,21,150,.3);
}
body[data-page="home"] .gv-section .gv-card-featured .gv-icon-circle{
  background:#fff;color:#5a1b71;box-shadow:0 8px 25px rgba(255,255,255,.3);
}

/* STEPS */
body[data-page="home"] .gv-section .gv-step{
  background:rgba(255,255,255,.98);color:#231741;
  border:2px solid rgba(136,21,150,.15);border-radius:24px;
  padding:44px 32px;box-shadow:0 10px 30px rgba(0,0,0,.18);
}
body[data-page="home"] .gv-section .gv-step:hover{
  transform:translateY(-12px) scale(1.02);
  box-shadow:0 25px 50px rgba(136,21,150,.3);border-color:rgba(136,21,150,.4);
}
body[data-page="home"] .gv-section .gv-step h3{color:#231741}
body[data-page="home"] .gv-section .gv-step p{color:#6c757d}
body[data-page="home"] .gv-section .gv-step-number{
  background:linear-gradient(135deg,#881596 0%,#5a1b71 100%);color:#fff;
  width:52px;height:52px;font-size:1.4rem;
  box-shadow:0 8px 22px rgba(136,21,150,.55);
}
body[data-page="home"] .gv-section .gv-step-icon{
  background:transparent;color:#5a1b71;
  font-size:2.6rem;width:auto;height:auto;
  filter:drop-shadow(0 0 12px rgba(90,27,113,.3));
}
body[data-page="home"] .gv-step-arrow{
  color:#FFD700;font-size:2rem;
  filter:drop-shadow(0 0 14px rgba(255,215,0,.85)) drop-shadow(0 0 24px rgba(255,215,0,.5));
}

/* GAME / BLOG cards keep dark — but lighten border on home */
body[data-page="home"] .gv-section .gv-game-card,
body[data-page="home"] .gv-section .gv-blog-card{
  background:rgba(255,255,255,.98);color:#231741;border:2px solid rgba(136,21,150,.15);
  box-shadow:0 8px 24px rgba(0,0,0,.15);
}
body[data-page="home"] .gv-section .gv-game-card:hover,
body[data-page="home"] .gv-section .gv-blog-card:hover{
  border-color:#FFD700;box-shadow:0 18px 36px rgba(136,21,150,.3);
}
body[data-page="home"] .gv-section .gv-game-info h3{color:#231741}
body[data-page="home"] .gv-section .gv-game-info p{color:#6c757d}
body[data-page="home"] .gv-section .gv-blog-card h3 a{color:#231741}
body[data-page="home"] .gv-section .gv-blog-card>p{color:#6c757d}
body[data-page="home"] .gv-section .gv-blog-meta,
body[data-page="home"] .gv-section .gv-blog-author{color:#6c757d}
body[data-page="home"] .gv-section .gv-blog-readmore{color:#881596}

/* CONTACT cards on home */
body[data-page="home"] .gv-section .gv-contact-card{
  background:rgba(255,255,255,.98);color:#231741;
  border:2px solid rgba(136,21,150,.15);border-radius:24px;
  box-shadow:0 10px 30px rgba(0,0,0,.18);
}
body[data-page="home"] .gv-section .gv-contact-card:hover{transform:translateY(-10px);border-color:#FFD700;color:#231741}
body[data-page="home"] .gv-section .gv-contact-card h3{color:#231741}
body[data-page="home"] .gv-section .gv-contact-card p{color:#6c757d}
body[data-page="home"] .gv-section .gv-contact-badge{background:#FFD700;color:#231741}
body[data-page="home"] .gv-section .gv-contact-card .gv-contact-btn{color:#881596;background:transparent;padding:0;margin-top:14px;font-weight:800}

/* FAQ on dark home section */
body[data-page="home"] .gv-section .gv-faq-item{
  background:rgba(255,255,255,.98);border:2px solid rgba(136,21,150,.15);border-radius:16px;
}
body[data-page="home"] .gv-section .gv-faq-item[open]{border-color:#FFD700}
body[data-page="home"] .gv-section .gv-faq-question h3{color:#231741}
body[data-page="home"] .gv-section .gv-faq-question i{color:#881596}
body[data-page="home"] .gv-section .gv-faq-answer{color:#6c757d}

/* CTA section */
body[data-page="home"] .gv-cta-section{
  background:linear-gradient(135deg,#1a0a2e 0%,#5a1b71 50%,#16213e 100%);
  position:relative;overflow:hidden;
}
body[data-page="home"] .gv-cta-section::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 50% 50%,rgba(136,21,150,.35) 0%,transparent 70%);
}
body[data-page="home"] .gv-cta-content h2{font-size:clamp(2rem,4.2vw,3rem);text-shadow:0 3px 20px rgba(0,0,0,.7)}
body[data-page="home"] .gv-cta-note{color:#FFD700;font-weight:700}

/* Logo glow on home header */
body[data-page="home"] .gv-logo-mark{
  background:linear-gradient(135deg,#a820c4 0%,#7a1a8f 100%);
  box-shadow:0 6px 20px rgba(168,32,196,.6),0 0 20px rgba(255,215,0,.25);
}

/* Mobile tweaks for the home design */
@media (max-width:640px){
  body[data-page="home"] .gv-section{padding:60px 0}
  body[data-page="home"] .gv-bonus-icon{font-size:2.2rem}
  body[data-page="home"] .gv-bonus-text h2{font-size:1.25rem}
  body[data-page="home"] .gv-bonus-text strong{font-size:1.4rem}
}

/* === Polish (gamevault777.vip parity) === */
.gv-skip-link{position:absolute;left:-9999px;top:0;background:#FFD700;color:#231741;padding:10px 16px;font-weight:800;border-radius:0 0 8px 0;z-index:1000}
.gv-skip-link:focus{left:0;outline:2px solid #fff}

/* ── Global focus-visible — keyboard navigation ring ─────────────────── */
:focus-visible{
  outline:2px solid #a820c4;
  outline-offset:3px;
  border-radius:4px;
}
/* Override for elements that have their own focus style */
.gv-btn:focus-visible,.gv-btn-primary:focus-visible,.gv-btn-secondary:focus-visible{
  outline:2px solid #FFD700;
  outline-offset:3px;
}
.gv-nav a:focus-visible{
  outline:2px solid #FFD700;
  outline-offset:2px;
}
.gv-skip-link:focus-visible{
  left:0;
  outline:2px solid #231741;
  outline-offset:0;
}
/* Suppress focus ring for mouse users (only keyboard gets it) */
:focus:not(:focus-visible){ outline:none; }

.gv-footer-business{display:grid;grid-template-columns:1.4fr 1fr;gap:40px;padding:30px 0;margin:24px 0;border-top:1px solid var(--gv-border);border-bottom:1px solid var(--gv-border)}
.gv-footer-business h3{font-size:.95rem;letter-spacing:1.2px;text-transform:uppercase;color:var(--gv-gold);margin-bottom:12px}
.gv-footer-business-info p{margin:6px 0;color:var(--gv-text-mute);font-size:.92rem}
.gv-footer-business-info p i{color:var(--gv-gold);width:18px;margin-right:6px}
.gv-footer-business-info a{color:#c8c4df;text-decoration:underline}
.gv-footer-business-info a:hover{color:#fff}
.gv-inline-list{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:6px 14px}
.gv-inline-list li{font-size:.9rem;color:var(--gv-text-mute)}
.gv-inline-list li+li::before{content:'|';color:var(--gv-border);margin-right:14px}
.gv-inline-list a{color:var(--gv-text-mute)}
.gv-inline-list a:hover{color:var(--gv-gold)}

@media (max-width:640px){
  .gv-footer-business{grid-template-columns:1fr;gap:24px}
}

/* === HERO REFINEMENT — clean & clear, parity with gamevault777.vip === */
body[data-page="home"] .gv-hero{
  background:linear-gradient(135deg,#1a0a2e 0%,#16213e 100%) !important;
  min-height:88vh;
  padding:40px 0 60px;
}
body[data-page="home"] .gv-hero-overlay{
  background-image:
    radial-gradient(ellipse at 20% 30%,rgba(168,32,196,.30) 0%,transparent 55%),
    radial-gradient(ellipse at 85% 75%,rgba(255,215,0,.10) 0%,transparent 55%) !important;
  opacity:.95;
}
body[data-page="home"] .gv-hero-content{padding:50px 20px}
body[data-page="home"] .gv-badge{
  background:rgba(255,255,255,.06) !important;
  border:1px solid rgba(255,215,0,.55) !important;
  box-shadow:0 0 18px rgba(255,215,0,.18) !important;
  padding:8px 20px;
  font-size:.82rem;
  letter-spacing:1px;
  text-transform:uppercase;
}
body[data-page="home"] .gv-badge i{color:#FFD700;font-size:.95rem}
body[data-page="home"] .gv-title{
  font-size:clamp(2.6rem,8vw,5.4rem) !important;
  text-shadow:0 4px 24px rgba(0,0,0,.55),0 0 60px rgba(168,32,196,.35) !important;
  margin-bottom:18px !important;
}
body[data-page="home"] .gv-highlight{
  color:#ffffff !important;
  background:none !important;
  -webkit-text-fill-color:#ffffff !important;
  letter-spacing:4px !important;
}
body[data-page="home"] .gv-subtitle{
  font-size:clamp(1.05rem,2.2vw,1.45rem) !important;
  color:#fff !important;
  font-weight:600 !important;
  margin-bottom:14px !important;
  text-shadow:0 2px 10px rgba(0,0,0,.5);
}
body[data-page="home"] .gv-description{
  color:rgba(255,255,255,.82) !important;
  font-weight:400 !important;
  max-width:640px;
  margin:0 auto 34px !important;
}
body[data-page="home"] .gv-cta-group{margin-bottom:36px !important;gap:16px}

/* Trust pills — softer, cleaner */
body[data-page="home"] .gv-trust-item{
  background:rgba(255,255,255,.05) !important;
  border:1px solid rgba(255,255,255,.12) !important;
  color:#fff !important;
  backdrop-filter:blur(6px);
  padding:9px 18px;
  font-size:.85rem;
  font-weight:500;
}
body[data-page="home"] .gv-trust-item i{font-size:.95rem}
body[data-page="home"] .gv-feature-badge{
  background:rgba(255,255,255,.05) !important;
  border:1px solid rgba(255,255,255,.12) !important;
  color:rgba(255,255,255,.92) !important;
  font-weight:500;
  padding:9px 18px;
  font-size:.85rem;
}
body[data-page="home"] .gv-feature-badge i{color:#FFD700 !important}

/* Trustpilot — match gamevault777.vip cleaner badge */
body[data-page="home"] .gv-trustpilot-badge{
  background:rgba(0,0,0,.45);
  border:1px solid rgba(255,255,255,.08);
}

/* === RESPONSIVE — mobile/tablet polish === */
@media (max-width:768px){
  .gv-hero{min-height:auto;padding:30px 0 40px}
  .gv-hero-content{padding:32px 16px !important}
  body[data-page="home"] .gv-hero{min-height:auto !important;padding:20px 0 40px !important}
  .gv-cta-group{flex-direction:column;width:100%;gap:12px}
  .gv-cta-group .gv-btn{width:100%;max-width:340px}
  .gv-trust-badges,.gv-features-row{gap:8px}
  .gv-trust-item,.gv-feature-badge{font-size:.78rem !important;padding:7px 14px !important}
  body[data-page="home"] .gv-highlight{letter-spacing:2px !important}
  .gv-bonus-flex{flex-direction:column;text-align:center;gap:14px}
  .gv-bonus-text h3{font-size:1.1rem !important}
  .gv-section{padding:50px 0 !important}
  .gv-footer{padding:40px 0 24px}
  .gv-footer-grid{grid-template-columns:1fr !important;gap:28px}
  .gv-footer-business{grid-template-columns:1fr !important;gap:20px;padding:24px 0}
  .gv-license-bar{flex-direction:column;align-items:flex-start;gap:12px}
  .gv-compliance-icons{justify-content:flex-start}
  .gv-compliance-row{flex-direction:column;align-items:center;text-align:center}
  .gv-footer-bottom{flex-direction:column;text-align:center}
  .gv-nav-wrap{padding:12px 16px}
  .gv-logo-text{font-size:1rem}
  .gv-steps{flex-direction:column;align-items:stretch;gap:28px}
  .gv-step{max-width:100%;width:100%;min-width:unset}
  .gv-step-arrow{transform:rotate(90deg);align-self:center}
}
@media (max-width:480px){
  .gv-badge{font-size:.72rem !important;padding:7px 14px !important}
  body[data-page="home"] .gv-title{font-size:clamp(2rem,10vw,2.8rem) !important}
  .gv-subtitle{font-size:1rem !important}
  .gv-description{font-size:.95rem !important}
  .gv-trustpilot-badge{flex-wrap:wrap;justify-content:center;gap:6px;padding:8px 14px}
  .gv-tp-text{font-size:.75rem}
  .gv-inline-list{justify-content:center}
  .gv-bonus-icon{width:46px;height:46px;font-size:1.2rem}
}

/* === Pure-white hero title (final override) === */
body[data-page="home"] .gv-title,
body[data-page="home"] .gv-title .gv-highlight{
  color:#ffffff !important;
  background:none !important;
  background-image:none !important;
  -webkit-background-clip:initial !important;
  background-clip:initial !important;
  -webkit-text-fill-color:#ffffff !important;
}

/* === EXACT PARITY with gamevault777.vip (ported 1:1) === */
/* Pure white hero title — kill all gold tinting */
body[data-page="home"] .gv-title{
  color:#ffffff !important;
  background:none !important;
  background-image:none !important;
  -webkit-background-clip:initial !important;
  background-clip:initial !important;
  -webkit-text-fill-color:#ffffff !important;
  text-shadow:0 0 40px rgba(136,21,150,.8),0 0 80px rgba(136,21,150,.5),0 4px 20px rgba(0,0,0,.8) !important;
}
body[data-page="home"] .gv-title .gv-highlight,
body[data-page="home"] .gv-highlight{
  color:#ffffff !important;
  background:none !important;
  background-image:none !important;
  -webkit-background-clip:initial !important;
  background-clip:initial !important;
  -webkit-text-fill-color:#ffffff !important;
  letter-spacing:3px !important;
  text-transform:uppercase;
  font-weight:900;
}

/* Bonus banner — ported from gamevault777.vip */
.gv-bonus-banner,
body[data-page="home"] .gv-bonus-banner{
  background:linear-gradient(135deg,rgba(35,23,65,.95) 0%,rgba(90,27,113,.92) 100%) !important;
  padding:28px 0 !important;
  position:relative;
  box-shadow:0 8px 25px rgba(0,0,0,.6);
  border-bottom:3px solid rgba(136,21,150,.4);
  overflow:hidden;
  color:#fff;
}
.gv-bonus-banner::before,
body[data-page="home"] .gv-bonus-banner::before{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(circle 4px at 20% 30%,gold,transparent),
    radial-gradient(circle 3px at 60% 70%,rgba(255,215,0,.9),transparent),
    radial-gradient(circle 3px at 50% 50%,#fff,transparent),
    radial-gradient(circle 3px at 80% 10%,gold,transparent),
    radial-gradient(circle 4px at 90% 60%,rgba(255,255,255,.9),transparent),
    radial-gradient(circle 3px at 33% 80%,gold,transparent),
    radial-gradient(circle 3px at 15% 90%,#fff,transparent),
    radial-gradient(circle 3px at 45% 20%,rgba(255,215,0,.8),transparent),
    radial-gradient(circle 4px at 70% 40%,rgba(255,255,255,.9),transparent),
    radial-gradient(circle 3px at 25% 60%,gold,transparent);
  background-size:300% 300%;background-position:0 0;
  animation:gv-sparkle 2s linear infinite;
  pointer-events:none;z-index:1;
}
@keyframes gv-sparkle{
  0%{opacity:.5;background-position:0 0;transform:scale(1)}
  50%{opacity:1;background-position:100% 100%;transform:scale(1.05)}
  100%{opacity:.5;background-position:200% 200%;transform:scale(1)}
}
.gv-bonus-flex,
body[data-page="home"] .gv-bonus-flex{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  flex-wrap:wrap !important;
  gap:20px !important;
  position:relative;z-index:2;
}
.gv-bonus-icon,
body[data-page="home"] .gv-bonus-icon{
  font-size:3.5rem !important;
  color:gold !important;
  background:none !important;
  width:auto !important;
  height:auto !important;
  border-radius:0 !important;
  filter:drop-shadow(0 0 20px rgba(255,215,0,.9)) drop-shadow(0 0 40px rgba(255,215,0,.6));
  text-shadow:0 0 30px rgba(255,215,0,.8);
  display:inline-flex;
  align-items:center;justify-content:center;
}
.gv-bonus-text,
body[data-page="home"] .gv-bonus-text{
  flex:1;min-width:250px;color:#fff !important;text-align:left;
}
.gv-bonus-text h3,
body[data-page="home"] .gv-bonus-text h3{
  font-size:2rem !important;
  margin:0 0 12px !important;
  color:#fff !important;
  text-shadow:0 2px 15px rgba(0,0,0,.8) !important;
  line-height:1.3;
}
.gv-bonus-text p,
body[data-page="home"] .gv-bonus-text p{
  color:rgba(255,255,255,.95) !important;
  font-size:1.1rem !important;
  line-height:1.6;margin:0;
}
.gv-bonus-text strong,
body[data-page="home"] .gv-bonus-text strong{
  color:gold !important;
  font-size:1.6rem;
  font-weight:900;
  text-shadow:0 0 30px gold,0 0 55px rgba(255,215,0,.7),0 3px 20px #000;
  letter-spacing:1px;
}
.gv-btn-bonus,
body[data-page="home"] .gv-btn-bonus{
  background:linear-gradient(135deg,#fff 0%,#f0f0f0 100%) !important;
  color:#5a1b71 !important;
  padding:20px 52px !important;
  border:3px solid gold !important;
  font-weight:900 !important;
  text-transform:uppercase;
  box-shadow:0 8px 30px rgba(255,215,0,.6),0 0 25px rgba(255,255,255,.8);
}
.gv-btn-bonus:hover,
body[data-page="home"] .gv-btn-bonus:hover{
  background:linear-gradient(135deg,#a820c4 0%,#7a1a8f 100%) !important;
  color:#fff !important;
  border-color:gold !important;
}

/* Bonus mobile — match 777 reference */
@media (max-width:768px){
  .gv-bonus-flex{flex-direction:column !important;text-align:center !important;gap:16px !important;padding:0 16px}
  .gv-bonus-text{text-align:center !important}
  .gv-bonus-icon{font-size:2.8rem !important;margin-bottom:0}
  .gv-bonus-text h3{font-size:1.4rem !important}
  .gv-bonus-text p{font-size:.95rem !important}
  .gv-bonus-text strong{font-size:1.3rem}
  .gv-btn-bonus{padding:16px 40px !important;font-size:.95rem !important}
}

/* === Animations + Font Awesome icon polish (parity with gamevault777.vip) === */

/* Reusable keyframes */
@keyframes gv-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes gv-bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes gv-spin-slow{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes gv-glow-pulse{0%,100%{filter:drop-shadow(0 0 6px rgba(255,215,0,.5))}50%{filter:drop-shadow(0 0 18px rgba(255,215,0,1)) drop-shadow(0 0 28px rgba(255,215,0,.7))}}
@keyframes gv-fade-up{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes gv-zoom-in{from{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}
@keyframes gv-slide-right{from{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}
@keyframes gv-tilt{0%,100%{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}
@keyframes gv-heartbeat{0%,28%,70%,100%{transform:scale(1)}14%,42%{transform:scale(1.18)}}
@keyframes gv-shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-3px)}75%{transform:translateX(3px)}}

/* Hero badge — float */
body[data-page="home"] .gv-badge{animation:gv-fade-up .8s ease both,gv-float 4s ease-in-out 1s infinite}
body[data-page="home"] .gv-badge i{animation:gv-glow-pulse 2.4s ease-in-out infinite}

/* Hero title staggered entrance */
body[data-page="home"] .gv-title{animation:gv-fade-up .9s ease both .15s}
body[data-page="home"] .gv-subtitle{animation:gv-fade-up .9s ease both .3s}
body[data-page="home"] .gv-description{animation:gv-fade-up .9s ease both .45s}
body[data-page="home"] .gv-cta-group{animation:gv-fade-up .9s ease both .6s}

/* Trust + feature pills — pop in + icon glow */
body[data-page="home"] .gv-trust-item,
body[data-page="home"] .gv-feature-badge{animation:gv-zoom-in .6s ease both;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease}
body[data-page="home"] .gv-trust-item:nth-child(1){animation-delay:.7s}
body[data-page="home"] .gv-trust-item:nth-child(2){animation-delay:.85s}
body[data-page="home"] .gv-trust-item:nth-child(3){animation-delay:1s}
body[data-page="home"] .gv-feature-badge:nth-child(1){animation-delay:1.15s}
body[data-page="home"] .gv-feature-badge:nth-child(2){animation-delay:1.3s}
body[data-page="home"] .gv-feature-badge:nth-child(3){animation-delay:1.45s}
body[data-page="home"] .gv-trust-item:hover,
body[data-page="home"] .gv-feature-badge:hover{transform:translateY(-3px) scale(1.05);border-color:rgba(255,215,0,.6) !important;box-shadow:0 8px 22px rgba(0,0,0,.35),0 0 18px rgba(255,215,0,.25)}
body[data-page="home"] .gv-trust-item:hover i,
body[data-page="home"] .gv-feature-badge:hover i{animation:gv-heartbeat 1s ease infinite}

/* Bonus icon — bouncing gift */
.gv-bonus-icon i{animation:gv-bounce 1.6s ease-in-out infinite}

/* CTA primary — fa-rocket lift on hover */
.gv-btn-primary i{transition:transform .35s cubic-bezier(.175,.885,.32,1.275)}
.gv-btn-primary:hover i.fa-rocket{transform:translate(4px,-6px) rotate(-15deg)}
.gv-btn-bonus i,.gv-btn-secondary i{transition:transform .3s ease}
.gv-btn:hover i.fa-arrow-right{transform:translateX(6px)}

/* Section card icons — circle scale + glow on hover */
body[data-page="home"] .gv-section .gv-card .gv-icon-circle,
body[data-page="home"] .gv-icon-circle{transition:transform .5s cubic-bezier(.175,.885,.32,1.275),box-shadow .5s ease}
body[data-page="home"] .gv-section .gv-card:hover .gv-icon-circle{transform:scale(1.12) rotate(-6deg);box-shadow:0 14px 38px rgba(136,21,150,.6),0 0 30px rgba(255,215,0,.45)}

/* Step numbers/icons */
body[data-page="home"] .gv-step .gv-step-number{transition:transform .4s ease,box-shadow .4s ease}
body[data-page="home"] .gv-step:hover .gv-step-number{transform:translateX(-50%) scale(1.15);box-shadow:0 12px 32px rgba(255,215,0,.55)}
body[data-page="home"] .gv-step:hover .gv-step-icon{animation:gv-tilt .6s ease-in-out 2}
body[data-page="home"] .gv-step-arrow{animation:gv-glow-pulse 2s ease-in-out infinite}

/* Contact card icons — wiggle */
body[data-page="home"] .gv-contact-card .gv-contact-icon{transition:transform .45s cubic-bezier(.175,.885,.32,1.275)}
body[data-page="home"] .gv-contact-card:hover .gv-contact-icon{transform:scale(1.12) rotate(8deg)}
body[data-page="home"] .gv-contact-card:hover .gv-contact-icon i{animation:gv-shake .5s ease infinite}

/* FAQ chevron rotation already exists — add hover wiggle */
body[data-page="home"] .gv-faq-question:hover i{animation:gv-shake .4s ease}

/* Footer social icons */
.gv-footer-social a{transition:transform .35s cubic-bezier(.175,.885,.32,1.275),background .35s ease}
.gv-footer-social a:hover{transform:translateY(-4px) scale(1.12)}
.gv-footer-social a:hover i{animation:gv-heartbeat 1s ease infinite}

/* Floating contact bubble — gentle pulse + slide-in options */
.gv-float-btn{animation:gv-float 3s ease-in-out infinite}
.gv-floating-contact.open .gv-float-btn{animation:none}
.gv-float-btn:hover{animation:gv-spin-slow 1.2s linear}
.gv-float-option{transition:transform .35s ease,box-shadow .35s ease}
.gv-float-option:hover{transform:translateX(-6px) scale(1.05)}

/* Header logo shine */
.gv-logo-mark{transition:transform .35s ease,box-shadow .35s ease}
.gv-logo:hover .gv-logo-mark{transform:rotate(-8deg) scale(1.08);box-shadow:0 8px 24px rgba(168,32,196,.7),0 0 22px rgba(255,215,0,.4)}

/* Scroll-reveal: any element with .gv-reveal */
.gv-reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s cubic-bezier(.175,.885,.32,1.275)}
.gv-reveal.is-visible{opacity:1;transform:translateY(0)}

/* Inline FA brand colors */
.gv-footer-social a:nth-child(1) i{color:#0078ff}
.gv-footer-social a:nth-child(2) i{color:#0088cc}
.gv-footer-social a:nth-child(3) i{color:#25d366}
.gv-footer-social a:nth-child(4) i{color:#FFD700}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001s !important;animation-iteration-count:1 !important;transition-duration:.001s !important}
}

/* === BONUS BANNER — premium animated parity with gamevault777.vip === */
@keyframes gv-bonus-rotate{0%,100%{transform:rotate(-8deg) scale(1)}50%{transform:rotate(8deg) scale(1.08)}}
@keyframes gv-bonus-pulse{0%,100%{transform:scale(1);filter:drop-shadow(0 0 18px rgba(255,215,0,.7)) drop-shadow(0 0 32px rgba(255,215,0,.4))}50%{transform:scale(1.12);filter:drop-shadow(0 0 28px rgba(255,215,0,1)) drop-shadow(0 0 50px rgba(255,215,0,.7))}}
@keyframes gv-text-glow{0%,100%{text-shadow:0 0 30px gold,0 0 55px rgba(255,215,0,.7),0 3px 20px #000}50%{text-shadow:0 0 40px gold,0 0 80px rgba(255,215,0,.9),0 0 100px rgba(255,215,0,.6),0 3px 20px #000}}
@keyframes gv-confetti-fall{0%{transform:translateY(-20px) rotate(0);opacity:0}10%{opacity:1}90%{opacity:1}100%{transform:translateY(120px) rotate(720deg);opacity:0}}
@keyframes gv-shine-sweep{0%{transform:translateX(-100%) skewX(-20deg)}100%{transform:translateX(250%) skewX(-20deg)}}
@keyframes gv-border-flow{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes gv-bonus-tag-blink{0%,100%{transform:scale(1);box-shadow:0 0 0 0 rgba(255,215,0,.6)}50%{transform:scale(1.05);box-shadow:0 0 0 12px rgba(255,215,0,0)}}

/* Animated gradient border on the banner */
.gv-bonus-banner{
  background:
    linear-gradient(135deg,rgba(35,23,65,.95) 0%,rgba(90,27,113,.92) 50%,rgba(35,23,65,.95) 100%) !important;
  background-size:200% 200% !important;
  animation:gv-border-flow 8s ease-in-out infinite;
  border-top:3px solid rgba(255,215,0,.4);
  border-bottom:3px solid rgba(255,215,0,.4);
  position:relative;
}

/* Top sweep highlight */
.gv-bonus-banner::after{
  content:"";position:absolute;top:0;left:0;right:0;bottom:0;
  background:linear-gradient(90deg,transparent 0%,rgba(255,215,0,.15) 50%,transparent 100%);
  pointer-events:none;
  animation:gv-shine-sweep 4s ease-in-out infinite;
  width:35%;
  z-index:2;
}

/* Confetti particles overlay */
.gv-bonus-banner .gv-bonus-confetti{
  position:absolute;inset:0;pointer-events:none;z-index:1;overflow:hidden;
}
.gv-bonus-banner .gv-bonus-confetti span{
  position:absolute;top:-20px;width:10px;height:10px;border-radius:2px;opacity:0;
  animation:gv-confetti-fall 4s linear infinite;
}
.gv-bonus-banner .gv-bonus-confetti span:nth-child(1){left:8%;background:#FFD700;animation-delay:0s;animation-duration:4.5s}
.gv-bonus-banner .gv-bonus-confetti span:nth-child(2){left:18%;background:#fff;animation-delay:.6s;animation-duration:5s;width:6px;height:6px;border-radius:50%}
.gv-bonus-banner .gv-bonus-confetti span:nth-child(3){left:28%;background:#a820c4;animation-delay:1.2s;animation-duration:4s}
.gv-bonus-banner .gv-bonus-confetti span:nth-child(4){left:38%;background:#FFD700;animation-delay:1.8s;animation-duration:5.5s;width:8px;height:8px;border-radius:50%}
.gv-bonus-banner .gv-bonus-confetti span:nth-child(5){left:48%;background:#c428e0;animation-delay:.3s;animation-duration:4.2s}
.gv-bonus-banner .gv-bonus-confetti span:nth-child(6){left:58%;background:#fff;animation-delay:2.4s;animation-duration:4.8s;width:6px;height:6px}
.gv-bonus-banner .gv-bonus-confetti span:nth-child(7){left:68%;background:#FFD700;animation-delay:1.5s;animation-duration:5s;border-radius:50%}
.gv-bonus-banner .gv-bonus-confetti span:nth-child(8){left:78%;background:#a820c4;animation-delay:.9s;animation-duration:4.6s}
.gv-bonus-banner .gv-bonus-confetti span:nth-child(9){left:88%;background:#FFD700;animation-delay:2.1s;animation-duration:5.2s;width:8px;height:8px}
.gv-bonus-banner .gv-bonus-confetti span:nth-child(10){left:95%;background:#fff;animation-delay:.4s;animation-duration:4.4s;border-radius:50%}

/* Bonus icon — gift wrapped in glowing rotating ring */
.gv-bonus-icon{
  position:relative !important;
  width:80px !important;height:80px !important;
  border-radius:50% !important;
  background:radial-gradient(circle,rgba(255,215,0,.25),transparent 70%) !important;
  display:grid !important;place-items:center;
  flex-shrink:0;
}
.gv-bonus-icon::before{
  content:"";position:absolute;inset:-4px;
  border-radius:50%;
  background:conic-gradient(from 0deg,#FFD700,#fff,#a820c4,#FFD700);
  animation:gv-spin-slow 3s linear infinite;
  -webkit-mask:radial-gradient(circle,transparent 60%,#000 62%);
  mask:radial-gradient(circle,transparent 60%,#000 62%);
}
.gv-bonus-icon i{
  font-size:2.2rem !important;color:gold !important;
  animation:gv-bonus-pulse 1.4s ease-in-out infinite !important;
  position:relative;z-index:2;
}

/* Heading — animated gold text-shadow on the strong */
.gv-bonus-text strong{
  animation:gv-text-glow 2s ease-in-out infinite !important;
  background:linear-gradient(135deg,#FFD700 0%,#fff7c2 50%,#FFD700 100%);
  background-size:200% 200%;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  animation:gv-text-glow 2s ease-in-out infinite,gv-border-flow 3s ease-in-out infinite !important;
}

/* Limited Time Offer pill on heading */
.gv-bonus-text h3{
  display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap;
}
.gv-bonus-text h3::before{
  content:"\f017"; /* fa-clock */
  font-family:"Font Awesome 6 Free";font-weight:900;
  background:linear-gradient(135deg,#FFD700,#ff8c00);
  color:#231741;
  padding:4px 12px;border-radius:50px;font-size:.7rem;
  text-shadow:none !important;
  animation:gv-bonus-tag-blink 1.6s ease-in-out infinite;
  box-shadow:0 4px 12px rgba(255,140,0,.4);
}

/* Claim button — gold border that breathes + arrow nudge */
.gv-btn-bonus{
  position:relative;
  overflow:hidden;
  animation:gv-bonus-tag-blink 2.4s ease-in-out infinite;
}
.gv-btn-bonus::after{
  content:"\f061"; /* fa-arrow-right */
  font-family:"Font Awesome 6 Free";font-weight:900;
  margin-left:8px;
  display:inline-block;
  transition:transform .35s ease;
}
.gv-btn-bonus:hover::after{transform:translateX(6px)}
.gv-btn-bonus::before{
  content:"";position:absolute;top:-50%;left:-50%;width:60%;height:200%;
  background:linear-gradient(45deg,transparent,rgba(255,215,0,.6),transparent);
  animation:gv-shine-sweep 2.8s ease-in-out infinite;
  pointer-events:none;
}

/* Mobile tweaks */
@media (max-width:768px){
  .gv-bonus-icon{width:64px !important;height:64px !important}
  .gv-bonus-icon i{font-size:1.8rem !important}
  .gv-bonus-text h3::before{font-size:.65rem;padding:3px 10px}
  .gv-bonus-banner::after{display:none}
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  .gv-bonus-banner,.gv-bonus-banner::after,.gv-bonus-banner::before,
  .gv-bonus-confetti span,.gv-bonus-icon::before,.gv-bonus-icon i,
  .gv-bonus-text strong,.gv-bonus-text h3::before,.gv-btn-bonus,.gv-btn-bonus::before{animation:none !important}
}

/* Real brand logo image (replaces CSS GV badge) */
.gv-logo-img{background:transparent !important;box-shadow:0 6px 20px rgba(168,32,196,.45);padding:2px;object-fit:contain;display:block}
.gv-logo:hover .gv-logo-img{box-shadow:0 8px 24px rgba(168,32,196,.7),0 0 22px rgba(255,215,0,.45)}

/* === COMPREHENSIVE RESPONSIVE POLISH =====================================
   Containers, buttons, grids, overflow — covers all breakpoints.
   ====================================================================== */

/* Touch targets + no text wrap inside buttons */
.gv-btn{min-height:44px;touch-action:manipulation;white-space:nowrap}
.gv-nav a{display:inline-flex;align-items:center}
.gv-burger{min-height:44px;min-width:44px}
.gv-float-btn{min-height:44px;min-width:44px}

/* Long word/overflow prevention everywhere */
.gv-blog-card h3,.gv-game-info h3,.gv-card h3,
.gv-step h3,.gv-contact-card h3,.gv-faq-question h3{word-break:break-word}
.gv-faq-answer p,.gv-card p,.gv-prose p,.gv-footer-about{overflow-wrap:break-word}

/* CTA group stacking (hero single button is fine, but defensive) */
@media (max-width:640px){
  .gv-cta-group{align-items:center}
}

/* Steps — already stacked at 768px; keep arrows readable */
@media (max-width:640px){
  .gv-step{padding:30px 18px;margin-top:22px}
  .gv-steps{gap:22px}
}

/* Game grid — 2 columns on small/medium mobiles */
@media (max-width:520px){
  .gv-grid-4{grid-template-columns:repeat(2,1fr);gap:12px}
  .gv-game-thumb{font-size:2rem}
  .gv-game-info{padding:12px}
  .gv-game-info h3{font-size:.9rem}
  .gv-game-info p{font-size:.76rem}
}

/* Blog & service grids — single column on small phones */
@media (max-width:440px){
  .gv-grid-3{grid-template-columns:1fr}
}

/* Footer social + inline list wrapping */
@media (max-width:480px){
  .gv-footer-social{flex-wrap:wrap;gap:8px}
  .gv-inline-list{gap:4px 8px}
  .gv-vip-grid{grid-template-columns:1fr}
}

/* Modal on very small screens */
@media (max-width:480px){
  .gv-modal{padding:14px}
  .gv-modal-content{padding:22px 16px}
  .gv-modal-contact-options .gv-contact-btn{padding:12px 14px;font-size:.88rem}
}

/* Very small phones (360px) — tighten all padding */
@media (max-width:360px){
  .gv-container{padding:0 12px}
  .gv-btn-large{padding:14px 22px;font-size:.9rem}
  .gv-step{padding:30px 14px}
  .gv-card{padding:22px 14px}
  .gv-faq-question{padding:14px 14px}
  .gv-faq-answer{padding:0 14px 14px}
  .gv-contact-card{padding:24px 14px}
  .gv-nav-wrap{padding:10px 12px}
  .gv-logo-text{font-size:.9rem}
}

/* Floating contact — ensure it doesn't clip on narrow screens */
@media (max-width:360px){
  .gv-floating-contact{right:12px;bottom:12px}
  .gv-float-option{font-size:.78rem;padding:8px 12px}
}

/* Tablet nav — prevent logo + nav from wrapping weirdly 769–1024px */
@media (max-width:1024px) and (min-width:769px){
  .gv-nav-wrap{flex-wrap:nowrap}
  .gv-logo-text{white-space:nowrap}
}

/* =====================================================================
   MOBILE GAMING FEEL — header, footer, homepage
   ===================================================================== */

/* ── Desktop: hide nav icon circles, keep text only ── */
@media (min-width:1025px){
  .gv-nav-icon{display:none !important}
  .gv-nav a::after{display:none !important}
}

/* ── Burger → X morph ── */
.gv-burger span{transition:transform .32s cubic-bezier(.175,.885,.32,1.275),opacity .22s ease,width .22s ease}
.gv-burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.gv-burger.is-open span:nth-child(2){opacity:0;transform:scaleX(0)}
.gv-burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── Mobile nav drawer — gaming skin ── */
@media (max-width:1024px){
  .gv-nav a{
    padding:13px 22px;
    border-radius:0;
    border-bottom:1px solid rgba(255,255,255,.035);
    font-size:1rem;
    font-weight:600;
    display:flex;
    align-items:center;
    gap:12px;
    color:var(--gv-text);
    position:relative;
    transition:background .2s,color .2s,border-left .2s;
  }
  .gv-nav a:hover{
    background:rgba(168,32,196,.12);
    color:#fff;
  }
  .gv-nav a.active{
    background:linear-gradient(90deg,rgba(168,32,196,.28) 0%,transparent 100%);
    border-left:4px solid var(--gv-gold) !important;
    color:#fff;
    border-radius:0;
  }
  /* Chevron arrow on right */
  .gv-nav a::after{
    content:'\f054';
    font-family:'Font Awesome 6 Free';
    font-weight:900;
    font-size:.6rem;
    margin-left:auto;
    color:rgba(255,255,255,.25);
    transition:transform .2s,color .2s;
  }
  .gv-nav a:hover::after,.gv-nav a.active::after{
    color:var(--gv-gold);
    transform:translateX(3px);
  }
  /* Icon badge circle */
  .gv-nav-icon{
    width:30px;height:30px;
    border-radius:9px;
    background:linear-gradient(135deg,rgba(168,32,196,.35),rgba(90,27,113,.55));
    border:1px solid rgba(168,32,196,.4);
    display:grid;place-items:center;
    font-size:.78rem;
    color:var(--gv-gold);
    flex-shrink:0;
    box-shadow:0 2px 8px rgba(168,32,196,.3);
    transition:background .2s,box-shadow .2s;
  }
  .gv-nav a:hover .gv-nav-icon,.gv-nav a.active .gv-nav-icon{
    background:linear-gradient(135deg,#a820c4,#5a1b71);
    box-shadow:0 4px 14px rgba(168,32,196,.55),0 0 12px rgba(255,215,0,.2);
  }
  .gv-nav a.active .gv-nav-icon{
    background:linear-gradient(135deg,#FFD700,#ff8c00);
    color:#1a0a2e;
  }
  /* "Get Started" — sizing */
  .gv-nav-actions .gv-btn-sm{font-size:.82rem;padding:9px 14px;letter-spacing:.2px}
}

/* ── Header: logo sizing — very small screens ── */
@media (max-width:360px){
  .gv-logo-img{width:32px !important;height:32px !important}
  .gv-logo-text{font-size:.82rem}
  .gv-btn-label{display:none}
  .gv-nav-actions .gv-btn-sm{padding:9px 12px}
}

/* ── Homepage hero pills — wrap on narrow mobile (hero has overflow:hidden so scroll can't work) ── */
@media (max-width:560px){
  .gv-trust-badges,.gv-features-row{
    flex-wrap:wrap;
    justify-content:center;
    gap:6px;
    -webkit-mask-image:none;
    mask-image:none;
  }
  .gv-trust-item,.gv-feature-badge{
    flex-shrink:1;
    font-size:.68rem !important;
    padding:5px 10px !important;
    white-space:nowrap;
  }
}

/* ── Homepage hero CTA — full width below 480 ── */
@media (max-width:480px){
  .gv-cta-group{flex-direction:column;align-items:stretch;width:100%;padding:0 16px;box-sizing:border-box}
  .gv-cta-group .gv-btn{width:100%;justify-content:center}
}

/* ── Section headers on mobile ── */
@media (max-width:640px){
  .gv-section-header{padding:0 4px;margin-bottom:32px}
  .gv-section-header h2{font-size:clamp(1.5rem,6vw,2rem)}
  .gv-section-header p{font-size:.95rem}
}

/* ── Footer brand — center-align on mobile ── */
@media (max-width:768px){
  .gv-footer-brand{text-align:center}
  .gv-footer-brand .gv-logo{justify-content:center}
  .gv-footer-social{justify-content:center}
  .gv-footer-social a{width:42px;height:42px;font-size:1.05rem}
}

/* ── Footer bottom — center + email word-break ── */
@media (max-width:640px){
  .gv-footer-bottom{flex-direction:column;align-items:center;text-align:center;gap:6px}
  .gv-footer-bottom a{word-break:break-all}
  .gv-footer-business-info a{word-break:break-all}
  .gv-compliance-row p a{word-break:break-all}
}

/* ── Footer compliance row ── */
@media (max-width:560px){
  .gv-compliance-row{flex-direction:column;align-items:center;text-align:center;gap:14px}
  .gv-age-badge{margin:0 auto}
}

/* ── Bonus banner on very small mobile ── */
@media (max-width:380px){
  .gv-btn-bonus{padding:14px 24px !important;font-size:.88rem !important;width:100%}
  .gv-bonus-banner .gv-container{padding:0 14px}
}

/* ── Game filter buttons wrap nicely ── */
@media (max-width:480px){
  .gv-filter-bar button{padding:8px 14px;font-size:.82rem}
}

/* ── Header glow line at bottom (gaming feel) ── */
.gv-header::after{
  content:'';
  display:block;
  height:2px;
  background:linear-gradient(90deg,transparent 0%,rgba(168,32,196,.6) 20%,rgba(255,215,0,.4) 50%,rgba(168,32,196,.6) 80%,transparent 100%);
  opacity:.8;
}

/* =====================================================================
   FULL SECTIONS MOBILE AUDIT — all pages
   ===================================================================== */

/* ── Logo img scales with clamp (CSS takes over from HTML width attr) ── */
.gv-logo-img{width:clamp(34px,6vw,42px) !important;height:clamp(34px,6vw,42px) !important}

/* ── nav-wrap: tighter on medium screens ── */
@media (max-width:900px){
  .gv-nav-wrap{padding:10px 16px;gap:10px}
}

/* ── Hero section ── */
@media (max-width:480px){
  .gv-hero-content{padding:28px 14px !important}
  body[data-page="home"] .gv-hero{padding:16px 0 36px !important}
  .gv-badge{font-size:.72rem !important;padding:7px 14px !important;margin-bottom:16px}
  body[data-page="home"] .gv-title{font-size:clamp(1.9rem,9.5vw,2.8rem) !important;margin-bottom:12px !important}
  .gv-subtitle{font-size:.98rem !important}
  .gv-description{font-size:.9rem !important;margin-bottom:22px !important;padding:0 4px}
}

/* ── Service / Why-choose cards (grid-4, grid-3) ── */
@media (max-width:480px){
  .gv-card{padding:22px 16px}
  .gv-icon-circle{width:58px;height:58px;font-size:1.35rem}
  .gv-card h3{font-size:1.1rem}
  .gv-check-list li{font-size:.85rem}
}

/* ── How-it-works steps ── */
@media (max-width:640px){
  .gv-steps{flex-direction:column;align-items:stretch;gap:28px}
  .gv-step{max-width:100%;min-width:unset;padding:38px 20px 24px}
  .gv-step-arrow{align-self:center;transform:rotate(90deg);margin:0}
  .gv-step-icon{width:52px;height:52px;font-size:1.25rem}
}

/* ── Games grid — 2 col on mobile, 1 col on very small ── */
@media (max-width:480px){
  .gv-game-card{border-radius:12px}
  .gv-game-rtp{font-size:.72rem;padding:3px 8px}
  .gv-game-flag{font-size:.72rem;padding:3px 8px}
}
@media (max-width:360px){
  .gv-grid-4{grid-template-columns:1fr}
}

/* ── Blog grid ── */
@media (max-width:480px){
  .gv-blog-card h3{font-size:1rem;padding:4px 14px}
  .gv-blog-meta{padding:10px 14px 0;font-size:.72rem}
  .gv-blog-card>p{padding:0 14px;font-size:.88rem}
  .gv-blog-readmore{padding:10px 14px;font-size:.88rem}
}

/* ── Contact cards ── */
@media (max-width:480px){
  .gv-contact-card{padding:26px 16px}
  .gv-contact-icon{width:58px;height:58px;font-size:1.5rem}
}

/* ── FAQ ── */
@media (max-width:480px){
  .gv-faq-question{padding:14px 16px}
  .gv-faq-question h3{font-size:.95rem}
  .gv-faq-answer{padding:0 16px 14px;font-size:.9rem}
}

/* ── CTA section ── */
@media (max-width:480px){
  .gv-cta-section{padding:54px 0}
  .gv-cta-content h2{font-size:clamp(1.4rem,6vw,1.9rem)}
  .gv-cta-content p{font-size:.9rem;padding:0 8px}
}

/* ── Page hero (inner pages: games, blog, about, etc.) ── */
@media (max-width:640px){
  .gv-page-hero{padding:54px 16px 36px}
  .gv-page-hero h1{font-size:clamp(1.6rem,7vw,2.4rem);margin-bottom:10px}
  .gv-page-hero p{font-size:.92rem}
}

/* ── Prose (legal / blog / about) ── */
@media (max-width:640px){
  .gv-prose{padding:0 4px}
  .gv-prose h2{font-size:1.3rem;margin:24px 0 10px}
  .gv-prose p,.gv-prose li{font-size:.95rem}
  .gv-callout{padding:14px 16px;font-size:.92rem}
}

/* ── Promotions / VIP pages ── */
@media (max-width:480px){
  .gv-promo-card{padding:20px 16px}
  .gv-promo-card h3{font-size:1.15rem}
  .gv-vip-tier{padding:20px 14px}
}

/* ── Footer business section ── */
@media (max-width:480px){
  .gv-footer-business-info p{font-size:.84rem}
  .gv-footer-col h3{font-size:.85rem}
  .gv-footer-col a{font-size:.84rem}
  .gv-footer-about{font-size:.84rem}
}

/* ── Bonus banner — ensure full-width stack on 430px iPhone ── */
@media (max-width:480px){
  .gv-bonus-flex{padding:0 16px !important;gap:14px !important}
  .gv-bonus-text h3{font-size:1.05rem !important}
  .gv-bonus-text strong{font-size:1.2rem}
  .gv-btn-bonus{width:100%;text-align:center;padding:16px 20px !important}
}

/* ── Filter bar (games page) ── */
@media (max-width:560px){
  .gv-filter-bar{gap:6px;padding:0 4px}
  .gv-filter-bar button{font-size:.78rem;padding:8px 12px}
}

/* ── Floating contact bubble — don't obscure content on small screens ── */
@media (max-width:480px){
  .gv-floating-contact{bottom:20px !important;right:16px !important}
  .gv-float-btn{width:48px;height:48px;font-size:1.1rem}
  .gv-float-option{font-size:.78rem !important;padding:9px 13px !important}
}

/* =====================================================================
   MOBILE — Services 1-per-row + Bonus banner redesign
   ===================================================================== */

/* ── Services "What We Provide" — always 1 per row on mobile ── */
@media (max-width:768px){
  #services .gv-grid-4{
    grid-template-columns:1fr !important;
    gap:16px;
  }
}

/* ── Bonus banner — compact single-row banner on mobile ── */
@media (max-width:768px){
  /* Tight banner padding — fits like a notification strip */
  .gv-bonus-banner,
  body[data-page="home"] .gv-bonus-banner{
    padding:14px 0 !important;
  }
  /* Row layout: icon | text | button — all inline */
  .gv-container.gv-bonus-flex,
  body[data-page="home"] .gv-bonus-flex{
    flex-direction:row !important;
    align-items:center !important;
    flex-wrap:nowrap !important;
    justify-content:space-between !important;
    gap:10px !important;
    padding:0 16px !important;
    text-align:left !important;
  }
  /* Small icon — doesn't overpower text */
  .gv-bonus-icon,
  body[data-page="home"] .gv-bonus-icon{
    font-size:1.6rem !important;
    flex-shrink:0;
    margin:0 !important;
  }
  /* Text block fills remaining space */
  .gv-bonus-text,
  body[data-page="home"] .gv-bonus-text{
    flex:1 !important;
    min-width:0 !important;
    text-align:left !important;
  }
  /* Headline — single line, tight */
  .gv-bonus-text h3,
  body[data-page="home"] .gv-bonus-text h3{
    font-size:clamp(.85rem,3.8vw,1rem) !important;
    line-height:1.2 !important;
    margin:0 0 2px !important;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  /* Sub-text / claim line */
  .gv-bonus-text p,
  body[data-page="home"] .gv-bonus-text p{
    font-size:clamp(.72rem,3vw,.85rem) !important;
    margin:0 !important;
    line-height:1.3;
  }
  .gv-bonus-text strong,
  body[data-page="home"] .gv-bonus-text strong{
    font-size:inherit !important;
    display:inline !important;
    margin:0 !important;
  }
  /* Compact pill button — right-aligned */
  .gv-btn-bonus,
  body[data-page="home"] .gv-btn-bonus{
    width:auto !important;
    max-width:none !important;
    padding:10px 14px !important;
    font-size:.72rem !important;
    white-space:nowrap;
    flex-shrink:0;
    margin:0 !important;
    letter-spacing:.5px;
  }
}

/* Very small phones (≤400px) — shrink further */
@media (max-width:400px){
  .gv-bonus-icon,
  body[data-page="home"] .gv-bonus-icon{ font-size:1.3rem !important }
  .gv-bonus-text h3,
  body[data-page="home"] .gv-bonus-text h3{ font-size:.8rem !important }
  .gv-bonus-text p,
  body[data-page="home"] .gv-bonus-text p{ font-size:.68rem !important }
  .gv-btn-bonus,
  body[data-page="home"] .gv-btn-bonus{ padding:9px 11px !important;font-size:.68rem !important }
}

/* ── Bonus banner mobile — 2-line: icon | Welcome Bonus! / 100% Bonus... [CLAIM] ── */
/* Hide verbose prefix on mobile */
@media (max-width:768px){
  .gv-mob-hide{ display:none !important }
}

@media (max-width:768px){
  /* Row layout: icon | text-block | button */
  .gv-bonus-banner,
  body[data-page="home"] .gv-bonus-banner{
    padding:12px 0 !important;
  }
  .gv-container.gv-bonus-flex,
  body[data-page="home"] .gv-bonus-flex{
    flex-direction:row !important;
    align-items:center !important;
    flex-wrap:nowrap !important;
    justify-content:space-between !important;
    gap:8px !important;
    padding:0 14px !important;
    text-align:left !important;
  }
  /* Icon — compact left anchor */
  .gv-bonus-icon,
  body[data-page="home"] .gv-bonus-icon{
    font-size:1.5rem !important;
    flex-shrink:0 !important;
    margin:0 !important;
  }
  /* Text block — 2 stacked lines */
  .gv-bonus-text,
  body[data-page="home"] .gv-bonus-text{
    flex:1 !important;
    min-width:0 !important;
    text-align:left !important;
    display:flex !important;
    flex-direction:column !important;
    gap:1px !important;
  }
  /* Line 1 — "Welcome Bonus!" */
  .gv-bonus-text h3,
  body[data-page="home"] .gv-bonus-text h3{
    font-size:clamp(.88rem,3.8vw,1rem) !important;
    line-height:1.2 !important;
    margin:0 !important;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  /* Line 2 — "100% Bonus on your first deposit" — SHOW it */
  .gv-bonus-text p,
  body[data-page="home"] .gv-bonus-text p{
    display:block !important;
    font-size:clamp(.7rem,2.9vw,.82rem) !important;
    margin:0 !important;
    line-height:1.3 !important;
    color:rgba(255,255,255,.9) !important;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .gv-bonus-text strong,
  body[data-page="home"] .gv-bonus-text strong{
    font-size:inherit !important;
    display:inline !important;
    color:gold !important;
  }
  /* Button — compact pill on right */
  .gv-btn-bonus,
  body[data-page="home"] .gv-btn-bonus{
    width:auto !important;
    max-width:none !important;
    flex-shrink:0 !important;
    padding:10px 12px !important;
    font-size:.68rem !important;
    white-space:nowrap !important;
    letter-spacing:.4px;
    margin:0 !important;
  }
}

/* ≤400px — tighten further */
@media (max-width:400px){
  .gv-bonus-icon,
  body[data-page="home"] .gv-bonus-icon{ font-size:1.2rem !important }
  .gv-bonus-text h3,
  body[data-page="home"] .gv-bonus-text h3{ font-size:.8rem !important }
  .gv-bonus-text p,
  body[data-page="home"] .gv-bonus-text p{ font-size:.65rem !important }
  .gv-btn-bonus,
  body[data-page="home"] .gv-btn-bonus{ padding:9px 10px !important;font-size:.62rem !important }
}

/* ─── Age Verification Gate ─────────────────────────────────────────── */
.gv-age-gate{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  background:rgba(10,4,24,.97);
  backdrop-filter:blur(8px);
  padding:20px;
  overflow-y:auto;
}
.gv-age-gate.gv-age-gate--hidden{display:none}
.gv-age-gate-box{
  background:linear-gradient(145deg,#1e0d38,#2d1254);
  border:1px solid rgba(255,215,0,.35);
  border-radius:24px;
  max-width:480px;width:100%;
  padding:40px 32px 32px;
  text-align:center;
  box-shadow:0 0 60px rgba(168,32,196,.4),0 0 120px rgba(0,0,0,.6);
  animation:gv-fadeUp .4s ease;
}
.gv-age-gate-badge{
  display:inline-flex;align-items:center;justify-content:center;
  width:80px;height:80px;border-radius:50%;
  background:#dc143c;
  color:#fff;font-size:1.6rem;font-weight:900;
  margin:0 auto 20px;
  box-shadow:0 0 24px rgba(220,20,60,.5);
}
.gv-age-gate-title{
  font-size:clamp(1.4rem,4vw,1.9rem);font-weight:800;
  color:#fff;margin:0 0 14px;
}
.gv-age-gate-text{
  font-size:1rem;color:rgba(255,255,255,.9);
  line-height:1.7;margin:0 0 12px;
}
.gv-age-gate-sub{
  font-size:.82rem;color:rgba(255,255,255,.55);
  line-height:1.6;margin:0 0 28px;
}
.gv-age-gate-link{color:var(--gv-gold);text-decoration:underline}
.gv-age-gate-actions{
  display:flex;flex-direction:column;gap:12px;margin-bottom:20px;
}
.gv-age-btn-yes{
  background:linear-gradient(135deg,#5a1b71,#a820c4);
  border:2px solid var(--gv-gold);
  font-size:1rem;padding:14px 20px;
}
.gv-age-btn-yes:hover{background:linear-gradient(135deg,#6e2288,#c428e0)}
.gv-age-btn-no{
  background:transparent;
  border:1px solid rgba(255,255,255,.2);
  color:rgba(255,255,255,.55);
  font-size:.88rem;padding:10px 20px;
}
.gv-age-btn-no:hover{border-color:rgba(255,255,255,.4);color:rgba(255,255,255,.8)}
.gv-age-gate-disclaimer{
  font-size:.75rem;color:rgba(255,255,255,.4);
  margin:0;display:flex;align-items:center;justify-content:center;gap:6px;
}
@media (max-width:480px){
  .gv-age-gate-box{padding:28px 18px 24px}
  .gv-age-gate-badge{width:64px;height:64px;font-size:1.3rem}
}

/* ─── CSP inline-style replacements (v11) ───────────────────────────── */
.gv-ic-green{ color:#00ff88 }
.gv-ic-blue { color:#2596be }
.gv-ic-gold { color:#FFD700 }
.gv-thumb-placeholder{ background:linear-gradient(135deg,#5a1b71,#231741) }

/* ─── Mobile first-view: show hero + bonus banner together (v12) ─────── */
@media (max-width:768px){
  /* Hide trust badges & features row — they push bonus banner off-screen */
  .gv-trust-badges,
  .gv-features-row{
    display:none !important;
  }

  /* Tighten hero so bonus banner fits in first viewport */
  body[data-page="home"] .gv-hero{
    min-height:0 !important;
    padding:16px 0 24px !important;
  }
  .gv-hero-content{
    padding:24px 16px 20px !important;
  }
  body[data-page="home"] .gv-description{
    margin-bottom:20px !important;
  }
  .gv-cta-group{
    margin-bottom:20px !important;
  }

  /* Bonus banner — compact and sticky at bottom of first view */
  .gv-bonus-banner,
  body[data-page="home"] .gv-bonus-banner{
    padding:14px 0 !important;
  }
  .gv-bonus-flex{
    gap:10px !important;
  }
}

/* ═══════════════════════════════════════════════════════════════════════
   Blog Rich Content Engine — v15
   ═══════════════════════════════════════════════════════════════════════ */

/* ── Reading Progress Bar ──────────────────────────────────────────── */
.gv-read-progress{
  position:fixed;top:0;left:0;height:3px;width:0%;
  background:linear-gradient(90deg,var(--gv-purple),var(--gv-gold));
  z-index:10000;transition:width .1s linear;
  border-radius:0 2px 2px 0;
}

/* ── Article Layout ────────────────────────────────────────────────── */
.gv-article-layout{ max-width:820px; margin:0 auto; }
/* gv-article-main width handled by grid; old width:100% removed to prevent grid conflicts */

/* ── Category + Tag Chips row under breadcrumb ─────────────────────── */
.gv-article-cats{ display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px; }

/* ── Tag Chips ─────────────────────────────────────────────────────── */
.gv-tag-chip{
  display:inline-block;
  font-size:.72rem;font-weight:600;letter-spacing:.03em;
  padding:3px 10px;border-radius:20px;
  background:rgba(168,32,196,.15);border:1px solid rgba(168,32,196,.35);
  color:var(--gv-purple-light,#d46ae0);
  white-space:nowrap;
}
.gv-card-tags{ display:flex;flex-wrap:wrap;gap:4px;margin:4px 0 8px; }

/* ── Table of Contents ──────────────────────────────────────────────── */
.gv-toc{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);
  border-left:3px solid var(--gv-purple);
  border-radius:8px;padding:20px 24px;margin:28px 0;
}
.gv-toc-title{
  font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--gv-gold);margin:0 0 12px;
}
.gv-toc-list{ margin:0;padding-left:20px; }
.gv-toc-item{ margin:6px 0;font-size:.92rem; }
.gv-toc-item a{ color:rgba(255,255,255,.8);text-decoration:none; }
.gv-toc-item a:hover{ color:var(--gv-gold);text-decoration:underline; }
.gv-toc-h3{ padding-left:14px;font-size:.85rem; }

/* ── Prose Rich Text ────────────────────────────────────────────────── */
.gv-prose{ line-height:1.8;color:rgba(255,255,255,.88); }
.gv-prose h2{ font-size:1.5rem;margin:2rem 0 .75rem;color:#fff; }
.gv-prose h3{ font-size:1.18rem;margin:1.5rem 0 .5rem;color:rgba(255,255,255,.95); }
.gv-prose p{ margin:0 0 1.2rem; }
.gv-lead{
  font-size:1.15rem;font-weight:500;line-height:1.7;
  color:rgba(255,255,255,.92);border-left:3px solid var(--gv-gold);
  padding-left:16px;margin-bottom:2rem;
}

/* ── Callout Boxes ──────────────────────────────────────────────────── */
.gv-callout{
  display:flex;align-items:flex-start;gap:12px;
  padding:16px 20px;border-radius:10px;margin:1.5rem 0;font-size:.95rem;
}
.gv-callout-icon{ font-size:1.2rem;flex-shrink:0;margin-top:1px; }
.gv-callout-tip{
  background:rgba(0,200,100,.1);border:1px solid rgba(0,200,100,.3);
  color:rgba(255,255,255,.9);
}
.gv-callout-warning{
  background:rgba(255,160,0,.1);border:1px solid rgba(255,160,0,.35);
  color:rgba(255,255,255,.9);
}
.gv-callout-cta{
  display:block;
  background:linear-gradient(135deg,rgba(90,27,113,.6),rgba(35,23,65,.8));
  border:1px solid rgba(255,215,0,.25);border-radius:12px;
  padding:24px 28px;text-align:center;margin:2.5rem 0 1.5rem;
}
.gv-callout-cta h3{ margin:0 0 8px;font-size:1.2rem;color:#fff; }
.gv-callout-cta p{ margin:0 0 16px;color:rgba(255,255,255,.75);font-size:.95rem; }

/* ── Prose Lists ────────────────────────────────────────────────────── */
.gv-prose-ul,.gv-prose-ol{ padding-left:24px;margin:0 0 1.2rem; }
.gv-prose-ul li,.gv-prose-ol li{ margin-bottom:.45rem;line-height:1.65; }
.gv-prose-ul li::marker{ color:var(--gv-gold); }

/* ── How-To Steps List ──────────────────────────────────────────────── */
.gv-steps-list{ list-style:none;padding:0;margin:1.5rem 0;counter-reset:gv-step; }
.gv-step-item{ display:flex;gap:1rem;align-items:flex-start;padding:1rem 1.2rem;margin-bottom:.75rem;background:rgba(255,255,255,.04);border-left:3px solid var(--gv-gold);border-radius:0 8px 8px 0;counter-increment:gv-step; }
.gv-step-item::before{ content:counter(gv-step);min-width:28px;height:28px;border-radius:50%;background:var(--gv-gold);color:#1a0a2e;font-weight:700;font-size:.85rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.1rem; }
.gv-step-item>div,.gv-step-item>div p{ margin:0; }
.gv-step-title{ display:block;font-weight:700;color:#fff;margin-bottom:.3rem; }
.gv-step-item p{ color:rgba(255,255,255,.75);margin:.25rem 0 0;line-height:1.6;font-size:.95rem; }

/* ── Data Tables ────────────────────────────────────────────────────── */
.gv-table-wrap{ overflow-x:auto;margin:1.5rem 0;border-radius:10px;border:1px solid rgba(255,255,255,.1); }
.gv-prose-table{ width:100%;border-collapse:collapse;font-size:.9rem; }
.gv-prose-table th{
  background:rgba(90,27,113,.5);color:var(--gv-gold);
  padding:10px 14px;text-align:left;font-weight:700;white-space:nowrap;
}
.gv-prose-table td{ padding:9px 14px;border-top:1px solid rgba(255,255,255,.07);color:rgba(255,255,255,.85); }
.gv-prose-table tr:hover td{ background:rgba(255,255,255,.04); }

/* ── FAQ Block (details/summary) ────────────────────────────────────── */
.gv-faq-block{ margin:1.5rem 0; }
.gv-faq-item{
  border:1px solid rgba(255,255,255,.1);border-radius:8px;
  margin-bottom:8px;overflow:hidden;
}
.gv-faq-q{
  padding:14px 18px;cursor:pointer;font-weight:600;font-size:.95rem;
  list-style:none;display:flex;justify-content:space-between;align-items:center;
  color:rgba(255,255,255,.9);
}
.gv-faq-q::-webkit-details-marker{ display:none; }
.gv-faq-q::after{ content:'+';font-size:1.2rem;color:var(--gv-gold);margin-left:10px;flex-shrink:0; }
.gv-faq-item[open] .gv-faq-q::after{ content:'−'; }
.gv-faq-item[open]{ border-color:rgba(168,32,196,.4);background:rgba(255,255,255,.03); }
.gv-faq-a{ padding:0 18px 14px; }
.gv-faq-a p{ margin:0;font-size:.93rem;color:rgba(255,255,255,.78);line-height:1.7; }

/* ── Article Tags Row ───────────────────────────────────────────────── */
.gv-article-tags{ display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:28px 0 20px;font-size:.88rem; }
.gv-article-tags strong{ color:rgba(255,255,255,.55); }

/* ── Social Share Buttons ───────────────────────────────────────────── */
.gv-share-btns{
  display:flex;align-items:center;flex-wrap:wrap;gap:10px;
  margin:24px 0 32px;padding:16px 0;border-top:1px solid rgba(255,255,255,.08);
}
.gv-share-label{ font-size:.85rem;font-weight:700;color:rgba(255,255,255,.5);margin-right:4px; }
.gv-share-btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 16px;border-radius:8px;font-size:.85rem;font-weight:600;
  cursor:pointer;text-decoration:none;border:1px solid transparent;
  transition:opacity .2s,transform .15s;
}
.gv-share-btn:hover{ opacity:.85;transform:translateY(-1px); }
.gv-share-twitter{ background:#1a1a2e;border-color:rgba(255,255,255,.2);color:#fff; }
.gv-share-facebook{ background:#1877f2;color:#fff; }
.gv-share-copy{ background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.2);color:rgba(255,255,255,.85); }

/* ── Author Bio Card ────────────────────────────────────────────────── */
.gv-author-bio{
  display:flex;gap:20px;align-items:flex-start;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);
  border-radius:12px;padding:24px;margin:32px 0;
}
.gv-author-bio-avatar{
  width:64px;height:64px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--gv-purple),#a820c4);
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;font-weight:800;color:#fff;letter-spacing:.02em;
}
.gv-author-bio-name{ font-size:1.05rem;font-weight:700;margin:0 0 2px; }
.gv-author-bio-name a{ color:#fff;text-decoration:none; }
.gv-author-bio-name a:hover{ color:var(--gv-gold); }
.gv-author-bio-role{ font-size:.82rem;color:var(--gv-gold);margin:0 0 8px;font-weight:600; }
.gv-author-bio-text{ font-size:.9rem;color:rgba(255,255,255,.72);margin:0 0 12px;line-height:1.65; }
.gv-author-bio-links{ display:flex;gap:12px; }
.gv-author-bio-links a{ color:rgba(255,255,255,.5);font-size:1rem;transition:color .2s; }
.gv-author-bio-links a:hover{ color:var(--gv-gold); }

/* ── Blog Featured Hero Card ────────────────────────────────────────── */
.gv-blog-featured{
  display:flex;gap:0;border-radius:16px;overflow:hidden;
  background:linear-gradient(135deg,rgba(90,27,113,.7),rgba(35,23,65,.9));
  border:1px solid rgba(168,32,196,.3);margin-bottom:8px;
}
.gv-blog-featured-thumb{
  width:280px;min-width:280px;flex-shrink:0;overflow:hidden;border-radius:14px 0 0 14px;
}
.gv-blog-featured-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.gv-blog-featured-body{ padding:28px 32px;flex:1; }
.gv-blog-featured-meta{ display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px; }
.gv-blog-featured-title{ font-size:1.55rem;margin:0 0 12px;line-height:1.3; }
.gv-blog-featured-title a{ color:#fff;text-decoration:none; }
.gv-blog-featured-title a:hover{ color:var(--gv-gold); }
.gv-blog-featured-excerpt{ font-size:.97rem;color:rgba(255,255,255,.75);margin:0 0 20px;line-height:1.65; }
.gv-blog-featured-footer{ display:flex;flex-wrap:wrap;align-items:center;gap:10px;font-size:.88rem;color:rgba(255,255,255,.55); }
.gv-blog-featured-footer a{ color:rgba(255,255,255,.55);text-decoration:none; }
.gv-blog-featured-footer .gv-blog-readmore{ margin-left:auto;color:var(--gv-gold);font-weight:700; }

/* ── Category Filter Bar ────────────────────────────────────────────── */
.gv-cat-filter{ display:flex;flex-wrap:wrap;gap:8px;margin-bottom:28px; }
.gv-cat-btn{
  padding:7px 18px;border-radius:20px;font-size:.87rem;font-weight:600;cursor:pointer;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);
  color:rgba(255,255,255,.7);transition:all .2s;
}
.gv-cat-btn:hover,.gv-cat-btn.active{
  background:linear-gradient(135deg,var(--gv-purple),#a820c4);
  border-color:transparent;color:#fff;
}

/* ── Blog Author small inline ───────────────────────────────────────── */
.gv-blog-author-sm{ font-size:.85rem; }

/* ── Responsive: blog post ──────────────────────────────────────────── */
@media (max-width:768px){
  .gv-blog-featured{ flex-direction:column; }
  .gv-blog-featured-thumb{ width:100%;min-width:unset;height:200px;border-radius:14px 14px 0 0; }
  .gv-blog-featured-body{ padding:20px 18px; }
  .gv-blog-featured-title{ font-size:1.2rem; }
  .gv-blog-featured-footer .gv-blog-readmore{ margin-left:0; }
  .gv-author-bio{ flex-direction:column; }
  .gv-toc{ padding:16px; }
  .gv-prose h2{ font-size:1.25rem; }
  .gv-prose-table{ font-size:.8rem; }
  .gv-prose-table th,.gv-prose-table td{ padding:7px 10px; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   ADVANCED COMPONENTS — Author Portraits / Verified Tick / Internal Links /
   Blog Layout / Author Pages  (added v2)
   ══════════════════════════════════════════════════════════════════════════ */

/* ── Verified Tick Badge ──────────────────────────────────────────────── */
.gv-verified{
  display:inline-flex;align-items:center;justify-content:center;
  width:18px;height:18px;border-radius:50%;
  background:#1d9bf0;flex-shrink:0;margin-left:4px;
  vertical-align:middle;overflow:hidden;
}
.gv-verified svg{ width:11px;height:11px;fill:#fff;flex-shrink:0; }
.gv-verified-lg{
  display:inline-flex;align-items:center;justify-content:center;
  width:26px;height:26px;border-radius:50%;
  background:#1d9bf0;flex-shrink:0;margin-left:6px;
  vertical-align:middle;overflow:hidden;
}
.gv-verified-lg svg{ width:16px;height:16px;fill:#fff;flex-shrink:0; }

/* ── Author Avatar — image based ─────────────────────────────────────── */
.gv-avatar-img{
  border-radius:50%;object-fit:cover;flex-shrink:0;
  border:2px solid rgba(255,215,0,.4);background:#1a0a2e;
}
.gv-avatar-img-sm{ width:32px;height:32px; }
.gv-avatar-img-md{ width:48px;height:48px; }
.gv-avatar-img-lg{ width:72px;height:72px; }
.gv-avatar-img-xl{ width:110px;height:110px;border-width:3px; }

/* ── Author chip wrapper (used in post header) ───────────────────────── */
.gv-author-chip{
  display:inline-flex;align-items:center;gap:8px;
  text-decoration:none;color:inherit;
}
.gv-author-chip-name{
  font-size:.88rem;font-weight:600;color:rgba(255,255,255,.9);
  display:flex;align-items:center;gap:3px;
}
.gv-author-chip-role{ font-size:.78rem;color:rgba(255,255,255,.5); }

/* ── Internal link (prose) ───────────────────────────────────────────── */
.gv-ilink{
  color:var(--gv-gold);text-decoration:none;
  border-bottom:1px dotted rgba(255,215,0,.5);
  transition:border-color .2s,color .2s;
}
.gv-ilink:hover{ border-bottom-style:solid; }

/* ── Two-column article layout ───────────────────────────────────────── */
.gv-article-wrap{
  display:grid;grid-template-columns:1fr 300px;
  gap:40px;align-items:start;
  max-width:1100px;margin:0 auto;padding:0;
}
.gv-article-main{ min-width:0; }
.gv-article-sidebar{
  position:sticky;top:80px;display:flex;flex-direction:column;gap:20px;
}
@media (max-width:1024px){
  .gv-article-wrap{ grid-template-columns:1fr; }
  .gv-article-sidebar{ display:none; }
}

/* ── Sidebar widgets ────────────────────────────────────────────────── */
.gv-sidebar-widget{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);
  border-radius:12px;padding:18px;
}
.gv-sidebar-widget-title{
  font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.45);margin:0 0 14px;padding-bottom:10px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.gv-sidebar-toc a{
  display:block;font-size:.83rem;color:rgba(255,255,255,.65);text-decoration:none;
  padding:4px 0;border-left:2px solid transparent;padding-left:10px;
  transition:color .2s,border-color .2s;
}
.gv-sidebar-toc a:hover,.gv-sidebar-toc a.active{
  color:var(--gv-gold);border-left-color:var(--gv-gold);
}
.gv-sidebar-author{
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;
}
.gv-sidebar-author-name{
  font-size:.93rem;font-weight:700;color:#fff;
  display:flex;align-items:center;justify-content:center;gap:4px;
}
.gv-sidebar-author-role{ font-size:.78rem;color:var(--gv-gold);font-weight:600; }

/* ── Author bio card v2 (post bottom) ────────────────────────────────── */
.gv-author-bio-v2{
  display:flex;gap:22px;align-items:flex-start;
  background:linear-gradient(135deg,rgba(45,27,78,.6),rgba(26,10,46,.8));
  border:1px solid rgba(168,32,196,.3);
  border-radius:16px;padding:28px;margin:36px 0;
}
.gv-author-bio-v2-avatar{
  position:relative;flex-shrink:0;
}
.gv-author-bio-v2-tick{
  position:absolute;bottom:4px;right:4px;
  display:flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:50%;background:#1d9bf0;
  border:2px solid #1a0a2e;overflow:hidden;
}
.gv-author-bio-v2-tick svg{ width:13px;height:13px;fill:#fff;flex-shrink:0; }
.gv-author-bio-v2-body{ flex:1;min-width:0; }
.gv-author-bio-v2-header{
  display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:4px;
}
.gv-author-bio-v2-name{
  font-size:1.05rem;font-weight:700;color:#fff;text-decoration:none;
}
.gv-author-bio-v2-name:hover{ color:var(--gv-gold); }
.gv-author-bio-v2-role{ font-size:.82rem;color:var(--gv-gold);font-weight:600; }
.gv-author-bio-v2-stats{
  display:flex;flex-wrap:wrap;gap:12px;margin:8px 0 10px;
}
.gv-author-bio-v2-stat{
  font-size:.78rem;color:rgba(255,255,255,.5);display:flex;align-items:center;gap:5px;
}
.gv-author-bio-v2-stat i{ color:var(--gv-purple); }
.gv-author-bio-v2-text{
  font-size:.9rem;color:rgba(255,255,255,.72);margin:0 0 14px;line-height:1.7;
}
.gv-author-bio-v2-links{ display:flex;gap:12px; }
.gv-author-bio-v2-links a{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 14px;border-radius:8px;font-size:.82rem;font-weight:600;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.7);text-decoration:none;transition:all .2s;
}
.gv-author-bio-v2-links a:hover{ background:rgba(255,215,0,.1);color:var(--gv-gold);border-color:rgba(255,215,0,.3); }
@media (max-width:600px){
  .gv-author-bio-v2{ flex-direction:column;align-items:center;text-align:center; }
  .gv-author-bio-v2-links{ justify-content:center; }
}

/* ── Blog search bar ─────────────────────────────────────────────────── */
.gv-blog-search-wrap{ position:relative;margin-bottom:28px; }
.gv-blog-search{
  width:100%;padding:13px 46px 13px 18px;border-radius:12px;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);
  color:#fff;font-size:.97rem;outline:none;transition:border-color .2s,background .2s;
  box-sizing:border-box;
}
.gv-blog-search:focus{ background:rgba(255,255,255,.1);border-color:rgba(168,32,196,.6); }
.gv-blog-search::placeholder{ color:rgba(255,255,255,.35); }
.gv-blog-search-icon{
  position:absolute;right:16px;top:50%;transform:translateY(-50%);
  color:rgba(255,255,255,.35);pointer-events:none;
}

/* ── Load More button ────────────────────────────────────────────────── */
.gv-load-more-wrap{ text-align:center;margin:32px 0 0; }
.gv-load-more{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 36px;border-radius:12px;font-size:.95rem;font-weight:700;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);
  color:rgba(255,255,255,.8);cursor:pointer;transition:all .2s;
}
.gv-load-more:hover{
  background:linear-gradient(135deg,var(--gv-purple),#a820c4);
  border-color:transparent;color:#fff;transform:translateY(-1px);
}
.gv-load-more[data-hidden="0"]{ display:none; }

/* ── Blog card — with author avatar ─────────────────────────────────── */
.gv-card-author{
  display:flex;align-items:center;gap:7px;
  margin-top:auto;padding:12px 18px 0;font-size:.82rem;
  color:rgba(255,255,255,.55);border-top:1px solid rgba(255,255,255,.06);
}
.gv-card-author a{ color:rgba(255,255,255,.55);text-decoration:none; }
.gv-card-author a:hover{ color:var(--gv-gold); }
.gv-card-author-verified{
  display:inline-flex;align-items:center;justify-content:center;
  width:14px;height:14px;border-radius:50%;background:#1d9bf0;flex-shrink:0;overflow:hidden;
}
.gv-card-author-verified svg{ width:8px;height:8px;fill:#fff;flex-shrink:0; }

/* ── Author page hero v2 ─────────────────────────────────────────────── */
.gv-author-hero-v2{
  display:flex;gap:32px;align-items:flex-start;
  padding:48px 0 36px;
}
.gv-author-hero-avatar{
  position:relative;flex-shrink:0;
}
.gv-author-hero-tick{
  position:absolute;bottom:6px;right:6px;
  display:flex;align-items:center;justify-content:center;
  width:30px;height:30px;border-radius:50%;background:#1d9bf0;
  border:3px solid #0d0d1a;overflow:hidden;
}
.gv-author-hero-tick svg{ width:17px;height:17px;fill:#fff;flex-shrink:0; }
.gv-author-hero-body{ flex:1; }
.gv-author-hero-role{
  font-size:.82rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--gv-gold);margin:0 0 6px;
}
.gv-author-hero-name{
  font-size:2.2rem;font-weight:800;margin:0 0 12px;line-height:1.15;
  display:flex;align-items:center;gap:10px;
}
.gv-author-hero-bio{
  font-size:.98rem;color:rgba(255,255,255,.72);max-width:620px;line-height:1.7;
  margin:0 0 20px;
}
.gv-author-stats-row{
  display:flex;flex-wrap:wrap;gap:20px;margin:16px 0 20px;
}
.gv-author-stat-item{
  display:flex;flex-direction:column;gap:2px;
}
.gv-author-stat-num{
  font-size:1.45rem;font-weight:800;color:#fff;line-height:1;
}
.gv-author-stat-label{
  font-size:.75rem;color:rgba(255,255,255,.45);font-weight:600;
  text-transform:uppercase;letter-spacing:.06em;
}
.gv-author-hero-links{ display:flex;gap:10px;flex-wrap:wrap; }
.gv-author-hero-links a{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 16px;border-radius:8px;font-size:.85rem;font-weight:600;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.8);text-decoration:none;transition:all .2s;
}
.gv-author-hero-links a:hover{
  background:rgba(255,215,0,.12);color:var(--gv-gold);border-color:rgba(255,215,0,.35);
}
.gv-author-expertise{
  display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;
}
.gv-expertise-tag{
  padding:5px 14px;border-radius:20px;font-size:.78rem;font-weight:600;
  background:rgba(168,32,196,.15);border:1px solid rgba(168,32,196,.3);
  color:rgba(255,255,255,.75);
}
@media (max-width:640px){
  .gv-author-hero-v2{ flex-direction:column;align-items:center;text-align:center; }
  .gv-author-stats-row{ justify-content:center; }
  .gv-author-hero-links{ justify-content:center; }
  .gv-author-expertise{ justify-content:center; }
  .gv-author-hero-name{ font-size:1.6rem;justify-content:center; }
}

/* ── Author index card v2 ────────────────────────────────────────────── */
.gv-author-card-v2{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  border-radius:16px;padding:28px 22px;text-align:center;
  transition:border-color .25s,transform .2s;display:flex;flex-direction:column;align-items:center;gap:12px;
}
.gv-author-card-v2:hover{ border-color:rgba(168,32,196,.4);transform:translateY(-2px); }
.gv-author-card-v2-avatar{ position:relative;display:inline-block; }
.gv-author-card-v2-tick{
  position:absolute;bottom:4px;right:4px;
  display:flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:50%;background:#1d9bf0;
  border:2px solid #0d0d1a;overflow:hidden;
}
.gv-author-card-v2-tick svg{ width:12px;height:12px;fill:#fff;flex-shrink:0; }
.gv-author-card-v2-name{
  font-size:1.05rem;font-weight:700;color:#fff;text-decoration:none;
  display:flex;align-items:center;justify-content:center;gap:5px;
  margin:0;line-height:1.3;
}
.gv-author-card-v2-name a{color:inherit;text-decoration:none;}
.gv-author-card-v2-name:hover,.gv-author-card-v2-name a:hover{ color:var(--gv-gold); }
.gv-author-card-v2-role{ font-size:.8rem;color:var(--gv-gold);font-weight:600; }
.gv-author-card-v2-bio{
  font-size:.85rem;color:rgba(255,255,255,.6);line-height:1.6;margin:0;
}
.gv-author-card-v2-posts{
  font-size:.8rem;color:rgba(255,255,255,.4);display:flex;align-items:center;gap:5px;
}
.gv-author-card-v2-posts i{ color:var(--gv-purple); }

/* ── Author post grid card v2 ────────────────────────────────────────── */
.gv-author-post-grid{ display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px;margin-top:28px; }
.gv-author-post-card{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  border-radius:12px;overflow:hidden;transition:border-color .2s,transform .2s;
  display:flex;flex-direction:column;
}
.gv-author-post-card:hover{ border-color:rgba(168,32,196,.35);transform:translateY(-2px); }
.gv-author-post-card-thumb{ aspect-ratio:16/9;overflow:hidden; }
.gv-author-post-card-thumb img{ width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s; }
.gv-author-post-card:hover .gv-author-post-card-thumb img{ transform:scale(1.04); }
.gv-author-post-card-body{ padding:16px;flex:1;display:flex;flex-direction:column;gap:8px; }
.gv-author-post-card-meta{ font-size:.78rem;color:rgba(255,255,255,.45);display:flex;gap:8px;align-items:center; }
.gv-author-post-card-cat{ color:var(--gv-gold);font-weight:600; }
.gv-author-post-card-title{ font-size:.95rem;font-weight:700;color:rgba(255,255,255,.9);text-decoration:none;line-height:1.4; }
.gv-author-post-card-title:hover{ color:var(--gv-gold); }
.gv-author-post-card-read{
  font-size:.82rem;color:var(--gv-gold);font-weight:600;text-decoration:none;
  margin-top:auto;display:flex;align-items:center;gap:6px;
}

/* ── Hide inline ToC on desktop — sidebar ToC handles it ────────────── */
@media (min-width:1025px){ .gv-toc-inline{ display:none; } }

/* ── Blog post prev/next navigation ─────────────────────────────────── */
.gv-post-nav{
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
}
.gv-post-nav-link{
  display:flex;flex-direction:column;gap:8px;padding:20px 22px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);
  border-radius:14px;text-decoration:none;transition:all .22s;
}
.gv-post-nav-link:hover{
  border-color:rgba(168,32,196,.45);background:rgba(168,32,196,.09);
  transform:translateY(-2px);box-shadow:0 6px 24px rgba(168,32,196,.15);
}
.gv-post-nav-prev{ align-items:flex-start; }
.gv-post-nav-next{ align-items:flex-end;text-align:right; }
.gv-post-nav-dir{
  font-size:.74rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  color:var(--gv-gold);display:flex;align-items:center;gap:6px;
}
.gv-post-nav-next .gv-post-nav-dir{ flex-direction:row-reverse; }
.gv-post-nav-title{
  font-size:.9rem;font-weight:600;color:rgba(255,255,255,.85);line-height:1.45;
}
@media (max-width:640px){
  .gv-post-nav{ grid-template-columns:1fr; }
  .gv-post-nav-next{ align-items:flex-start;text-align:left; }
  .gv-post-nav-next .gv-post-nav-dir{ flex-direction:row; }
}

/* ── Blog index — no results state ──────────────────────────────────── */
.gv-no-results{
  text-align:center;padding:64px 24px;color:rgba(255,255,255,.45);
  grid-column:1/-1;
}
.gv-no-results i{
  display:block;font-size:2.4rem;margin-bottom:16px;
  color:rgba(255,255,255,.18);
}
.gv-no-results p{ margin:0;font-size:.97rem;line-height:1.6; }

/* ── Author page — load more button wrap ─────────────────────────── */
.gv-author-load-more-wrap{ text-align:center;margin:36px 0 0; }

/* ── Author post grid — force single column at narrow widths ─────── */
@media (max-width:560px){
  .gv-author-post-grid{ grid-template-columns:1fr; }
}

/* ── Blog search bar — enhanced focus glow ───────────────────────── */
.gv-blog-search:focus{
  background:rgba(255,255,255,.1);
  border-color:rgba(168,32,196,.7);
  box-shadow:0 0 0 3px rgba(168,32,196,.18);
}

/* ═══════════════════════════════════════════════════════════════════════
   INNER PAGES — Section alternating background, titles, steps, tables
   ═══════════════════════════════════════════════════════════════════════ */

/* ── Alternating section bg ──────────────────────────────────────────── */
.gv-section-alt{
  background:linear-gradient(180deg,#110828 0%,#1c1038 100%);
}

/* ── Section sub-heading ─────────────────────────────────────────────── */
.gv-section-sub{
  text-align:center;max-width:720px;margin:-16px auto 36px;
  color:rgba(255,255,255,.65);font-size:1rem;line-height:1.7;
}
.gv-section-title + .gv-section-sub{ margin-top:-20px; }

/* ── Steps / How-to grid ─────────────────────────────────────────────── */
.gv-steps-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:22px;
}
.gv-steps-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  border-radius:14px;padding:26px 24px;
  position:relative;
}
.gv-steps-card:hover{
  border-color:rgba(168,32,196,.35);
  background:rgba(168,32,196,.06);
  transform:translateY(-2px);
  transition:all .22s;
}
.gv-steps-card h3{
  font-size:1.08rem;margin:0 0 12px;color:#fff;
  display:flex;align-items:center;gap:8px;
}
.gv-steps-card h3 i{ color:var(--gv-gold);font-size:1.1rem; }
.gv-steps-card p{
  font-size:.93rem;color:rgba(255,255,255,.68);
  line-height:1.7;margin:0 0 .75rem;
}
.gv-steps-card p:last-child{ margin-bottom:0; }
.gv-steps-list{
  padding-left:20px;margin:10px 0 0;
  counter-reset:steps;
}
.gv-steps-list li{
  font-size:.9rem;color:rgba(255,255,255,.72);
  line-height:1.65;margin-bottom:8px;padding-left:4px;
}
.gv-steps-list li strong{ color:rgba(255,255,255,.9); }
@media (max-width:600px){
  .gv-steps-grid{ grid-template-columns:1fr; }
}

/* ── Trouble-shooting grid ───────────────────────────────────────────── */
.gv-trouble-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:18px;margin-top:8px;
}
.gv-trouble-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-left:3px solid rgba(168,32,196,.5);
  border-radius:12px;padding:20px 22px;
}
.gv-trouble-card h3{
  font-size:.97rem;color:rgba(255,255,255,.9);
  margin:0 0 10px;
}
.gv-trouble-card p{
  font-size:.88rem;color:rgba(255,255,255,.62);
  line-height:1.65;margin:0;
}
@media (max-width:560px){
  .gv-trouble-grid{ grid-template-columns:1fr; }
}

/* ── Note / small footnote ───────────────────────────────────────────── */
.gv-note{
  font-size:.83rem;color:rgba(255,255,255,.5);
  margin:14px 0 0;line-height:1.6;
  padding:10px 14px;
  background:rgba(255,255,255,.04);
  border-radius:8px;border-left:3px solid rgba(255,215,0,.35);
}

/* ── Styled data table ───────────────────────────────────────────────── */
.gv-table{
  width:100%;border-collapse:collapse;font-size:.9rem;
}
.gv-table thead tr{
  background:linear-gradient(135deg,rgba(168,32,196,.25),rgba(168,32,196,.12));
}
.gv-table th{
  text-align:left;padding:12px 16px;font-size:.78rem;
  font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:rgba(255,255,255,.7);white-space:nowrap;
}
.gv-table td{
  padding:11px 16px;border-bottom:1px solid rgba(255,255,255,.06);
  color:rgba(255,255,255,.8);font-size:.88rem;vertical-align:middle;
}
.gv-table tbody tr:last-child td{ border-bottom:none; }
.gv-table tbody tr:hover td{
  background:rgba(255,255,255,.04);
}
.gv-table td i{ color:var(--gv-gold); }
@media (max-width:640px){
  .gv-table th,.gv-table td{ padding:9px 12px;font-size:.82rem; }
}

/* ── Promotions FAQ (details/summary accordion) ─────────────────────── */
.gv-faq-wrap{ max-width:820px;margin:0 auto; }
.gv-faq{ display:flex;flex-direction:column;gap:12px; }
.gv-faq .gv-faq-item{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  border-radius:12px;overflow:hidden;
}
.gv-faq .gv-faq-item[open]{
  border-color:rgba(168,32,196,.45);
}
.gv-faq summary.gv-faq-q{
  display:flex;justify-content:space-between;align-items:center;
  padding:18px 22px;cursor:pointer;list-style:none;
  font-size:1rem;font-weight:600;color:#fff;line-height:1.45;
}
.gv-faq summary.gv-faq-q::-webkit-details-marker{ display:none; }
.gv-faq summary.gv-faq-q::after{
  content:'+';font-size:1.3rem;color:var(--gv-gold);
  margin-left:14px;flex-shrink:0;transition:transform .2s;
}
.gv-faq .gv-faq-item[open] summary.gv-faq-q::after{ content:'−'; }
.gv-faq .gv-faq-a{
  padding:0 22px 18px;
}
.gv-faq .gv-faq-a p{
  margin:0;font-size:.92rem;color:rgba(255,255,255,.72);line-height:1.7;
}
/* Static non-accordion variant (h3.gv-faq-q / p.gv-faq-a) */
.gv-faq h3.gv-faq-q{
  font-size:1rem;color:#fff;margin:0 0 10px;line-height:1.45;
  cursor:default;display:block;
}
.gv-faq h3.gv-faq-q::after{ content:none; }
.gv-faq p.gv-faq-a{
  font-size:.9rem;color:rgba(255,255,255,.68);
  margin:0;line-height:1.7;
}

/* ── HTML Sitemap page ───────────────────────────────────────────────── */
.gv-sitemap-grid{
  display:grid;grid-template-columns:1fr 2fr 1fr;gap:32px;align-items:start;
}
@media (max-width:768px){
  .gv-sitemap-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:480px){
  .gv-sitemap-grid{ grid-template-columns:1fr; }
}
.gv-sitemap h3{
  font-size:1rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--gv-gold);margin:0 0 14px;padding-bottom:10px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.gv-sitemap ul{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:4px;
  max-height:520px;overflow-y:auto;
}
.gv-sitemap ul::-webkit-scrollbar{ width:4px; }
.gv-sitemap ul::-webkit-scrollbar-track{ background:rgba(255,255,255,.04);border-radius:4px; }
.gv-sitemap ul::-webkit-scrollbar-thumb{ background:rgba(168,32,196,.4);border-radius:4px; }
.gv-sitemap ul li a{
  font-size:.88rem;color:rgba(255,255,255,.65);
  text-decoration:none;display:block;padding:3px 0;
  transition:color .15s;
}
.gv-sitemap ul li a:hover{ color:var(--gv-gold); }

/* ── VIP tier — icon/badge per tier ─────────────────────────────────── */
.gv-vip-tier{ transition:transform .2s,border-color .2s; }
.gv-vip-tier:hover{ transform:translateY(-3px);border-color:rgba(255,215,0,.25); }
.gv-vip-tier.featured:hover{ border-color:rgba(255,215,0,.6); }

/* ── Contact page — ensure gv-prose gets top spacing after card row ── */
.gv-section .gv-container.gv-prose{ margin-top:48px; }

/* ── 404 hero CTA button spacing ────────────────────────────────────── */
.gv-page-hero .gv-btn{ margin-top:24px;display:inline-flex; }

/* ── Page hero badge top spacing ────────────────────────────────────── */
.gv-page-hero .gv-badge-sm{ margin-bottom:14px;display:inline-block; }

/* ── Section title second-occurrence top margin ─────────────────────── */
.gv-section-title{ margin-bottom:8px; }
.gv-section-title + *:not(.gv-section-sub){ margin-top:28px; }

/* ── Screen-reader-only utility ──────────────────────────────────────── */
.gv-sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
