/*
Theme Name: IPTV Information Pro
Theme URI: https://iptvinformation.com
Author: IPTVInformation Team
Description: Aggressive, fully responsive IPTV directory, review and blog theme — optimized for mobile, iPad, laptop and desktop. Elementor ready. AdSense ready.
Version: 3.0.0
Requires at least: 6.0
Requires PHP: 8.0
License: GNU General Public License v2 or later
Text Domain: iptv-info-pro
Tags: blog, reviews, directory, iptv, elementor, adsense, dark, responsive
*/

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  --c-bg:        #060e1a;
  --c-bg2:       #0a1628;
  --c-card:      #0d1f38;
  --c-card2:     #112240;
  --c-border:    rgba(0,200,255,.12);
  --c-border-h:  rgba(0,200,255,.38);
  --c-text:      #cdd9f0;
  --c-muted:     #6a85a8;
  --c-dim:       #3a5070;
  --c-white:     #ffffff;

  --c-cyan:      #00c8ff;
  --c-blue:      #0055ff;
  --c-neon:      #00ff88;
  --c-fire:      #ff4400;
  --c-orange:    #ff8c00;
  --c-gold:      #ffd700;
  --c-purple:    #7c3aed;
  --c-danger:    #ff2244;
  --c-success:   #00e676;
  --c-warn:      #ffab00;

  --g-hero:      linear-gradient(135deg,#060e1a 0%,#0a1628 50%,#0d2040 100%);
  --g-cyan:      linear-gradient(90deg,#00c8ff,#0055ff);
  --g-fire:      linear-gradient(90deg,#ff4400,#ff8c00);
  --g-neon:      linear-gradient(90deg,#00ff88,#00c8ff);
  --g-gold:      linear-gradient(90deg,#ffd700,#ff8c00);
  --g-purple:    linear-gradient(90deg,#7c3aed,#4f46e5);
  --g-card:      linear-gradient(135deg,#0d1f38,#112240);

  --shadow-card: 0 4px 24px rgba(0,0,0,.35);
  --shadow-neon: 0 0 24px rgba(0,200,255,.2);
  --shadow-fire: 0 0 24px rgba(255,68,0,.35);
  --shadow-gold: 0 0 20px rgba(255,215,0,.25);
  --shadow-lg:   0 20px 60px rgba(0,0,0,.5);

  --r-sm:  6px;
  --r-md:  12px;
  --r-lg:  18px;
  --r-xl:  26px;
  --r-2xl: 36px;

  --f-head: 'Exo 2','Sora',sans-serif;
  --f-body: 'DM Sans','Roboto',sans-serif;
  --f-mono: 'JetBrains Mono',monospace;

  --ease: cubic-bezier(.4,0,.2,1);
  --tr: all .25s var(--ease);
  --hdr-h: 64px;

  /* Fluid typography scale */
  --fs-xs:  clamp(.65rem,.6rem + .2vw,.75rem);
  --fs-sm:  clamp(.78rem,.72rem + .3vw,.9rem);
  --fs-md:  clamp(.9rem,.85rem + .25vw,1rem);
  --fs-lg:  clamp(1rem,.95rem + .35vw,1.15rem);
  --fs-xl:  clamp(1.2rem,1.1rem + .5vw,1.5rem);
  --fs-2xl: clamp(1.5rem,1.3rem + .8vw,2rem);
  --fs-3xl: clamp(1.8rem,1.5rem + 1.5vw,2.8rem);
  --fs-4xl: clamp(2rem,1.6rem + 2vw,3.5rem);

  /* Fluid spacing */
  --sp-xs:  clamp(4px,1vw,8px);
  --sp-sm:  clamp(8px,2vw,14px);
  --sp-md:  clamp(14px,3vw,22px);
  --sp-lg:  clamp(20px,4vw,36px);
  --sp-xl:  clamp(32px,6vw,64px);
  --sp-2xl: clamp(48px,8vw,96px);
}

/* ============================================================
   GLOBAL RESET
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{
  font-family:var(--f-body);
  background:var(--c-bg);
  color:var(--c-text);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  min-width:320px;
}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--c-bg)}
::-webkit-scrollbar-thumb{background:var(--c-blue);border-radius:3px}
::selection{background:var(--c-blue);color:#fff}
a{color:var(--c-cyan);text-decoration:none;transition:var(--tr)}
a:hover{color:#fff}
img{max-width:100%;height:auto;display:block}
ul{list-style:none}
button,input,select,textarea{font-family:inherit;font-size:inherit}
picture,svg{display:block}

/* ============================================================
   LAYOUT CONTAINERS — ALL SCREEN SIZES
   ============================================================ */
.wrap   {width:100%;max-width:1280px;margin:0 auto;padding:0 clamp(16px,4vw,32px)}
.wrap-sm{width:100%;max-width:900px; margin:0 auto;padding:0 clamp(16px,4vw,32px)}
.wrap-xs{width:100%;max-width:680px; margin:0 auto;padding:0 clamp(16px,4vw,28px)}

.section{padding:var(--sp-2xl) 0}
.section-sm{padding:var(--sp-xl) 0}
.bg-dark  {background:var(--c-bg2)}
.bg-card  {background:var(--c-card)}
.bg-hero  {background:var(--g-hero)}

/* ============================================================
   TYPOGRAPHY — FLUID & RESPONSIVE
   ============================================================ */
h1,h2,h3,h4,h5,h6{
  font-family:var(--f-head);
  font-weight:800;
  line-height:1.15;
  color:var(--c-white);
  letter-spacing:-.02em;
}
h1{font-size:var(--fs-4xl)}
h2{font-size:var(--fs-3xl)}
h3{font-size:var(--fs-2xl)}
h4{font-size:var(--fs-xl)}
h5{font-size:var(--fs-lg)}
p{color:var(--c-text);line-height:1.75}
.text-muted{color:var(--c-muted)}
.text-dim  {color:var(--c-dim)}
.mono      {font-family:var(--f-mono)}

.grad-text    {background:var(--g-cyan);  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.fire-text    {background:var(--g-fire);  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.neon-text    {color:var(--c-neon);text-shadow:0 0 16px rgba(0,255,136,.4)}
.gold-text    {color:var(--c-gold);text-shadow:0 0 12px rgba(255,215,0,.3)}

.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:var(--fs-xs);font-weight:800;letter-spacing:.12em;
  text-transform:uppercase;color:var(--c-cyan);font-family:var(--f-mono);
  margin-bottom:12px;
}
.eyebrow::before{content:'';width:22px;height:2px;background:var(--g-cyan);border-radius:2px}

.section-head{text-align:center;margin-bottom:var(--sp-lg)}
.section-head .eyebrow{justify-content:center}
.section-head h2{margin-bottom:10px}
.section-head p{color:var(--c-muted);font-size:var(--fs-md);max-width:600px;margin:0 auto}

/* ============================================================
   BUTTONS — ALL SIZES, TOUCH FRIENDLY
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  min-height:44px; /* touch target */
  padding:0 clamp(16px,3vw,28px);
  border-radius:var(--r-md);
  font-family:var(--f-head);font-weight:700;font-size:var(--fs-sm);
  letter-spacing:.05em;text-transform:uppercase;
  cursor:pointer;border:none;transition:var(--tr);
  text-decoration:none;position:relative;overflow:hidden;
  white-space:nowrap;
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation;
}
.btn i{font-size:.9em}

.btn-cyan  {background:var(--g-cyan);color:#000;box-shadow:0 4px 18px rgba(0,85,255,.4)}
.btn-fire  {background:var(--g-fire);color:#fff;box-shadow:0 4px 18px rgba(255,68,0,.4)}
.btn-neon  {background:transparent;color:var(--c-neon);border:2px solid var(--c-neon);box-shadow:0 0 14px rgba(0,255,136,.15)}
.btn-ghost {background:rgba(0,200,255,.07);color:var(--c-cyan);border:1px solid var(--c-border-h)}
.btn-gold  {background:var(--g-gold);color:#000;box-shadow:0 4px 18px rgba(255,215,0,.3)}

.btn-cyan:hover {transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,85,255,.55);color:#000}
.btn-fire:hover {transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,68,0,.55);color:#fff}
.btn-neon:hover {background:var(--c-neon);color:#000;box-shadow:0 0 28px rgba(0,255,136,.4)}
.btn-ghost:hover{background:rgba(0,200,255,.15);color:#fff;border-color:var(--c-cyan)}
.btn-gold:hover {transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,215,0,.45);color:#000}

.btn-sm{min-height:38px;padding:0 16px;font-size:var(--fs-xs)}
.btn-lg{min-height:52px;padding:0 clamp(20px,4vw,38px);font-size:var(--fs-md)}
.btn-xl{min-height:56px;padding:0 clamp(24px,5vw,48px);font-size:var(--fs-lg);border-radius:var(--r-lg)}
.btn-block{width:100%}

/* ============================================================
   TICKER
   ============================================================ */
.ticker{
  background:var(--g-cyan);height:32px;
  display:flex;align-items:center;overflow:hidden;flex-shrink:0;
}
.ticker-lbl{
  background:rgba(0,0,0,.28);color:#000;padding:0 14px;
  font-size:var(--fs-xs);font-weight:900;letter-spacing:.1em;
  text-transform:uppercase;height:100%;display:flex;align-items:center;
  white-space:nowrap;flex-shrink:0;font-family:var(--f-mono);
}
.ticker-track{display:flex;gap:40px;white-space:nowrap;animation:tick 28s linear infinite;color:#000;font-size:var(--fs-xs);font-weight:700}
.ticker-track span{display:flex;align-items:center;gap:6px}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   HEADER — FULLY RESPONSIVE
   ============================================================ */
#hdr{
  position:sticky;top:0;z-index:900;
  background:rgba(6,14,26,.95);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--c-border);
  height:var(--hdr-h);
}
.hdr-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:var(--hdr-h);gap:12px;
}

/* Logo */
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-mark{
  width:40px;height:40px;border-radius:var(--r-sm);
  background:var(--g-cyan);display:flex;align-items:center;justify-content:center;
  font-family:var(--f-head);font-weight:900;font-size:1rem;color:#000;
  box-shadow:var(--shadow-neon);flex-shrink:0;
}
.logo-text{display:flex;flex-direction:column;line-height:1}
.logo-name{font-family:var(--f-head);font-weight:900;font-size:clamp(.9rem,2vw,1.1rem);color:#fff;letter-spacing:-.02em}
.logo-tag {font-size:clamp(.55rem,1.2vw,.68rem);color:var(--c-cyan);letter-spacing:.09em;text-transform:uppercase;font-family:var(--f-mono);margin-top:2px}

/* Desktop Nav */
.nav-links{display:flex;align-items:center;gap:2px}
.nav-links a{
  display:flex;align-items:center;gap:5px;
  padding:8px 11px;color:var(--c-muted);
  font-size:var(--fs-xs);font-weight:700;border-radius:var(--r-sm);
  transition:var(--tr);letter-spacing:.03em;text-transform:uppercase;
  font-family:var(--f-head);white-space:nowrap;
}
.nav-links a:hover{color:var(--c-cyan);background:rgba(0,200,255,.07)}
.nav-links a.hot{color:var(--c-fire)}
.nav-links a .badge{background:var(--g-fire);color:#fff;font-size:.55rem;padding:1px 5px;border-radius:3px;font-weight:800}

/* Has dropdown */
.nav-drop{position:relative}
.nav-drop .dropdown{
  position:absolute;top:calc(100% + 6px);left:0;min-width:200px;
  background:var(--c-card);border:1px solid var(--c-border);
  border-radius:var(--r-md);padding:6px;
  opacity:0;visibility:hidden;transform:translateY(8px);
  transition:var(--tr);z-index:500;box-shadow:var(--shadow-lg);
}
.nav-drop:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown a{display:block;padding:9px 12px;color:var(--c-muted);font-size:var(--fs-xs);border-radius:var(--r-sm)}
.dropdown a:hover{color:var(--c-cyan);background:rgba(0,200,255,.07)}

/* Header actions */
.hdr-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
.hdr-search-btn{
  width:38px;height:38px;background:rgba(0,200,255,.07);
  border:1px solid var(--c-border);color:var(--c-cyan);
  border-radius:var(--r-sm);cursor:pointer;display:flex;
  align-items:center;justify-content:center;transition:var(--tr);font-size:.9rem;
  -webkit-tap-highlight-color:transparent;
}
.hdr-search-btn:hover{background:rgba(0,200,255,.15);border-color:var(--c-cyan)}

/* Hamburger — hidden on desktop */
.hamburger{
  display:none;flex-direction:column;gap:5px;
  background:rgba(0,200,255,.07);border:1px solid var(--c-border);
  border-radius:var(--r-sm);cursor:pointer;padding:10px;
  width:40px;height:40px;justify-content:center;align-items:center;
  -webkit-tap-highlight-color:transparent;
}
.hamburger span{width:18px;height:2px;background:var(--c-cyan);border-radius:2px;transition:var(--tr);display:block}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile nav drawer */
.mobile-nav{
  display:none;position:fixed;top:var(--hdr-h);left:0;right:0;
  background:rgba(6,14,26,.98);backdrop-filter:blur(24px);
  border-bottom:1px solid var(--c-border);z-index:850;
  padding:16px;flex-direction:column;gap:4px;
  max-height:calc(100vh - var(--hdr-h));overflow-y:auto;
}
.mobile-nav.open{display:flex}
.mobile-nav a{
  display:flex;align-items:center;gap:10px;
  padding:14px 16px;color:var(--c-muted);font-size:var(--fs-sm);
  font-weight:700;border-radius:var(--r-sm);border:1px solid transparent;
  font-family:var(--f-head);text-transform:uppercase;letter-spacing:.03em;
  transition:var(--tr);
}
.mobile-nav a:hover,.mobile-nav a:active{color:var(--c-cyan);background:rgba(0,200,255,.07);border-color:var(--c-border)}
.mobile-nav a i{width:20px;text-align:center;color:var(--c-cyan)}
.mobile-nav .nav-divider{height:1px;background:var(--c-border);margin:6px 0}
.mobile-nav .nav-section-title{font-size:var(--fs-xs);color:var(--c-dim);font-family:var(--f-mono);letter-spacing:.1em;text-transform:uppercase;padding:8px 16px 4px}

/* Search bar (slides under header) */
.hdr-search-bar{
  display:none;border-top:1px solid var(--c-border);
  background:rgba(6,14,26,.98);padding:12px 0;
}
.hdr-search-bar.open{display:block}
.hdr-search-bar input{
  width:100%;padding:12px 16px;background:rgba(255,255,255,.05);
  border:1px solid var(--c-border-h);border-radius:var(--r-sm);
  color:#fff;font-size:var(--fs-md);
}
.hdr-search-bar input:focus{outline:none;border-color:var(--c-cyan);background:rgba(0,200,255,.06)}

/* ============================================================
   HERO — FULLY RESPONSIVE
   ============================================================ */
.hero{
  background:var(--g-hero);padding:var(--sp-2xl) 0;
  position:relative;overflow:hidden;
  min-height:clamp(480px,80vh,900px);
  display:flex;align-items:center;
}
/* Animated grid */
.hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(0,200,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(0,200,255,.03) 1px,transparent 1px);
  background-size:clamp(40px,5vw,70px) clamp(40px,5vw,70px);
  animation:gridScroll 25s linear infinite;
}
@keyframes gridScroll{from{background-position:0 0}to{background-position:60px 60px}}
/* Glow orbs */
.hero-orb-r{position:absolute;top:-20%;right:-10%;width:clamp(300px,50vw,700px);height:clamp(300px,50vw,700px);border-radius:50%;background:radial-gradient(circle,rgba(0,85,255,.1) 0%,transparent 70%);pointer-events:none}
.hero-orb-l{position:absolute;bottom:-20%;left:-10%;width:clamp(250px,40vw,600px);height:clamp(250px,40vw,600px);border-radius:50%;background:radial-gradient(circle,rgba(0,255,136,.07) 0%,transparent 70%);pointer-events:none}

.hero-grid{
  display:grid;
  grid-template-columns:1fr min(420px,40%);
  gap:clamp(24px,5vw,64px);
  align-items:center;
  position:relative;z-index:1;
}

/* Hero badge */
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,68,0,.12);border:1px solid rgba(255,68,0,.4);
  color:var(--c-fire);padding:6px 14px;border-radius:100px;
  font-size:var(--fs-xs);font-weight:800;letter-spacing:.1em;
  text-transform:uppercase;font-family:var(--f-mono);margin-bottom:16px;
}
.hero-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--c-fire);animation:livePulse 1.4s infinite}
@keyframes livePulse{0%,100%{box-shadow:0 0 0 0 rgba(255,68,0,.7)}50%{box-shadow:0 0 0 6px rgba(255,68,0,0)}}

.hero-title{font-size:var(--fs-4xl);color:#fff;margin-bottom:16px;line-height:1.08}
.hero-title .ln2{display:block;background:var(--g-cyan);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-title .ln3{display:block;font-size:.5em;color:rgba(255,255,255,.5);font-weight:500;letter-spacing:.01em;margin-top:10px;line-height:1.5;-webkit-text-fill-color:rgba(255,255,255,.5)}
.hero-desc{color:var(--c-muted);font-size:var(--fs-md);margin-bottom:28px;max-width:520px}

.hero-btns{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:36px}

/* Hero stats */
.hero-stats{display:flex;flex-wrap:wrap;gap:clamp(16px,3vw,32px)}
.h-stat .num{font-size:var(--fs-2xl);font-weight:900;color:#fff;font-family:var(--f-head);line-height:1}
.h-stat .lbl{font-size:var(--fs-xs);color:var(--c-dim);text-transform:uppercase;letter-spacing:.07em;font-family:var(--f-mono);margin-top:2px}

/* Hero search panel */
.hero-panel{
  background:rgba(13,31,56,.85);backdrop-filter:blur(20px);
  border:1px solid var(--c-border);border-radius:var(--r-xl);
  padding:clamp(20px,3vw,30px);
  box-shadow:var(--shadow-neon),var(--shadow-lg);
  position:relative;
}
.hero-panel::before{
  content:'';position:absolute;top:0;left:20px;right:20px;height:1px;
  background:var(--g-cyan);border-radius:0 0 4px 4px;
}
.hp-title{font-family:var(--f-head);font-weight:800;font-size:var(--fs-md);color:#fff;margin-bottom:4px}
.hp-sub{font-size:var(--fs-xs);color:var(--c-dim);margin-bottom:18px}
.hp-fields{display:flex;flex-direction:column;gap:10px}
.fp-label{font-size:var(--fs-xs);color:var(--c-dim);text-transform:uppercase;letter-spacing:.08em;font-family:var(--f-mono);font-weight:700;margin-bottom:5px;display:block}
.fp-input,.fp-select{
  width:100%;padding:12px 14px;background:rgba(255,255,255,.05);
  border:1px solid rgba(0,200,255,.15);border-radius:var(--r-sm);
  color:#fff;font-size:var(--fs-sm);transition:var(--tr);appearance:none;
  min-height:44px;
}
.fp-select option{background:var(--c-card);color:#fff}
.fp-input::placeholder{color:rgba(255,255,255,.22)}
.fp-input:focus,.fp-select:focus{outline:none;border-color:var(--c-cyan);background:rgba(0,200,255,.07);box-shadow:0 0 0 3px rgba(0,200,255,.1)}
.hp-live{
  margin-top:14px;padding:10px;
  background:rgba(0,255,136,.05);border:1px solid rgba(0,255,136,.15);
  border-radius:var(--r-sm);font-size:var(--fs-xs);color:var(--c-neon);
  text-align:center;display:flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--f-mono);
}
.live-dot{width:7px;height:7px;border-radius:50%;background:var(--c-neon);animation:livePulse 1.4s infinite}

/* ============================================================
   STATS BAR
   ============================================================ */
.stats-bar{background:var(--c-bg2);border-top:1px solid var(--c-border);border-bottom:1px solid var(--c-border)}
.stats-inner{display:grid;grid-template-columns:repeat(5,1fr)}
.stat-cell{
  padding:clamp(14px,3vw,24px) clamp(10px,2vw,20px);
  text-align:center;border-right:1px solid var(--c-border);
  transition:var(--tr);
}
.stat-cell:last-child{border-right:none}
.stat-cell:hover{background:rgba(0,200,255,.04)}
.stat-num{font-size:var(--fs-2xl);font-weight:900;line-height:1;font-family:var(--f-head);letter-spacing:-.03em}
.stat-lbl{font-size:var(--fs-xs);color:var(--c-dim);text-transform:uppercase;letter-spacing:.07em;font-family:var(--f-mono);margin-top:3px}
.n-fire  {background:var(--g-fire);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.n-cyan  {background:var(--g-cyan);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.n-neon  {color:var(--c-neon)}
.n-gold  {color:var(--c-gold)}
.n-purple{color:#a78bfa}

/* ============================================================
   AD ZONES
   ============================================================ */
.ad-wrap{padding:clamp(12px,2vw,20px) 0}
.ad-zone{
  background:rgba(13,31,56,.5);border:1px dashed rgba(0,200,255,.1);
  border-radius:var(--r-md);display:flex;align-items:center;
  justify-content:center;color:var(--c-dim);font-size:var(--fs-xs);
  text-transform:uppercase;letter-spacing:.06em;font-family:var(--f-mono);
}
.ad-leader{min-height:90px}
.ad-rect  {min-height:250px}
.ad-side  {min-height:200px}

/* ============================================================
   PROVIDER CARDS
   ============================================================ */
.cards-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(min(100%,310px),1fr));
  gap:clamp(14px,2.5vw,22px);
}

.pcard{
  background:var(--g-card);border:1px solid var(--c-border);
  border-radius:var(--r-lg);padding:clamp(16px,2.5vw,22px);
  position:relative;overflow:hidden;transition:var(--tr);
  display:flex;flex-direction:column;
}
.pcard::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--g-cyan);transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease);
}
.pcard:hover{
  transform:translateY(-5px);
  border-color:var(--c-border-h);
  box-shadow:var(--shadow-neon),0 24px 64px rgba(0,0,0,.45);
}
.pcard:hover::before{transform:scaleX(1)}

/* Rank 1 special */
.pcard.gold-card{border-color:rgba(255,215,0,.3)}
.pcard.gold-card::before{background:var(--g-gold)}
.pcard.gold-card:hover{box-shadow:var(--shadow-gold),0 24px 64px rgba(0,0,0,.45)}

/* Rank badge */
.rank-badge{
  position:absolute;top:14px;right:14px;
  min-width:30px;height:30px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:var(--fs-xs);font-weight:900;font-family:var(--f-head);
}
.rb-1{background:var(--g-gold);color:#000;box-shadow:var(--shadow-gold)}
.rb-2{background:linear-gradient(135deg,#aaa,#ddd);color:#000}
.rb-3{background:linear-gradient(135deg,#b87333,#e0a060);color:#000}
.rb-n{background:rgba(255,255,255,.07);color:var(--c-muted);border:1px solid var(--c-border)}

/* Card header */
.pc-head{display:flex;align-items:flex-start;gap:12px;margin-bottom:14px;padding-right:38px}
.pc-logo{
  width:50px;height:50px;flex-shrink:0;border-radius:var(--r-sm);
  background:var(--c-card2);border:1px solid var(--c-border);
  display:flex;align-items:center;justify-content:center;font-size:1.6rem;overflow:hidden;
}
.pc-logo img{width:100%;height:100%;object-fit:contain}
.pc-name{font-family:var(--f-head);font-weight:800;font-size:var(--fs-md);color:#fff;margin-bottom:3px;line-height:1.2}
.pc-loc{font-size:var(--fs-xs);color:var(--c-dim);display:flex;align-items:center;gap:4px}
.pc-score{margin-left:auto;text-align:right;flex-shrink:0}
.score-big{font-size:clamp(1.6rem,3vw,2rem);font-weight:900;line-height:1;font-family:var(--f-head)}
.score-stars{font-size:var(--fs-xs);color:var(--c-gold);margin-top:2px}
.s-neon{color:var(--c-neon);text-shadow:0 0 10px rgba(0,255,136,.3)}
.s-cyan{color:var(--c-cyan)}
.s-gold{color:var(--c-gold)}

/* Score bars */
.score-bars{display:flex;flex-direction:column;gap:7px;margin-bottom:14px}
.sb-row{display:flex;align-items:center;gap:8px}
.sb-lbl{font-size:var(--fs-xs);color:var(--c-dim);width:76px;flex-shrink:0;font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.04em}
.sb-track{flex:1;height:4px;background:rgba(255,255,255,.05);border-radius:2px;overflow:hidden}
.sb-fill{height:100%;border-radius:2px}
.sb-val{font-size:var(--fs-xs);font-weight:700;color:#fff;width:26px;text-align:right;font-family:var(--f-mono)}
.fill-cyan  {background:var(--g-cyan)}
.fill-neon  {background:var(--g-neon)}
.fill-gold  {background:var(--g-gold)}
.fill-fire  {background:var(--g-fire)}
.fill-purple{background:var(--g-purple)}

/* Chips */
.chips{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:14px}
.chip{
  padding:3px 9px;border-radius:100px;font-size:var(--fs-xs);
  font-weight:700;font-family:var(--f-mono);letter-spacing:.04em;
  text-transform:uppercase;
}
.ch-cyan  {background:rgba(0,200,255,.1); color:var(--c-cyan); border:1px solid rgba(0,200,255,.25)}
.ch-neon  {background:rgba(0,255,136,.1); color:var(--c-neon); border:1px solid rgba(0,255,136,.25)}
.ch-fire  {background:rgba(255,68,0,.12);  color:var(--c-fire); border:1px solid rgba(255,68,0,.3)}
.ch-gold  {background:rgba(255,215,0,.1); color:var(--c-gold); border:1px solid rgba(255,215,0,.25)}
.ch-muted {background:rgba(255,255,255,.05);color:var(--c-muted);border:1px solid rgba(255,255,255,.08)}
.ch-purple{background:rgba(124,58,237,.12);color:#a78bfa;border:1px solid rgba(124,58,237,.3)}

/* Price row */
.pc-price{
  display:flex;align-items:center;gap:8px;margin-bottom:14px;
  padding:10px;background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.05);border-radius:var(--r-sm);
}
.p-amt{font-size:var(--fs-xl);font-weight:900;color:#fff;font-family:var(--f-head)}
.p-per{font-size:var(--fs-xs);color:var(--c-dim)}
.p-save{margin-left:auto;background:rgba(0,255,136,.1);color:var(--c-neon);padding:3px 10px;border-radius:100px;font-size:var(--fs-xs);font-weight:800;border:1px solid rgba(0,255,136,.2);font-family:var(--f-mono)}

.pc-actions{display:flex;gap:8px;margin-top:auto}

/* ============================================================
   VPN CARDS
   ============================================================ */
.vpn-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,300px),1fr));gap:clamp(14px,2.5vw,22px)}
.vcard{
  background:var(--g-card);border:1px solid var(--c-border);
  border-radius:var(--r-lg);overflow:hidden;transition:var(--tr);
}
.vcard:hover{transform:translateY(-4px);border-color:rgba(124,58,237,.45);box-shadow:0 0 28px rgba(124,58,237,.18),var(--shadow-lg)}
.vc-head{
  padding:clamp(16px,2.5vw,22px);
  background:linear-gradient(135deg,rgba(124,58,237,.18),rgba(79,70,229,.08));
  border-bottom:1px solid var(--c-border);
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:10px;
}
.vc-logo-wrap{display:flex;align-items:center;gap:12px}
.vc-icon{width:46px;height:46px;border-radius:var(--r-sm);background:var(--g-purple);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}
.vc-name{font-family:var(--f-head);font-weight:800;color:#fff;font-size:var(--fs-md)}
.vc-sub {font-size:var(--fs-xs);color:var(--c-dim)}
.vc-badge{background:var(--g-purple);color:#fff;padding:6px 12px;border-radius:var(--r-sm);font-size:var(--fs-lg);font-weight:900;font-family:var(--f-head)}
.vc-body{padding:clamp(16px,2.5vw,20px)}
.vc-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.vc-metric{text-align:center;padding:10px 6px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);border-radius:var(--r-sm)}
.vc-metric .val{font-size:var(--fs-xl);font-weight:900;color:#fff;font-family:var(--f-head);line-height:1}
.vc-metric .key{font-size:var(--fs-xs);color:var(--c-dim);text-transform:uppercase;letter-spacing:.06em;font-family:var(--f-mono);margin-top:3px}
.vc-feats{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:14px}
.vc-feat{display:flex;align-items:center;gap:6px;font-size:var(--fs-xs);color:var(--c-muted)}
.v-tick{color:var(--c-neon);font-size:.75rem}
.v-cross{color:var(--c-danger);font-size:.75rem}
.vc-price-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.vc-price .val{font-size:var(--fs-xl);font-weight:900;color:#fff;font-family:var(--f-head)}
.vc-price .per{font-size:var(--fs-xs);color:var(--c-dim)}
.vc-off{background:rgba(0,255,136,.1);color:var(--c-neon);padding:4px 10px;border-radius:100px;font-size:var(--fs-xs);font-weight:800;border:1px solid rgba(0,255,136,.2);font-family:var(--f-mono)}
.vc-actions{display:flex;gap:8px}

/* ============================================================
   BLOG CARDS
   ============================================================ */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,290px),1fr));gap:clamp(14px,2.5vw,22px)}
.bcard{
  background:var(--g-card);border:1px solid var(--c-border);
  border-radius:var(--r-lg);overflow:hidden;transition:var(--tr);
  display:flex;flex-direction:column;
}
.bcard:hover{transform:translateY(-4px);border-color:var(--c-border-h);box-shadow:var(--shadow-neon),var(--shadow-lg)}
.bc-thumb{position:relative;overflow:hidden;height:clamp(150px,20vw,200px)}
.bc-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.bcard:hover .bc-thumb img{transform:scale(1.06)}
.bc-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--c-bg2),var(--c-card));display:flex;align-items:center;justify-content:center;font-size:2.5rem}
.bc-cat{
  position:absolute;top:12px;left:12px;
  padding:3px 10px;border-radius:100px;font-size:var(--fs-xs);
  font-weight:800;text-transform:uppercase;letter-spacing:.06em;
  font-family:var(--f-mono);backdrop-filter:blur(8px);
}
.bc-cat.iptv  {background:rgba(0,200,255,.2);color:var(--c-cyan);border:1px solid rgba(0,200,255,.4)}
.bc-cat.vpn   {background:rgba(124,58,237,.2);color:#a78bfa;border:1px solid rgba(124,58,237,.4)}
.bc-cat.review{background:rgba(255,215,0,.15);color:var(--c-gold);border:1px solid rgba(255,215,0,.3)}
.bc-cat.guide {background:rgba(0,255,136,.12);color:var(--c-neon);border:1px solid rgba(0,255,136,.3)}
.bc-cat.default{background:rgba(255,68,0,.15);color:var(--c-fire);border:1px solid rgba(255,68,0,.3)}
.bc-readtime{position:absolute;bottom:10px;right:10px;background:rgba(0,0,0,.7);color:rgba(255,255,255,.8);padding:3px 8px;border-radius:100px;font-size:var(--fs-xs);font-family:var(--f-mono);backdrop-filter:blur(8px)}

.bc-body{padding:clamp(14px,2.5vw,20px);flex:1;display:flex;flex-direction:column}
.bc-meta{display:flex;gap:12px;color:var(--c-dim);font-size:var(--fs-xs);font-family:var(--f-mono);margin-bottom:10px;flex-wrap:wrap}
.bc-meta span{display:flex;align-items:center;gap:4px}
.bc-title{font-size:var(--fs-md);font-weight:800;color:#fff;margin-bottom:8px;line-height:1.3;font-family:var(--f-head)}
.bc-title a{color:inherit}
.bc-title a:hover{color:var(--c-cyan)}
.bc-excerpt{color:var(--c-muted);font-size:var(--fs-sm);flex:1;margin-bottom:14px;line-height:1.6}
.bc-footer{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid var(--c-border)}
.bc-author{display:flex;align-items:center;gap:7px}
.bc-author img{width:24px;height:24px;border-radius:50%}
.bc-author span{font-size:var(--fs-xs);color:var(--c-muted);font-weight:600}
.bc-more{font-size:var(--fs-xs);font-weight:800;color:var(--c-cyan);font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.05em}
.bc-more:hover{color:#fff}

/* ============================================================
   COMPARISON TABLE — HORIZONTAL SCROLL ON MOBILE
   ============================================================ */
.tbl-wrap{overflow-x:auto;border-radius:var(--r-lg);border:1px solid var(--c-border);-webkit-overflow-scrolling:touch}
.cmp-tbl{width:100%;border-collapse:collapse;min-width:680px}
.cmp-tbl th{
  background:var(--c-card);padding:clamp(10px,1.5vw,14px) clamp(10px,1.5vw,16px);
  text-align:left;font-size:var(--fs-xs);font-weight:800;
  color:var(--c-dim);text-transform:uppercase;letter-spacing:.08em;
  font-family:var(--f-mono);border-bottom:1px solid var(--c-border);
  white-space:nowrap;
}
.cmp-tbl th:first-child{color:var(--c-cyan)}
.cmp-tbl td{
  padding:clamp(10px,1.5vw,14px) clamp(10px,1.5vw,16px);
  border-bottom:1px solid rgba(255,255,255,.04);
  font-size:var(--fs-sm);color:var(--c-muted);
  vertical-align:middle;
}
.cmp-tbl td:first-child{color:#fff;font-weight:700;white-space:nowrap}
.cmp-tbl tr:hover td{background:rgba(0,200,255,.02)}
.cmp-tbl tr:last-child td{border-bottom:none}
.tbl-scroll-hint{display:none;text-align:center;color:var(--c-dim);font-size:var(--fs-xs);padding:8px;font-family:var(--f-mono)}

/* ============================================================
   COUNTRY SEARCH SECTION
   ============================================================ */
.search-sec{
  background:var(--g-hero);padding:var(--sp-2xl) 0;
  border-top:1px solid var(--c-border);border-bottom:1px solid var(--c-border);
  position:relative;overflow:hidden;
}
.search-sec::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(0,200,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(0,200,255,.025) 1px,transparent 1px);
  background-size:45px 45px;
}
.search-card{
  background:rgba(13,31,56,.9);backdrop-filter:blur(20px);
  border:1px solid var(--c-border);border-radius:var(--r-xl);
  padding:clamp(20px,4vw,32px);box-shadow:var(--shadow-neon);
  position:relative;z-index:1;
}
.search-row{
  display:grid;
  grid-template-columns:1fr 1fr auto;
  gap:12px;align-items:end;margin-bottom:18px;
}
.sf-group label{display:block;font-size:var(--fs-xs);font-weight:700;color:var(--c-dim);text-transform:uppercase;letter-spacing:.09em;font-family:var(--f-mono);margin-bottom:6px}
.qtags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.qtag{
  background:rgba(255,255,255,.04);border:1px solid rgba(0,200,255,.12);
  color:var(--c-muted);padding:7px 14px;border-radius:100px;
  font-size:var(--fs-xs);font-weight:700;cursor:pointer;transition:var(--tr);
  font-family:var(--f-mono);min-height:36px;display:flex;align-items:center;
  -webkit-tap-highlight-color:transparent;
}
.qtag:hover,.qtag:active{background:rgba(0,200,255,.1);border-color:var(--c-cyan);color:var(--c-cyan)}

/* ============================================================
   TRUST CARDS
   ============================================================ */
.trust-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,220px),1fr));gap:clamp(14px,2.5vw,20px)}
.tcard{
  background:var(--g-card);border:1px solid var(--c-border);
  border-radius:var(--r-lg);padding:clamp(20px,3vw,28px);
  text-align:center;transition:var(--tr);
}
.tcard:hover{border-color:var(--c-border-h);transform:translateY(-4px)}
.t-icon{width:52px;height:52px;border-radius:var(--r-md);margin:0 auto 16px;display:flex;align-items:center;justify-content:center;font-size:1.3rem}
.tcard h4{color:#fff;font-size:var(--fs-md);margin-bottom:8px;font-family:var(--f-head)}
.tcard p{color:var(--c-dim);font-size:var(--fs-sm);margin:0;line-height:1.6}

/* ============================================================
   DEAL / CTA BANNER
   ============================================================ */
.deal-banner{
  background:linear-gradient(90deg,rgba(255,68,0,.12),rgba(255,140,0,.07));
  border:1px solid rgba(255,68,0,.28);border-radius:var(--r-md);
  padding:clamp(16px,3vw,20px) clamp(16px,3vw,22px);
  display:flex;align-items:center;gap:clamp(12px,2vw,18px);flex-wrap:wrap;
}
.deal-icon{font-size:clamp(1.3rem,3vw,2rem);flex-shrink:0}
.deal-content{flex:1;min-width:200px}
.deal-content strong{color:#fff;font-family:var(--f-head);font-weight:800;font-size:var(--fs-md);display:block;margin-bottom:4px}
.deal-content p{color:var(--c-muted);font-size:var(--fs-sm);margin:0}
.deal-actions{flex-shrink:0;display:flex;gap:8px;flex-wrap:wrap}

/* ============================================================
   SIGNUP PAGE — RESPONSIVE SPLIT
   ============================================================ */
.signup-layout{
  display:grid;grid-template-columns:1fr 1fr;min-height:calc(100vh - var(--hdr-h) - 32px);
}
.signup-left{
  background:var(--g-hero);padding:clamp(32px,6vw,72px) clamp(24px,5vw,64px);
  display:flex;flex-direction:column;justify-content:center;
  position:relative;overflow:hidden;
}
.signup-left::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(0,200,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(0,200,255,.035) 1px,transparent 1px);
  background-size:50px 50px;
}
.sl-content{position:relative;z-index:1}
.sl-content h1{font-size:clamp(1.8rem,4vw,3rem);margin-bottom:14px}
.sl-content p{color:var(--c-muted);font-size:var(--fs-md);margin-bottom:32px}
.benefit-list{display:flex;flex-direction:column;gap:16px}
.benefit-row{display:flex;align-items:flex-start;gap:14px}
.b-icon{width:38px;height:38px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.b-info h4{color:#fff;font-size:var(--fs-sm);font-weight:700;margin-bottom:2px}
.b-info p{color:var(--c-dim);font-size:var(--fs-xs);margin:0;line-height:1.5}

.signup-right{
  background:var(--c-bg2);padding:clamp(32px,6vw,72px) clamp(24px,5vw,56px);
  display:flex;align-items:center;justify-content:center;overflow-y:auto;
}
.su-form-wrap{width:100%;max-width:440px}
.su-form-wrap h2{font-size:clamp(1.5rem,3vw,2rem);margin-bottom:4px}
.su-form-wrap .sub{color:var(--c-muted);font-size:var(--fs-sm);margin-bottom:24px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-field{margin-bottom:14px}
.form-field label{display:block;font-size:var(--fs-xs);font-weight:700;color:var(--c-muted);text-transform:uppercase;letter-spacing:.07em;font-family:var(--f-mono);margin-bottom:6px}
.form-field input,.form-field select,.form-field textarea{
  width:100%;padding:12px 14px;
  background:rgba(255,255,255,.05);border:1px solid rgba(0,200,255,.12);
  border-radius:var(--r-sm);color:#fff;font-size:var(--fs-md);
  transition:var(--tr);appearance:none;min-height:44px;
}
.form-field input::placeholder{color:rgba(255,255,255,.2)}
.form-field input:focus,.form-field select:focus{outline:none;border-color:var(--c-cyan);background:rgba(0,200,255,.06);box-shadow:0 0 0 3px rgba(0,200,255,.1)}
.form-field select option{background:var(--c-card);color:#fff}
.chk-label{display:flex;align-items:flex-start;gap:10px;font-size:var(--fs-xs);color:var(--c-dim);cursor:pointer;line-height:1.5}
.chk-label input{margin-top:2px;accent-color:var(--c-cyan);min-width:16px}
.divider-or{text-align:center;position:relative;margin:18px 0;color:var(--c-dim);font-size:var(--fs-xs);font-family:var(--f-mono)}
.divider-or::before{content:'';position:absolute;top:50%;left:0;right:0;height:1px;background:var(--c-border)}
.divider-or span{background:var(--c-bg2);padding:0 12px;position:relative}
.social-btns{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.soc-btn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:11px;border:1px solid var(--c-border);border-radius:var(--r-sm);
  font-size:var(--fs-xs);font-weight:700;color:var(--c-muted);cursor:pointer;
  background:rgba(255,255,255,.03);transition:var(--tr);min-height:44px;
}
.soc-btn:hover{border-color:var(--c-border-h);color:#fff;background:rgba(255,255,255,.06)}
.form-note{text-align:center;font-size:var(--fs-xs);color:var(--c-dim);margin-top:16px}

/* ============================================================
   CONTENT + SIDEBAR LAYOUT
   ============================================================ */
.cs-layout{display:grid;grid-template-columns:1fr 290px;gap:clamp(20px,4vw,40px);align-items:start}
.sidebar{display:flex;flex-direction:column;gap:18px;position:sticky;top:calc(var(--hdr-h) + 16px)}
.sw{background:var(--g-card);border:1px solid var(--c-border);border-radius:var(--r-lg);padding:clamp(16px,2.5vw,22px)}
.sw-title{font-size:var(--fs-xs);font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--c-cyan);margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--c-border);font-family:var(--f-mono)}

/* ============================================================
   FOOTER
   ============================================================ */
#ftr{background:var(--c-bg);border-top:1px solid var(--c-border)}
.ftr-top{padding:clamp(40px,6vw,72px) 0 clamp(28px,4vw,48px)}
.ftr-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1.4fr;
  gap:clamp(24px,4vw,52px);
}
.ftr-desc{color:var(--c-dim);font-size:var(--fs-sm);line-height:1.8;margin:14px 0 20px;max-width:280px}
.socials{display:flex;gap:8px;flex-wrap:wrap}
.soc-link{
  width:34px;height:34px;border-radius:var(--r-sm);
  background:rgba(255,255,255,.05);border:1px solid var(--c-border);
  display:flex;align-items:center;justify-content:center;
  color:var(--c-dim);font-size:.85rem;transition:var(--tr);text-decoration:none;
}
.soc-link:hover{background:var(--c-blue);color:#fff;border-color:var(--c-blue)}
.ftr-col h4{font-size:var(--fs-xs);color:var(--c-cyan);font-weight:800;text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px;font-family:var(--f-mono)}
.ftr-links{display:flex;flex-direction:column;gap:9px}
.ftr-links a{color:var(--c-dim);font-size:var(--fs-sm);transition:var(--tr);display:flex;align-items:center;gap:6px}
.ftr-links a::before{content:'›';color:var(--c-border-h);transition:var(--tr)}
.ftr-links a:hover{color:var(--c-cyan);padding-left:4px}
.ftr-links a:hover::before{color:var(--c-cyan)}
.nl-desc{color:var(--c-dim);font-size:var(--fs-xs);margin-bottom:12px}
.nl-row{display:flex}
.nl-row input{
  flex:1;padding:10px 12px;background:rgba(255,255,255,.05);
  border:1px solid var(--c-border);border-right:none;
  border-radius:var(--r-sm) 0 0 var(--r-sm);color:#fff;font-size:var(--fs-xs);
  min-height:40px;
}
.nl-row input::placeholder{color:var(--c-dim)}
.nl-row input:focus{outline:none;border-color:var(--c-cyan)}
.nl-row button{
  padding:0 14px;background:var(--g-cyan);border:none;
  border-radius:0 var(--r-sm) var(--r-sm) 0;color:#000;
  font-weight:800;font-size:var(--fs-xs);cursor:pointer;font-family:var(--f-mono);
  letter-spacing:.05em;text-transform:uppercase;
}
.ftr-bottom{
  border-top:1px solid var(--c-border);padding:clamp(14px,2.5vw,20px) 0;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:12px;font-size:var(--fs-xs);color:var(--c-dim);
}
.ftr-btm-links{display:flex;gap:18px;flex-wrap:wrap}
.ftr-btm-links a{color:var(--c-dim);font-size:var(--fs-xs)}
.ftr-btm-links a:hover{color:var(--c-cyan)}

/* ============================================================
   MISC — BREADCRUMBS, PAGINATION, NOTICES
   ============================================================ */
.breadcrumbs{background:var(--c-bg2);padding:10px 0;border-bottom:1px solid var(--c-border)}
.breadcrumbs ul{display:flex;align-items:center;flex-wrap:wrap;gap:6px;font-size:var(--fs-xs);color:var(--c-dim);font-family:var(--f-mono)}
.breadcrumbs li::after{content:'/';margin-left:6px;color:var(--c-border-h)}
.breadcrumbs li:last-child::after{display:none}
.breadcrumbs a{color:var(--c-cyan)}

.pager{display:flex;justify-content:center;flex-wrap:wrap;gap:8px;margin-top:clamp(28px,5vw,52px)}
.pager a,.pager span{
  min-width:40px;height:40px;display:flex;align-items:center;justify-content:center;
  border-radius:var(--r-sm);border:1px solid var(--c-border);
  color:var(--c-muted);font-weight:700;font-size:var(--fs-xs);
  background:var(--g-card);font-family:var(--f-mono);padding:0 10px;
}
.pager a:hover,.pager .current{background:var(--c-blue);border-color:var(--c-blue);color:#fff}

.notice{padding:12px 16px;border-radius:var(--r-sm);display:flex;align-items:flex-start;gap:10px;font-size:var(--fs-sm);margin:14px 0;border-left:3px solid}
.n-info   {background:rgba(0,200,255,.07);border-color:var(--c-cyan);color:var(--c-text)}
.n-success{background:rgba(0,255,136,.07);border-color:var(--c-neon);color:var(--c-text)}
.n-warn   {background:rgba(255,171,0,.07);border-color:var(--c-warn);color:var(--c-text)}
.n-danger {background:rgba(255,34,68,.08); border-color:var(--c-danger);color:var(--c-text)}

/* ============================================================
   POST CONTENT STYLES
   ============================================================ */
.post-content{color:var(--c-muted);line-height:1.85;font-size:var(--fs-md)}
.post-content h2,.post-content h3,.post-content h4{color:#fff;margin:clamp(20px,4vw,32px) 0 12px}
.post-content h2{font-size:var(--fs-2xl);padding-bottom:10px;border-bottom:1px solid var(--c-border)}
.post-content h3{font-size:var(--fs-xl)}
.post-content p{margin-bottom:1rem}
.post-content a{color:var(--c-cyan);border-bottom:1px solid rgba(0,200,255,.3)}
.post-content a:hover{color:#fff;border-color:#fff}
.post-content ul,.post-content ol{padding-left:1.4rem;margin-bottom:1rem}
.post-content li{margin-bottom:5px}
.post-content blockquote{border-left:3px solid var(--c-cyan);padding:14px 18px;margin:20px 0;background:rgba(0,200,255,.05);border-radius:0 var(--r-sm) var(--r-sm) 0}
.post-content blockquote p{color:var(--c-text);margin:0;font-style:italic}
.post-content code{background:rgba(0,200,255,.1);color:var(--c-cyan);padding:2px 6px;border-radius:4px;font-family:var(--f-mono);font-size:.87em}
.post-content pre{background:var(--c-card);border:1px solid var(--c-border);border-radius:var(--r-md);padding:clamp(14px,2.5vw,20px);overflow-x:auto;margin-bottom:1rem}
.post-content table{width:100%;border-collapse:collapse;margin-bottom:1.4rem;overflow-x:auto;display:block}
.post-content th{background:var(--c-card);padding:10px 12px;text-align:left;font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--c-cyan);border-bottom:1px solid var(--c-border)}
.post-content td{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.04);color:var(--c-muted);font-size:var(--fs-sm)}

/* ============================================================
   ELEMENTOR
   ============================================================ */
.elementor-section{width:100%}
.elementor-container{max-width:1280px}
body.elementor-page .site-content{padding:0}

/* WP alignment classes */
.alignleft {float:left;margin-right:1.5rem;margin-bottom:1rem;max-width:50%}
.alignright{float:right;margin-left:1.5rem;margin-bottom:1rem;max-width:50%}
.aligncenter{display:block;margin:0 auto 1rem}
.alignwide {max-width:calc(100% + 80px);margin-left:-40px}
.alignfull {max-width:100vw;margin-left:calc(50% - 50vw)}
.wp-caption-text{font-size:var(--fs-xs);color:var(--c-dim);text-align:center;padding:6px 0}
.screen-reader-text{clip:rect(1px,1px,1px,1px);position:absolute;height:1px;width:1px;overflow:hidden}

/* ============================================================
   ★★★ RESPONSIVE BREAKPOINTS ★★★
   ============================================================ */

/* XL: 1400px+ — very wide screens */
@media (min-width:1400px){
  .wrap{max-width:1360px}
  .hero-grid{grid-template-columns:1fr min(480px,38%)}
}

/* LG: 1024–1200px — laptops */
@media (max-width:1200px){
  .ftr-grid{grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,36px)}
  .hero-grid{grid-template-columns:1fr min(380px,38%);gap:clamp(24px,4vw,44px)}
}

/* MD: 900–1024px — iPad Pro, small laptops */
@media (max-width:1024px){
  :root{--hdr-h:60px}
  .nav-links{display:none}
  .hamburger{display:flex}
  .cs-layout{grid-template-columns:1fr}
  .sidebar{position:static}
  .hero-grid{grid-template-columns:1fr}
  .hero-panel{display:none}  /* panel hidden on tablet — search in-page instead */
  .stats-inner{grid-template-columns:repeat(3,1fr)}
  .stat-cell:nth-child(4){border-top:1px solid var(--c-border)}
  .stat-cell:nth-child(5){border-top:1px solid var(--c-border);border-right:none}
  .ftr-grid{grid-template-columns:1fr 1fr}
  .signup-layout{grid-template-columns:1fr}
  .signup-left{display:none}
  .signup-right{min-height:auto;padding:clamp(32px,6vw,60px) clamp(20px,5vw,48px)}
}

/* SM: 640–900px — iPad, large phones landscape */
@media (max-width:900px){
  .search-row{grid-template-columns:1fr 1fr}
  .search-row .btn-search{grid-column:span 2}
  .ftr-grid{grid-template-columns:1fr 1fr}
  .tbl-scroll-hint{display:block}
  .form-row{grid-template-columns:1fr}
}

/* XS: 0–640px — phones */
@media (max-width:640px){
  :root{--hdr-h:56px}
  .ticker{height:28px}
  .ticker-lbl{padding:0 10px;font-size:.6rem}
  .ticker-track{font-size:.6rem}

  /* Logo: hide tagline on very small */
  .logo-tag{display:none}

  .hero{min-height:auto;padding:clamp(32px,8vw,60px) 0}
  .hero-badge{font-size:.6rem;padding:4px 10px}
  .hero-btns{flex-direction:column;gap:10px}
  .hero-btns .btn{width:100%;justify-content:center}
  .hero-stats{gap:clamp(12px,3vw,20px)}
  .h-stat .num{font-size:var(--fs-xl)}

  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .stat-cell:nth-child(5){grid-column:span 2;border-top:1px solid var(--c-border)}
  .stat-cell{border-right:none;border-bottom:1px solid var(--c-border)}
  .stat-cell:nth-child(2){border-right:1px solid var(--c-border)}
  .stat-cell:nth-child(4){border-right:1px solid var(--c-border)}

  .cards-grid,.vpn-grid,.blog-grid,.trust-grid{grid-template-columns:1fr}

  .search-row{grid-template-columns:1fr}
  .search-row .btn-search{grid-column:auto}

  .deal-banner{flex-direction:column;text-align:center}
  .deal-actions{justify-content:center}

  .ftr-grid{grid-template-columns:1fr}
  .ftr-bottom{flex-direction:column;text-align:center}
  .ftr-btm-links{justify-content:center}

  .hdr-actions .btn-sm:first-of-type{display:none} /* hide login on tiny */

  .pc-head{padding-right:36px}
  .score-big{font-size:1.5rem}

  .vc-metrics{grid-template-columns:repeat(3,1fr)}
  .vc-feats{grid-template-columns:1fr}

  .social-btns{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}

  .pager a,.pager span{min-width:36px;height:36px;font-size:.65rem}
}

/* Touch device: remove hover-only effects */
@media (hover:none){
  .pcard:hover,.bcard:hover,.vcard:hover,.tcard:hover{transform:none}
  .btn-cyan:hover,.btn-fire:hover,.btn-gold:hover{transform:none}
}

/* High DPI */
@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){
  .hero::before{background-size:40px 40px}
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
}

/* ============================================================
   EXTRA RESPONSIVE ADDITIONS
   ============================================================ */

/* Mobile search bar inside hero */
.mobile-search-bar{display:none}
@media(max-width:1024px){.mobile-search-bar{display:block}}
@media(min-width:1025px){.mobile-search-bar{display:none!important}}

/* Touch improvements */
@media(hover:none) and (pointer:coarse){
  .btn{min-height:48px}
  .nav-links a{min-height:44px}
  .fp-select,.fp-input{min-height:48px;font-size:16px} /* prevent iOS zoom */
  .qtag{min-height:44px;padding:0 16px}
  .soc-link{width:42px;height:42px}
}

/* iOS input zoom fix — inputs need 16px+ */
input[type="text"],input[type="email"],input[type="password"],
input[type="url"],input[type="search"],select,textarea{font-size:max(16px,var(--fs-md))}

/* Prevent horizontal scroll on all viewports */
html,body{overflow-x:hidden;max-width:100vw}
img{max-width:100%}

/* Hero panel: hide on ≤1024px */
@media(max-width:1024px){.hero-panel{display:none}}

/* Stats bar responsive */
@media(max-width:900px){
  .stats-inner{grid-template-columns:repeat(3,1fr)}
  .stat-cell:nth-child(4){border-top:1px solid var(--c-border);grid-column:auto}
  .stat-cell:nth-child(5){border-top:1px solid var(--c-border);grid-column:auto}
}
@media(max-width:640px){
  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .stat-cell{border-right:none!important;border-bottom:1px solid var(--c-border)}
  .stat-cell:nth-child(2n){border-right:none}
  /* Make odd cells have right border */
  .stat-cell:nth-child(odd){border-right:1px solid var(--c-border)!important}
}

/* Search section row on mobile */
@media(max-width:640px){
  .search-row{grid-template-columns:1fr!important}
  .search-row .btn-search{width:100%}
}

/* Footer grid */
@media(max-width:900px){
  .ftr-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:580px){
  .ftr-grid{grid-template-columns:1fr}
}

/* Provider card actions stack on tiny */
@media(max-width:360px){
  .pc-actions{flex-direction:column}
  .vc-actions{flex-direction:column}
}

/* Score bar label shorter on mobile */
@media(max-width:400px){
  .sb-lbl{width:58px;font-size:.6rem}
}

/* Deal banner stack */
@media(max-width:700px){
  .deal-banner{flex-direction:column;text-align:center}
  .deal-actions{justify-content:center;width:100%}
  .deal-actions .btn{flex:1}
}

/* Signup form on mobile */
@media(max-width:900px){
  .signup-layout{grid-template-columns:1fr}
  .signup-left{display:none}
  .signup-right{padding:clamp(24px,5vw,48px) clamp(16px,4vw,40px)}
}

/* Table horizontal scroll indicator */
.tbl-scroll-hint{
  display:none;text-align:center;padding:8px;
  color:var(--c-dim);font-size:var(--fs-xs);
  font-family:var(--f-mono);
}
@media(max-width:720px){.tbl-scroll-hint{display:block}}

/* VPN grid 1 col on small */
@media(max-width:540px){
  .vpn-grid{grid-template-columns:1fr}
  .vc-feats{grid-template-columns:1fr 1fr}
}

/* Blog grid */
@media(max-width:540px){
  .blog-grid,.cards-grid,.trust-grid{grid-template-columns:1fr}
}

/* Hero title line3 hidden on very small */
@media(max-width:380px){
  .hero-title .ln3{display:none}
}

/* wp-search-form responsive */
.wp-block-search__inside-wrapper,.search-form{display:flex;gap:8px}
.wp-block-search__input,.search-field input{
  flex:1;padding:11px 14px;background:rgba(255,255,255,.05);
  border:1px solid var(--c-border-h);border-radius:var(--r-sm);
  color:#fff;font-size:var(--fs-md);min-height:44px;
}
.wp-block-search__input:focus,.search-field input:focus{outline:none;border-color:var(--c-cyan)}
.wp-block-search__button,.search-submit{
  padding:0 18px;background:var(--g-cyan);border:none;
  border-radius:var(--r-sm);color:#000;font-weight:800;
  cursor:pointer;min-height:44px;font-size:var(--fs-sm);
}

/* Comments */
.comment-list{display:flex;flex-direction:column;gap:16px}
.comment-body{background:var(--c-card);border:1px solid var(--c-border);border-radius:var(--r-md);padding:clamp(14px,2.5vw,20px)}
.comment-author{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.comment-author img{border-radius:50%}
.comment-meta{font-size:var(--fs-xs);color:var(--c-dim);font-family:var(--f-mono)}
.comment-content p{color:var(--c-muted);font-size:var(--fs-sm)}
.comment-form input,.comment-form textarea{
  width:100%;padding:11px 14px;background:rgba(255,255,255,.05);
  border:1px solid var(--c-border-h);border-radius:var(--r-sm);
  color:#fff;margin-bottom:12px;font-size:var(--fs-md);min-height:44px;
}
.comment-form textarea{min-height:110px;resize:vertical}
.comment-form input:focus,.comment-form textarea:focus{outline:none;border-color:var(--c-cyan)}
.comment-form .submit{background:var(--g-fire);border:none;color:#fff;padding:12px 24px;border-radius:var(--r-sm);font-weight:800;cursor:pointer;font-size:var(--fs-sm)}
