/*
Theme Name: Luso IPTV
Theme URI: https://lusoiptv.com
Author: Luso IPTV
Author URI: https://lusoiptv.com
Description: Tema WordPress premium e otimizado para SEO, desenvolvido especificamente para Luso IPTV — IPTV Portugal. Design claro, moderno e orientado para conversão, com estrutura semântica HTML5, Schema.org JSON-LD e desempenho otimizado.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: lusoiptv
Tags: iptv, portugal, light, responsive, seo-friendly, custom-menu, featured-images, translation-ready
*/

/* =========================================================
   1. RESET & BASE
   ========================================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.65;
  color:var(--color-text);
  background:var(--color-bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:var(--color-primary);text-decoration:none;transition:color .2s ease}
a:hover{color:var(--color-accent)}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul,ol{list-style:none}
input,textarea,select{font-family:inherit;font-size:inherit}

/* =========================================================
   2. DESIGN TOKENS
   ========================================================= */
:root{
  /* Brand palette — Portuguese premium light theme */
  --color-primary:#0a3d62;       /* Deep ocean blue */
  --color-primary-dark:#072b47;
  --color-primary-light:#1e5a8a;
  --color-accent:#e84a5f;        /* Portuguese coral */
  --color-accent-dark:#c93a4c;
  --color-gold:#d4a857;          /* Azulejo gold */
  --color-success:#2a9d5f;

  --color-text:#1a2332;
  --color-text-muted:#5a6478;
  --color-text-light:#8a94a8;
  --color-bg:#fdfcfa;            /* Warm off-white */
  --color-surface:#ffffff;
  --color-surface-alt:#f5f2ec;   /* Warm cream */
  --color-border:#e8e3d9;
  --color-border-strong:#d4ccbe;

  /* Typography */
  --font-display:'Fraunces',Georgia,'Times New Roman',serif;
  --font-body:'Outfit',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;

  /* Spacing scale */
  --space-xs:.5rem;
  --space-sm:1rem;
  --space-md:1.5rem;
  --space-lg:2.5rem;
  --space-xl:4rem;
  --space-2xl:6rem;
  --space-3xl:8rem;

  /* Radius */
  --radius-sm:6px;
  --radius-md:12px;
  --radius-lg:20px;
  --radius-xl:32px;
  --radius-pill:999px;

  /* Shadows */
  --shadow-sm:0 1px 2px rgba(10,61,98,.06);
  --shadow-md:0 4px 16px rgba(10,61,98,.08);
  --shadow-lg:0 12px 40px rgba(10,61,98,.12);
  --shadow-xl:0 24px 60px rgba(10,61,98,.16);

  /* Layout */
  --container:1200px;
  --container-narrow:880px;
  --header-h:84px;

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

/* =========================================================
   3. TYPOGRAPHY
   ========================================================= */
h1,h2,h3,h4,h5,h6{
  font-family:var(--font-display);
  font-weight:600;
  line-height:1.15;
  color:var(--color-primary-dark);
  letter-spacing:-.02em;
}
h1{font-size:clamp(2.25rem,5vw,3.75rem);font-weight:700}
h2{font-size:clamp(1.875rem,3.8vw,2.75rem)}
h3{font-size:clamp(1.375rem,2.4vw,1.75rem)}
h4{font-size:1.25rem}
h5{font-size:1.125rem}
h6{font-size:1rem}
p{margin-bottom:var(--space-sm)}
.eyebrow{
  display:inline-block;
  font-family:var(--font-body);
  font-size:.8125rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--color-accent);
  margin-bottom:var(--space-sm);
}
.section-title{text-align:center;margin-bottom:var(--space-sm)}
.section-intro{
  text-align:center;
  max-width:680px;
  margin:0 auto var(--space-xl);
  color:var(--color-text-muted);
  font-size:1.0625rem;
}

/* =========================================================
   4. LAYOUT
   ========================================================= */
.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 var(--space-md);
}
.container-narrow{max-width:var(--container-narrow)}
.section{padding:var(--space-3xl) 0}
.section-sm{padding:var(--space-2xl) 0}
.section-alt{background:var(--color-surface-alt)}
.section-dark{background:var(--color-primary-dark);color:#fff}
.section-dark h1,.section-dark h2,.section-dark h3{color:#fff}
.grid{display:grid;gap:var(--space-md)}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.grid-4{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}

/* =========================================================
   5. BUTTONS
   ========================================================= */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  padding:.95rem 1.75rem;
  font-family:var(--font-body);
  font-size:1rem;
  font-weight:600;
  line-height:1;
  border-radius:var(--radius-pill);
  transition:all var(--t-base);
  cursor:pointer;
  white-space:nowrap;
  border:2px solid transparent;
}
.btn-primary{background:var(--color-accent);color:#fff;box-shadow:var(--shadow-md)}
.btn-primary:hover{background:var(--color-accent-dark);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-secondary{background:var(--color-primary);color:#fff}
.btn-secondary:hover{background:var(--color-primary-dark);color:#fff;transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--color-primary);border-color:var(--color-primary)}
.btn-outline:hover{background:var(--color-primary);color:#fff}
.btn-whatsapp{
  background:#25D366;color:#fff;
  box-shadow:0 6px 20px rgba(37,211,102,.3);
}
.btn-whatsapp:hover{background:#1faa54;color:#fff;transform:translateY(-2px);box-shadow:0 10px 30px rgba(37,211,102,.4)}
.btn-lg{padding:1.15rem 2.25rem;font-size:1.0625rem}
.btn-block{width:100%}

/* =========================================================
   6. HEADER
   ========================================================= */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(253,252,250,.92);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--color-border);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:var(--header-h);
  gap:var(--space-md);
}
.site-logo img{height:48px;width:auto}
.site-logo-text{
  font-family:var(--font-display);
  font-size:1.375rem;
  font-weight:700;
  color:var(--color-primary-dark);
}
.site-logo-text span{color:var(--color-accent)}
.main-nav{display:flex;align-items:center;gap:var(--space-lg)}
.main-nav ul{display:flex;gap:var(--space-md);align-items:center}
.main-nav a{
  color:var(--color-text);
  font-weight:500;
  font-size:.9375rem;
  position:relative;
  padding:.5rem 0;
}
.main-nav a::after{
  content:'';position:absolute;left:0;bottom:0;
  width:0;height:2px;background:var(--color-accent);
  transition:width var(--t-base);
}
.main-nav a:hover::after,.main-nav .current-menu-item a::after{width:100%}
.header-cta{display:flex;gap:.75rem;align-items:center}
.menu-toggle{display:none;flex-direction:column;gap:5px;padding:8px}
.menu-toggle span{width:26px;height:2px;background:var(--color-primary-dark);transition:var(--t-base)}

/* =========================================================
   7. HERO
   ========================================================= */
.hero{
  position:relative;
  padding:var(--space-3xl) 0 var(--space-2xl);
  background:linear-gradient(135deg,#fdfcfa 0%,#f5f2ec 60%,#ece5d3 100%);
  overflow:hidden;
}
.hero::before{
  content:'';position:absolute;top:-20%;right:-10%;
  width:600px;height:600px;
  background:radial-gradient(circle,rgba(232,74,95,.08),transparent 70%);
  border-radius:50%;
}
.hero::after{
  content:'';position:absolute;bottom:-30%;left:-15%;
  width:700px;height:700px;
  background:radial-gradient(circle,rgba(10,61,98,.06),transparent 70%);
  border-radius:50%;
}
.hero-inner{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--space-xl);
  align-items:center;
  position:relative;
  z-index:1;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.5rem 1rem;
  background:rgba(232,74,95,.1);
  color:var(--color-accent-dark);
  border-radius:var(--radius-pill);
  font-size:.8125rem;
  font-weight:600;
  margin-bottom:var(--space-md);
}
.hero-badge::before{
  content:'';width:8px;height:8px;border-radius:50%;
  background:var(--color-accent);
  animation:pulse 2s infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
.hero h1{margin-bottom:var(--space-md)}
.hero h1 em{font-style:italic;color:var(--color-accent);font-family:var(--font-display)}
.hero-lead{font-size:1.1875rem;color:var(--color-text-muted);margin-bottom:var(--space-lg);max-width:540px}
.hero-ctas{display:flex;gap:var(--space-sm);flex-wrap:wrap;margin-bottom:var(--space-lg)}
.hero-trust{display:flex;gap:var(--space-md);flex-wrap:wrap;align-items:center;font-size:.875rem;color:var(--color-text-muted)}
.hero-trust-item{display:flex;align-items:center;gap:.5rem}
.hero-trust-item svg{width:18px;height:18px;color:var(--color-success)}
.hero-visual{position:relative}
.hero-visual img{border-radius:var(--radius-lg);box-shadow:var(--shadow-xl)}
.hero-floating{
  position:absolute;
  background:#fff;
  padding:var(--space-sm);
  border-radius:var(--radius-md);
  box-shadow:var(--shadow-lg);
  display:flex;align-items:center;gap:.75rem;
}
.hero-floating-1{top:10%;left:-30px;animation:float 4s ease-in-out infinite}
.hero-floating-2{bottom:15%;right:-20px;animation:float 4s ease-in-out infinite .8s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.hero-floating-icon{
  width:40px;height:40px;border-radius:50%;
  background:var(--color-surface-alt);
  display:grid;place-items:center;color:var(--color-accent);
}
.hero-floating-label{font-size:.75rem;color:var(--color-text-muted)}
.hero-floating-value{font-weight:600;color:var(--color-primary-dark)}

/* =========================================================
   8. PRICING
   ========================================================= */
.pricing-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:var(--space-md);
  max-width:1100px;
  margin:0 auto;
}
.pricing-card{
  background:var(--color-surface);
  border-radius:var(--radius-lg);
  padding:var(--space-lg);
  border:2px solid var(--color-border);
  transition:all var(--t-base);
  position:relative;
  display:flex;flex-direction:column;
}
.pricing-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--color-primary-light)}
.pricing-card.featured{
  border-color:var(--color-accent);
  background:linear-gradient(180deg,#fff,#fff9f9);
  box-shadow:var(--shadow-lg);
  transform:scale(1.03);
}
.pricing-badge{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:var(--color-accent);color:#fff;
  padding:.35rem 1rem;border-radius:var(--radius-pill);
  font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
}
.pricing-name{
  font-family:var(--font-display);
  font-size:1.375rem;font-weight:600;
  color:var(--color-primary-dark);
  margin-bottom:.5rem;
}
.pricing-desc{color:var(--color-text-muted);font-size:.9375rem;margin-bottom:var(--space-md)}
.pricing-price{
  display:flex;align-items:baseline;gap:.3rem;
  margin-bottom:var(--space-md);
  padding-bottom:var(--space-md);
  border-bottom:1px solid var(--color-border);
}
.pricing-currency{font-size:1.5rem;color:var(--color-text-muted);font-weight:500}
.pricing-amount{font-family:var(--font-display);font-size:3rem;font-weight:700;color:var(--color-primary-dark);line-height:1}
.pricing-period{color:var(--color-text-muted);font-size:.9375rem}
.pricing-features{margin-bottom:var(--space-md);flex-grow:1}
.pricing-features li{
  padding:.6rem 0;
  padding-left:1.75rem;
  position:relative;
  font-size:.9375rem;
  color:var(--color-text);
  border-bottom:1px solid var(--color-border);
}
.pricing-features li:last-child{border-bottom:none}
.pricing-features li::before{
  content:'';
  position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:18px;height:18px;border-radius:50%;
  background:var(--color-success);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/></svg>") center/70% no-repeat;
  mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/></svg>") center/70% no-repeat;
}

/* =========================================================
   9. FEATURE CARDS
   ========================================================= */
.feature-card{
  background:var(--color-surface);
  padding:var(--space-lg);
  border-radius:var(--radius-lg);
  border:1px solid var(--color-border);
  transition:all var(--t-base);
  height:100%;
}
.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--color-primary-light)}
.feature-icon{
  width:56px;height:56px;
  border-radius:var(--radius-md);
  background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));
  color:#fff;
  display:grid;place-items:center;
  margin-bottom:var(--space-sm);
  font-size:1.5rem;
}
.feature-icon.accent{background:linear-gradient(135deg,var(--color-accent),var(--color-accent-dark))}
.feature-card h3{font-size:1.25rem;margin-bottom:.5rem}
.feature-card p{color:var(--color-text-muted);font-size:.9375rem;margin:0}

/* =========================================================
   10. STEPS
   ========================================================= */
.steps-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:var(--space-md);
  position:relative;
}
.step-card{
  position:relative;
  padding:var(--space-lg);
  background:var(--color-surface);
  border-radius:var(--radius-lg);
  border:1px solid var(--color-border);
}
.step-number{
  font-family:var(--font-display);
  font-size:3.5rem;
  font-weight:700;
  line-height:1;
  color:var(--color-accent);
  opacity:.25;
  margin-bottom:.5rem;
}
.step-card h3{font-size:1.25rem;margin-bottom:.5rem}
.step-card p{color:var(--color-text-muted);font-size:.9375rem;margin:0}

/* =========================================================
   11. STATS
   ========================================================= */
.stats-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:var(--space-lg);
  text-align:center;
}
.stat-value{
  font-family:var(--font-display);
  font-size:clamp(2.5rem,4vw,3.5rem);
  font-weight:700;
  color:var(--color-accent);
  line-height:1;
  display:block;
}
.section-dark .stat-value{color:var(--color-gold)}
.stat-label{
  font-size:.9375rem;
  color:var(--color-text-muted);
  margin-top:.5rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:500;
}
.section-dark .stat-label{color:rgba(255,255,255,.75)}

/* =========================================================
   12. TESTIMONIALS
   ========================================================= */
.testimonial-card{
  background:var(--color-surface);
  padding:var(--space-lg);
  border-radius:var(--radius-lg);
  border:1px solid var(--color-border);
  position:relative;
  height:100%;
}
.testimonial-card::before{
  content:'"';
  position:absolute;top:10px;right:20px;
  font-family:var(--font-display);
  font-size:5rem;
  color:var(--color-accent);
  opacity:.15;
  line-height:1;
}
.testimonial-stars{color:var(--color-gold);margin-bottom:.75rem;font-size:1.125rem}
.testimonial-text{
  font-size:1rem;
  color:var(--color-text);
  margin-bottom:var(--space-md);
  font-style:italic;
}
.testimonial-author{display:flex;align-items:center;gap:.75rem}
.testimonial-avatar{
  width:48px;height:48px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--color-primary),var(--color-accent));
  color:#fff;
  display:grid;place-items:center;
  font-weight:600;
  font-family:var(--font-display);
}
.testimonial-name{font-weight:600;color:var(--color-primary-dark)}
.testimonial-role{font-size:.8125rem;color:var(--color-text-muted)}

/* =========================================================
   13. DEVICES (ICON ROW)
   ========================================================= */
.devices-row{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:var(--space-md);
  text-align:center;
}
.device-item{
  padding:var(--space-md);
  background:var(--color-surface);
  border-radius:var(--radius-md);
  border:1px solid var(--color-border);
  transition:all var(--t-base);
}
.device-item:hover{transform:translateY(-3px);border-color:var(--color-accent);box-shadow:var(--shadow-sm)}
.device-icon{
  font-size:2.25rem;
  color:var(--color-primary);
  margin-bottom:.5rem;
}
.device-name{font-weight:600;font-size:.9375rem;color:var(--color-primary-dark)}

/* =========================================================
   14. CHANNEL SHOWCASE
   ========================================================= */
.channels-showcase{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--space-xl);
  align-items:center;
}
.channels-media img{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}
.channel-category-list{display:grid;gap:.75rem}
.channel-category{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:var(--space-sm) var(--space-md);
  background:var(--color-surface);
  border-radius:var(--radius-md);
  border:1px solid var(--color-border);
  transition:all var(--t-fast);
}
.channel-category:hover{border-color:var(--color-accent);transform:translateX(4px)}
.channel-category-name{font-weight:600;color:var(--color-primary-dark)}
.channel-category-count{
  background:var(--color-surface-alt);
  padding:.25rem .75rem;
  border-radius:var(--radius-pill);
  font-size:.8125rem;
  font-weight:600;
  color:var(--color-primary);
}

/* =========================================================
   15. FAQ / ACCORDION
   ========================================================= */
.faq-list{max-width:780px;margin:0 auto;display:grid;gap:.75rem}
.faq-item{
  background:var(--color-surface);
  border-radius:var(--radius-md);
  border:1px solid var(--color-border);
  overflow:hidden;
  transition:all var(--t-base);
}
.faq-item[open]{border-color:var(--color-primary-light);box-shadow:var(--shadow-sm)}
.faq-question{
  padding:var(--space-md);
  font-family:var(--font-display);
  font-weight:600;
  font-size:1.0625rem;
  color:var(--color-primary-dark);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  list-style:none;
  gap:var(--space-sm);
}
.faq-question::-webkit-details-marker{display:none}
.faq-question::after{
  content:'+';
  font-size:1.75rem;
  color:var(--color-accent);
  transition:transform var(--t-base);
  font-weight:300;
  line-height:1;
}
.faq-item[open] .faq-question::after{transform:rotate(45deg)}
.faq-answer{
  padding:0 var(--space-md) var(--space-md);
  color:var(--color-text-muted);
  line-height:1.7;
}

/* =========================================================
   16. CTA BANNER
   ========================================================= */
.cta-banner{
  background:linear-gradient(135deg,var(--color-primary-dark) 0%,var(--color-primary) 100%);
  color:#fff;
  padding:var(--space-2xl) var(--space-lg);
  border-radius:var(--radius-xl);
  text-align:center;
  position:relative;
  overflow:hidden;
  margin:var(--space-xl) auto;
  max-width:1100px;
}
.cta-banner::before{
  content:'';position:absolute;top:-50%;right:-10%;width:400px;height:400px;
  background:radial-gradient(circle,rgba(232,74,95,.3),transparent 70%);
  border-radius:50%;
}
.cta-banner::after{
  content:'';position:absolute;bottom:-50%;left:-10%;width:500px;height:500px;
  background:radial-gradient(circle,rgba(212,168,87,.2),transparent 70%);
  border-radius:50%;
}
.cta-banner-inner{position:relative;z-index:1}
.cta-banner h2{color:#fff;margin-bottom:var(--space-sm)}
.cta-banner p{color:rgba(255,255,255,.85);font-size:1.125rem;max-width:560px;margin:0 auto var(--space-lg)}

/* =========================================================
   17. COMPARISON TABLE
   ========================================================= */
.compare-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  background:var(--color-surface);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.compare-table th,.compare-table td{
  padding:var(--space-sm) var(--space-md);
  text-align:left;
  border-bottom:1px solid var(--color-border);
}
.compare-table th{
  background:var(--color-primary-dark);
  color:#fff;
  font-family:var(--font-display);
  font-weight:600;
  font-size:1rem;
}
.compare-table th.highlight{background:var(--color-accent)}
.compare-table td.check{color:var(--color-success);font-weight:700}
.compare-table td.cross{color:var(--color-text-light)}
.compare-table tr:last-child td{border-bottom:none}
.compare-wrap{overflow-x:auto}

/* =========================================================
   18. PAGE HEADER
   ========================================================= */
.page-header{
  background:linear-gradient(135deg,var(--color-surface-alt),#ece5d3);
  padding:var(--space-xl) 0 var(--space-xl);
  text-align:center;
  border-bottom:1px solid var(--color-border);
  position:relative;
  overflow:hidden;
}
.page-header::before{
  content:'';position:absolute;top:-40%;left:-10%;width:500px;height:500px;
  background:radial-gradient(circle,rgba(232,74,95,.08),transparent 70%);
  border-radius:50%;
}
.page-header-inner{position:relative;z-index:1}
.breadcrumbs{
  font-size:.875rem;
  color:var(--color-text-muted);
  margin-bottom:var(--space-sm);
}
.breadcrumbs a{color:var(--color-text-muted)}
.breadcrumbs a:hover{color:var(--color-accent)}
.breadcrumbs span{margin:0 .5rem;opacity:.5}

/* =========================================================
   19. CONTACT PAGE
   ========================================================= */
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1.4fr;
  gap:var(--space-xl);
}
.contact-info-card{
  background:var(--color-surface);
  padding:var(--space-lg);
  border-radius:var(--radius-lg);
  border:1px solid var(--color-border);
  margin-bottom:var(--space-sm);
}
.contact-info-icon{
  width:44px;height:44px;
  border-radius:var(--radius-sm);
  background:rgba(232,74,95,.1);
  color:var(--color-accent);
  display:grid;place-items:center;
  margin-bottom:.75rem;
  font-size:1.125rem;
}
.contact-info-label{font-size:.8125rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin-bottom:.25rem;font-weight:600}
.contact-info-value{font-size:1.0625rem;font-weight:600;color:var(--color-primary-dark)}
.contact-info-value a{color:inherit}
.contact-form-wrap{
  background:var(--color-surface);
  padding:var(--space-lg);
  border-radius:var(--radius-lg);
  border:1px solid var(--color-border);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm);margin-bottom:var(--space-sm)}
.form-group{margin-bottom:var(--space-sm)}
.form-group label{display:block;font-weight:600;font-size:.9375rem;margin-bottom:.4rem;color:var(--color-primary-dark)}
.form-control{
  width:100%;
  padding:.85rem 1rem;
  border:1.5px solid var(--color-border);
  border-radius:var(--radius-sm);
  background:var(--color-bg);
  transition:all var(--t-fast);
  font-size:1rem;
}
.form-control:focus{outline:none;border-color:var(--color-accent);background:#fff;box-shadow:0 0 0 3px rgba(232,74,95,.1)}
textarea.form-control{min-height:140px;resize:vertical}

/* =========================================================
   20. BLOG
   ========================================================= */
.blog-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:var(--space-lg);
}
.post-card{
  background:var(--color-surface);
  border-radius:var(--radius-lg);
  overflow:hidden;
  border:1px solid var(--color-border);
  transition:all var(--t-base);
  display:flex;flex-direction:column;
  height:100%;
}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-primary-light)}
.post-card-media{aspect-ratio:16/9;overflow:hidden;background:var(--color-surface-alt)}
.post-card-media img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow)}
.post-card:hover .post-card-media img{transform:scale(1.06)}
.post-card-body{padding:var(--space-md);display:flex;flex-direction:column;flex-grow:1}
.post-card-meta{
  display:flex;gap:var(--space-sm);
  font-size:.8125rem;
  color:var(--color-text-muted);
  margin-bottom:.5rem;
  text-transform:uppercase;
  letter-spacing:.06em;
  font-weight:500;
}
.post-card h3{font-size:1.25rem;margin-bottom:.5rem;line-height:1.3}
.post-card h3 a{color:var(--color-primary-dark)}
.post-card h3 a:hover{color:var(--color-accent)}
.post-card-excerpt{color:var(--color-text-muted);font-size:.9375rem;margin-bottom:var(--space-sm);flex-grow:1}
.post-card-more{
  color:var(--color-accent);
  font-weight:600;
  font-size:.9375rem;
  display:inline-flex;align-items:center;gap:.25rem;
  margin-top:auto;
}
.post-card-more::after{content:'→';transition:transform var(--t-fast)}
.post-card-more:hover::after{transform:translateX(4px)}

/* Single post */
.single-post-wrap{max-width:780px;margin:0 auto;padding:var(--space-xl) 0}
.single-post-meta{
  display:flex;gap:var(--space-sm);
  font-size:.875rem;color:var(--color-text-muted);
  margin-bottom:var(--space-md);
  align-items:center;flex-wrap:wrap;
}
.single-post-meta .sep{opacity:.4}
.single-post-title{margin-bottom:var(--space-md)}
.single-post-featured{margin-bottom:var(--space-lg);border-radius:var(--radius-lg);overflow:hidden}
.post-content{font-size:1.0625rem;line-height:1.8;color:var(--color-text)}
.post-content h2{margin:var(--space-lg) 0 var(--space-sm);font-size:1.875rem}
.post-content h3{margin:var(--space-md) 0 .75rem;font-size:1.375rem}
.post-content p{margin-bottom:var(--space-sm)}
.post-content ul,.post-content ol{margin:var(--space-sm) 0 var(--space-sm) 1.5rem}
.post-content li{margin-bottom:.5rem;list-style:disc}
.post-content ol li{list-style:decimal}
.post-content blockquote{
  padding:var(--space-md) var(--space-lg);
  border-left:4px solid var(--color-accent);
  background:var(--color-surface-alt);
  margin:var(--space-md) 0;
  font-style:italic;
  border-radius:0 var(--radius-md) var(--radius-md) 0;
}
.post-content a{color:var(--color-accent);text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px}
.post-content img{border-radius:var(--radius-md);margin:var(--space-sm) 0}

/* Pagination */
.pagination{display:flex;justify-content:center;gap:.5rem;margin-top:var(--space-xl);flex-wrap:wrap}
.pagination a,.pagination span{
  display:grid;place-items:center;
  min-width:44px;height:44px;padding:0 .75rem;
  border-radius:var(--radius-sm);
  background:var(--color-surface);
  border:1px solid var(--color-border);
  color:var(--color-text);
  font-weight:600;
  transition:var(--t-fast);
}
.pagination a:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}
.pagination .current{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}

/* =========================================================
   21. LEGAL / LONG-FORM
   ========================================================= */
.legal-wrap{max-width:820px;margin:0 auto;padding:var(--space-xl) 0}
.legal-wrap h2{margin-top:var(--space-lg);margin-bottom:var(--space-sm);font-size:1.5rem;color:var(--color-primary-dark)}
.legal-wrap h3{margin-top:var(--space-md);margin-bottom:.5rem;font-size:1.1875rem}
.legal-wrap p,.legal-wrap li{color:var(--color-text);line-height:1.8;font-size:1rem}
.legal-wrap ul,.legal-wrap ol{margin:var(--space-sm) 0 var(--space-sm) 1.5rem}
.legal-wrap li{list-style:disc;margin-bottom:.4rem}
.legal-updated{
  font-size:.875rem;
  color:var(--color-text-muted);
  margin-bottom:var(--space-lg);
  padding:.5rem 1rem;
  background:var(--color-surface-alt);
  border-radius:var(--radius-sm);
  display:inline-block;
}

/* =========================================================
   22. FOOTER
   ========================================================= */
.site-footer{
  background:var(--color-primary-dark);
  color:rgba(255,255,255,.8);
  padding:var(--space-2xl) 0 var(--space-md);
  margin-top:var(--space-2xl);
}
.footer-grid{
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:var(--space-lg);
  margin-bottom:var(--space-xl);
}
.footer-about .site-logo-text,.footer-about .site-logo-text span{color:#fff}
.footer-about .site-logo-text span{color:var(--color-gold)}
.footer-about p{color:rgba(255,255,255,.7);font-size:.9375rem;margin-top:.75rem}
.footer-heading{
  color:#fff;
  font-family:var(--font-display);
  font-size:1.0625rem;
  margin-bottom:var(--space-sm);
}
.footer-links li{margin-bottom:.6rem}
.footer-links a{color:rgba(255,255,255,.7);font-size:.9375rem}
.footer-links a:hover{color:var(--color-gold)}
.footer-contact-item{
  display:flex;gap:.75rem;align-items:flex-start;
  margin-bottom:.75rem;font-size:.9375rem;
  color:rgba(255,255,255,.8);
}
.footer-contact-item svg{flex-shrink:0;margin-top:3px;color:var(--color-gold)}
.footer-contact-item a{color:inherit}
.footer-contact-item a:hover{color:var(--color-gold)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:var(--space-md);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-sm);
  font-size:.875rem;color:rgba(255,255,255,.6);
}
.footer-bottom a{color:rgba(255,255,255,.7)}
.footer-bottom a:hover{color:var(--color-gold)}

/* =========================================================
   23. WHATSAPP FLOAT
   ========================================================= */
.whatsapp-float{
  position:fixed;
  right:24px;bottom:24px;
  width:60px;height:60px;
  background:#25D366;
  border-radius:50%;
  display:grid;place-items:center;
  color:#fff;
  box-shadow:0 10px 30px rgba(37,211,102,.4);
  z-index:90;
  animation:pulse-shadow 2.5s infinite;
  transition:transform var(--t-base);
}
.whatsapp-float:hover{transform:scale(1.1);color:#fff}
.whatsapp-float svg{width:32px;height:32px}
@keyframes pulse-shadow{
  0%,100%{box-shadow:0 10px 30px rgba(37,211,102,.4)}
  50%{box-shadow:0 10px 40px rgba(37,211,102,.7)}
}

/* =========================================================
   24. UTILITIES
   ========================================================= */
.text-center{text-align:center}
.mb-sm{margin-bottom:var(--space-sm)}
.mb-md{margin-bottom:var(--space-md)}
.mb-lg{margin-bottom:var(--space-lg)}
.mt-lg{margin-top:var(--space-lg)}

/* =========================================================
   25. RESPONSIVE
   ========================================================= */
@media (max-width:980px){
  :root{--header-h:72px}
  .hero-inner,.channels-showcase,.contact-grid{grid-template-columns:1fr;gap:var(--space-lg)}
  .hero-visual{order:-1;max-width:480px;margin:0 auto}
  .hero-floating{display:none}
  .footer-grid{grid-template-columns:1fr 1fr;gap:var(--space-md)}
  .pricing-card.featured{transform:none}
  .section{padding:var(--space-2xl) 0}
}
@media (max-width:760px){
  .main-nav{
    position:fixed;
    top:var(--header-h);left:0;right:0;
    background:var(--color-surface);
    flex-direction:column;
    align-items:stretch;
    gap:0;
    padding:var(--space-md);
    border-top:1px solid var(--color-border);
    box-shadow:var(--shadow-md);
    transform:translateY(-120%);
    transition:transform var(--t-base);
    z-index:99;
  }
  .main-nav.is-open{transform:translateY(0)}
  .main-nav ul{flex-direction:column;gap:0;width:100%}
  .main-nav li{width:100%;border-bottom:1px solid var(--color-border)}
  .main-nav li:last-child{border-bottom:none}
  .main-nav a{padding:.85rem 0;display:block;width:100%}
  .header-cta .btn-outline{display:none}
  .menu-toggle{display:flex}
  .hero{padding:var(--space-xl) 0}
  .hero-ctas{flex-direction:column}
  .hero-ctas .btn{width:100%}
  .footer-grid{grid-template-columns:1fr;text-align:left}
  .footer-bottom{flex-direction:column;text-align:center}
  .form-row{grid-template-columns:1fr}
  .page-header{padding:var(--space-lg) 0}
  .cta-banner{padding:var(--space-xl) var(--space-md);border-radius:var(--radius-lg)}
  .whatsapp-float{width:54px;height:54px;right:16px;bottom:16px}
}
@media (max-width:480px){
  .pricing-card{padding:var(--space-md)}
  .section{padding:var(--space-xl) 0}
}

/* Print & reduced motion */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}
