/* ============================================================
   TeteServ — Design System
   A vitrine digital da Província de Tete
   ============================================================ */

/* ====== RESET ====== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Sora',system-ui,-apple-system,sans-serif;
  color:var(--fg);background:var(--bg);
  line-height:1.65;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none;transition:color .15s}
img{max-width:100%;display:block}
ul,ol{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font-family:inherit}
h1,h2,h3,h4,h5,h6{
  font-family:'Fraunces',Georgia,serif;
  letter-spacing:-0.02em;line-height:1.05;
  font-weight:700;color:var(--fg);
}

/* ====== TOKENS ====== */
:root{
  --brand-orange:#FF6600;
  --brand-orange-light:#FF8A33;
  --brand-orange-soft:#FFF3EB;
  --brand-green:#93BC0A;
  --brand-green-dark:#7a9d08;
  --brand-green-soft:#F0F7D4;
  --brand-navy:#182E4E;
  --brand-navy-light:#2a4570;
  --brand-cream:#FAFAF7;
  --bg:#FCFCFA;
  --bg-soft:#F4F2EC;
  --fg:#111418;
  --fg-soft:#374151;
  --muted:#6B7280;
  --muted-light:#9CA3AF;
  --border:#E6E4DE;
  --border-soft:#EFEDE6;
  --card:#FFFFFF;
  --radius:.625rem;
  --radius-lg:1rem;
  --radius-pill:999px;
  --shadow-sm:0 2px 8px rgba(0,0,0,.04);
  --shadow-cta:0 14px 40px -12px rgba(255,102,0,.4);
  --shadow-card:0 12px 40px -16px rgba(0,0,0,.18);
  --shadow-deep:0 30px 80px -30px rgba(24,46,78,.4);
}

::selection{background:var(--brand-orange);color:#fff}

/* ====== UTILITIES ====== */
.container{max-width:1200px;margin:0 auto;padding:0 20px}
section{padding:96px 0}
.eyebrow{
  display:inline-block;
  font-size:11px;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--brand-orange);
}
.eyebrow.is-light{color:var(--brand-green)}
.section-title{font-size:clamp(2rem,4vw,3rem);margin-top:14px;max-width:760px}
.section-lede{margin-top:16px;color:var(--muted);font-size:17px;max-width:640px;line-height:1.6}

/* ====== BUTTONS ====== */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 28px;border-radius:var(--radius-pill);
  font-weight:600;font-size:14px;
  transition:transform .2s,box-shadow .2s,background .2s,color .2s,border-color .2s;
  cursor:pointer;line-height:1;
}
.btn-primary{
  background:linear-gradient(90deg,var(--brand-orange),var(--brand-orange-light));
  color:#fff;box-shadow:var(--shadow-cta);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 50px -12px rgba(255,102,0,.5)}
.btn-ghost{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.3);
  color:#fff;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.btn-ghost:hover{background:rgba(255,255,255,.18);transform:translateY(-2px)}
.btn-outline{
  background:transparent;color:var(--brand-navy);
  border:1.5px solid var(--brand-navy);
}
.btn-outline:hover{background:var(--brand-navy);color:#fff;transform:translateY(-2px)}
.btn-wa{
  background:#25D366;color:#fff;
  width:100%;justify-content:center;padding:14px 24px;
  font-size:15px;
}
.btn-wa:hover{background:#1dab54;transform:translateY(-2px)}
.btn-call{
  background:var(--brand-navy);color:#fff;
  width:100%;justify-content:center;padding:12px 20px;font-size:14px;
}
.btn-call:hover{background:var(--brand-navy-light);transform:translateY(-2px)}

/* ====== HEADER ====== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  background:transparent;transition:background .3s,backdrop-filter .3s,box-shadow .3s,border-color .3s;
  border-bottom:1px solid transparent;
}
.site-header.scrolled,
.site-header.theme-light{
  background:rgba(252,252,250,.92);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom-color:var(--border);
  box-shadow:0 1px 0 rgba(0,0,0,.03);
}
.site-header .inner{
  display:flex;align-items:center;gap:24px;height:72px;
  max-width:1280px;margin:0 auto;padding:0 20px;
}
.site-header .logo,
.site-header .custom-logo-link{
  flex-shrink:0;display:inline-flex;align-items:center;
  text-decoration:none;line-height:0;
  padding:6px 12px;border-radius:var(--radius-pill);
  background:rgba(255,255,255,.92);
  transition:background .3s,box-shadow .3s,padding .3s;
}
.site-header.scrolled .logo,
.site-header.scrolled .custom-logo-link,
.site-header.theme-light .logo,
.site-header.theme-light .custom-logo-link{
  background:transparent;padding:0;
}
.site-header .logo img,
.site-header .logo svg,
.site-header .custom-logo,
.site-header .custom-logo-link img{
  height:38px !important;width:auto !important;
  max-height:38px;max-width:200px;
  display:block;
}
.site-nav{display:flex;gap:4px;margin-left:16px}
.site-nav ul{display:flex;gap:4px;align-items:center}
.site-nav a{
  padding:8px 16px;border-radius:var(--radius-pill);
  font-size:14px;font-weight:500;color:rgba(17,20,24,.7);
  transition:all .15s;
}
.site-header:not(.scrolled):not(.theme-light) .site-nav a{color:rgba(255,255,255,.8)}
.site-header:not(.scrolled):not(.theme-light) .site-nav a:hover{color:#fff;background:rgba(255,255,255,.08)}
.site-nav a:hover{background:#F0EFE9;color:var(--fg)}
.site-nav .current-menu-item a,
.site-nav .current_page_item a{background:var(--brand-navy);color:#fff}
.site-header:not(.scrolled):not(.theme-light) .site-nav .current-menu-item a{background:rgba(255,255,255,.15);color:#fff}
.cta-header{
  margin-left:auto;
  background:linear-gradient(90deg,var(--brand-orange),var(--brand-orange-light));
  color:#fff;padding:10px 22px;border-radius:var(--radius-pill);
  font-weight:600;font-size:14px;box-shadow:var(--shadow-cta);
  transition:transform .2s;white-space:nowrap;
}
.cta-header:hover{transform:scale(1.04)}

/* Mobile menu toggle */
.menu-toggle{
  display:none;width:42px;height:42px;border-radius:50%;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  margin-left:auto;flex-direction:column;align-items:center;justify-content:center;gap:4px;
}
.site-header.scrolled .menu-toggle,
.site-header.theme-light .menu-toggle{background:#F0EFE9;border-color:var(--border)}
.menu-toggle span{display:block;width:18px;height:2px;background:#fff;border-radius:2px}
.site-header.scrolled .menu-toggle span,
.site-header.theme-light .menu-toggle span{background:var(--fg)}

.mobile-menu{
  display:none;position:fixed;top:72px;left:0;right:0;
  background:rgba(252,252,250,.98);backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);z-index:49;padding:20px;
  flex-direction:column;gap:6px;
}
.mobile-menu.open{display:flex}
.mobile-menu a{padding:12px 18px;border-radius:var(--radius);font-size:15px;font-weight:500;color:var(--fg-soft)}
.mobile-menu a:hover{background:var(--bg-soft)}
.mobile-menu .cta-header{margin:8px 0 0;text-align:center;justify-content:center}

/* Body padding when header is light (non-front) */
body.has-header-padding{padding-top:72px}

/* ====== HERO ====== */
.hero{position:relative;height:100svh;min-height:680px;overflow:hidden}
.hero .bg{position:absolute;inset:0;will-change:transform;overflow:hidden}
.hero .bg img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero::before,
.hero::after{content:'';position:absolute;inset:0;pointer-events:none;z-index:1}
.hero::before{background:linear-gradient(180deg,rgba(24,46,78,.65) 0%,rgba(24,46,78,.4) 40%,rgba(24,46,78,.92) 100%)}
.hero::after{background:linear-gradient(90deg,rgba(24,46,78,.85) 0%,rgba(24,46,78,.3) 60%,transparent 100%)}
.hero .content{
  position:relative;z-index:2;min-height:100%;
  display:flex;flex-direction:column;justify-content:flex-start;
  max-width:1200px;margin:0 auto;padding:130px 20px 60px;color:#fff;
}
.hero .badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.22);
  padding:6px 16px;border-radius:var(--radius-pill);
  font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  width:fit-content;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.hero .badge .dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--brand-green);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.hero h1{
  font-size:clamp(2.5rem,6.5vw,5.25rem);
  max-width:880px;margin-top:28px;color:#fff;
  font-weight:700;
}
.hero h1 em{
  font-style:italic;
  background:linear-gradient(90deg,var(--brand-orange),var(--brand-green));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero .lede{
  margin-top:24px;max-width:580px;
  color:rgba(255,255,255,.78);font-size:18px;line-height:1.6;
}
.hero .ctas{margin-top:44px;display:flex;gap:12px;flex-wrap:wrap}

/* Hero search bar */
.hero-search{
  margin-top:36px;max-width:640px;
  background:rgba(255,255,255,.96);border-radius:var(--radius);
  padding:6px 6px 6px 0;
  display:flex;align-items:stretch;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.4);
}
.hero-search-field{
  display:flex;align-items:center;gap:10px;
  flex:1;padding:10px 16px;border-right:1.5px solid var(--border);
}
.hero-search-field:last-of-type{border-right:none}
.hero-search-field svg{flex-shrink:0;color:var(--brand-orange);width:18px;height:18px}
.hero-search-field label{
  display:block;font-size:10px;font-weight:700;
  color:var(--muted);text-transform:uppercase;letter-spacing:.4px;
}
.hero-search-field input,
.hero-search-field select{
  border:none;outline:none;background:transparent;
  font-size:14px;color:var(--fg);width:100%;padding-top:2px;
}
.hero-search-btn{
  background:linear-gradient(90deg,var(--brand-orange),var(--brand-orange-light));
  color:#fff;border:none;padding:0 24px;
  border-radius:var(--radius);
  font-size:14px;font-weight:700;display:inline-flex;align-items:center;gap:6px;
  cursor:pointer;transition:transform .2s;
}
.hero-search-btn:hover{transform:scale(1.02)}

/* ====== STATS BAR ====== */
.stats{background:var(--brand-navy);color:#fff;padding:64px 0;position:relative;overflow:hidden}
.stats::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--brand-orange),var(--brand-green));
}
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.stat{padding-left:22px;border-left:2px solid var(--brand-orange)}
.stat .n{font-family:'Fraunces',serif;font-size:48px;font-weight:700;line-height:1;color:#fff}
.stat .l{color:rgba(255,255,255,.55);margin-top:8px;font-size:13px;letter-spacing:.02em}

/* ====== SECTIONS ====== */
.section-header{margin-bottom:48px}
.section-header.split{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap}

/* ====== CARDS — Negócios ====== */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius-lg);overflow:hidden;
  transition:transform .25s,box-shadow .25s,border-color .25s;
  cursor:pointer;display:block;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card);border-color:var(--brand-orange)}
.card .thumb{
  height:200px;position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--brand-navy),var(--brand-navy-light));
  display:flex;align-items:center;justify-content:center;
}
.card .thumb img{width:100%;height:100%;object-fit:cover}
.card .thumb-emoji{font-size:64px;line-height:1}
.card .badge-verified{
  position:absolute;top:12px;left:12px;
  background:var(--brand-green);color:#fff;
  font-size:10px;font-weight:700;
  padding:4px 10px;border-radius:var(--radius-pill);
  letter-spacing:.1em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:4px;
}
.card .badge-verified::before{content:'✓'}
.card .badge-independent{
  position:absolute;top:12px;right:12px;
  background:rgba(0,0,0,.7);color:#fff;
  font-size:10px;font-weight:600;
  padding:4px 10px;border-radius:var(--radius-pill);
  backdrop-filter:blur(8px);
}
.card .body{padding:22px}
.card .cat{
  font-size:10px;font-weight:700;
  color:var(--brand-orange);letter-spacing:.18em;
  text-transform:uppercase;margin-bottom:8px;
}
.card h3{font-size:19px;margin-bottom:10px;color:var(--fg);line-height:1.25}
.card .meta{
  color:var(--muted);font-size:13px;
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
}
.card .meta .rating{color:var(--fg-soft);font-weight:600}
.card .meta .rating small{color:var(--muted);font-weight:400}
.card .excerpt{
  color:var(--muted);font-size:13.5px;line-height:1.6;
  margin-top:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}

/* ====== CATEGORIES (Horizontal Seiko-style) ====== */
.categories-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:12px;
}
.category-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:20px 22px;
  display:flex;align-items:center;gap:16px;
  cursor:pointer;transition:all .2s;
}
.category-card:hover{
  border-color:var(--brand-orange);background:var(--brand-orange-soft);
  transform:translateY(-1px);box-shadow:var(--shadow-sm);
}
.category-card .icon{
  width:48px;height:48px;border-radius:var(--radius);
  background:var(--bg-soft);display:flex;align-items:center;justify-content:center;
  font-size:22px;flex-shrink:0;
}
.category-card .text{flex:1;min-width:0}
.category-card .name{font-family:'Sora',sans-serif;font-size:14px;font-weight:700;color:var(--fg);line-height:1.2}
.category-card .count{font-size:12px;color:var(--muted);margin-top:2px}

/* ====== HOW IT WORKS (3 STEPS) ====== */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;counter-reset:step}
.step{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:32px 28px;
  position:relative;
}
.step .num{
  width:52px;height:52px;border-radius:50%;
  background:var(--brand-orange);color:#fff;
  font-family:'Fraunces',serif;font-size:22px;font-weight:700;
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;
}
.step:nth-child(2) .num{background:var(--brand-green)}
.step:nth-child(3) .num{background:var(--brand-navy)}
.step h3{font-size:18px;margin-bottom:8px}
.step p{color:var(--muted);font-size:14px;line-height:1.65}

/* ====== BANNER SPONSOR ====== */
.sponsor-banner{
  background:linear-gradient(135deg,var(--brand-navy) 0%,#0e1f36 100%);
  border:1.5px solid rgba(255,102,0,.3);
  border-radius:var(--radius-lg);padding:24px 28px;
  display:flex;align-items:center;justify-content:space-between;
  gap:20px;flex-wrap:wrap;margin-bottom:40px;
  position:relative;overflow:hidden;
}
.sponsor-banner::before{
  content:'';position:absolute;top:-40px;right:-40px;
  width:140px;height:140px;background:rgba(255,102,0,.1);border-radius:50%;
}
.sponsor-banner .label{font-size:10px;font-weight:700;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.8px;margin-bottom:5px}
.sponsor-banner .title{font-size:18px;font-weight:700;color:#fff}
.sponsor-banner .title span{color:var(--brand-orange)}
.sponsor-banner .sub{font-size:13px;color:rgba(255,255,255,.55);margin-top:3px}

/* ====== SOBRE — VIDEO ====== */
.sobre-hero{padding:140px 0 60px;background:linear-gradient(180deg,var(--brand-cream),var(--bg))}
.sobre-hero .container{max-width:920px}
.sobre-hero h1{font-size:clamp(2.5rem,5.5vw,4.5rem);margin-top:18px}
.sobre-hero h1 em{font-style:italic;color:var(--brand-orange)}
.sobre-hero .lede{margin-top:24px;color:var(--muted);font-size:19px;max-width:680px;line-height:1.65}

.video-section{padding:0 0 96px}
.video-wrap{
  position:relative;aspect-ratio:16/9;
  border-radius:24px;overflow:hidden;
  background:var(--brand-navy);
  box-shadow:var(--shadow-deep);
}
.video-wrap iframe{width:100%;height:100%;border:0;display:block}
.video-poster{
  position:relative;width:100%;height:100%;
  cursor:pointer;border:0;background:none;padding:0;
}
.video-poster img{width:100%;height:100%;object-fit:cover;opacity:.65;transition:opacity .3s}
.video-poster:hover img{opacity:.55}
.play-btn{
  position:absolute;inset:0;margin:auto;
  width:88px;height:88px;border-radius:50%;
  background:var(--brand-orange);color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 20px 60px -10px rgba(255,102,0,.6);
  transition:transform .25s;font-size:28px;
}
.video-poster:hover .play-btn{transform:scale(1.15)}

/* ====== SOBRE — VALUES ====== */
.values{padding:96px 0;background:var(--bg-soft)}
.values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-top:48px}
.value{background:var(--card);border-radius:var(--radius-lg);padding:32px 28px;border:1px solid var(--border)}
.value .ico{font-size:32px;margin-bottom:16px}
.value h3{font-size:18px;margin-bottom:8px}
.value p{color:var(--muted);font-size:14px;line-height:1.65}

/* ====== SINGLE NEGOCIO ====== */
.negocio-hero{
  background:linear-gradient(135deg,var(--brand-navy) 0%,#0e1f36 100%);
  color:#fff;padding:120px 0 60px;position:relative;overflow:hidden;
}
.negocio-hero::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--brand-orange),var(--brand-green));
}
.negocio-hero .container{display:grid;grid-template-columns:96px 1fr;gap:24px;align-items:center}
.negocio-avatar{
  width:96px;height:96px;border-radius:var(--radius-lg);
  background:linear-gradient(135deg,var(--brand-orange),var(--brand-orange-light));
  display:flex;align-items:center;justify-content:center;
  font-size:44px;flex-shrink:0;overflow:hidden;
}
.negocio-avatar img{width:100%;height:100%;object-fit:cover}
.negocio-hero .meta h1{color:#fff;font-size:clamp(1.75rem,3vw,2.5rem);margin-bottom:10px}
.negocio-hero .meta .tags{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.tag{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:var(--radius-pill);font-size:11px;font-weight:700;letter-spacing:.05em}
.tag-cat{background:var(--brand-orange);color:#fff}
.tag-verified{background:rgba(147,188,10,.2);color:#c8f07a;border:1px solid rgba(147,188,10,.4)}
.tag-independent{background:rgba(255,102,0,.2);color:#ffb380;border:1px solid rgba(255,102,0,.35)}
.negocio-hero .location{color:rgba(255,255,255,.7);font-size:14px}
.negocio-hero .rating{display:inline-flex;align-items:center;gap:6px;color:#fff;font-weight:600;margin-right:14px}
.negocio-hero .rating .stars-bar{color:#FDB022;letter-spacing:1px}
.negocio-hero .rating small{color:rgba(255,255,255,.5);font-weight:400;margin-left:4px}

.negocio-body{
  max-width:1100px;margin:0 auto;padding:48px 20px;
  display:grid;grid-template-columns:1fr 320px;gap:32px;
}
.negocio-main{}
.negocio-side{}
.panel{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:28px;margin-bottom:24px;
}
.panel h2{
  font-size:15px;font-family:'Sora',sans-serif;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;color:var(--brand-navy);
  padding-bottom:10px;border-bottom:2px solid var(--brand-orange);
  display:inline-block;margin-bottom:18px;
}
.panel p{color:var(--fg-soft);font-size:15px;line-height:1.8}

.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.gallery a,.gallery .gal-i{
  aspect-ratio:1;border-radius:var(--radius);
  background:var(--bg-soft);overflow:hidden;
  display:flex;align-items:center;justify-content:center;font-size:32px;
}
.gallery img{width:100%;height:100%;object-fit:cover;display:block}

.info-list .row{
  display:flex;gap:14px;padding:12px 0;
  border-bottom:1px solid var(--border-soft);align-items:flex-start;
}
.info-list .row:last-child{border:none}
.info-list .ico{
  width:38px;height:38px;border-radius:9px;
  background:var(--brand-orange-soft);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;font-size:16px;
}
.info-list .label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.info-list .value{font-size:14px;color:var(--fg);font-weight:500;margin-top:2px}

.social-list{display:flex;flex-direction:column;gap:8px}
.social-item{
  display:flex;align-items:center;gap:12px;
  padding:11px 14px;border-radius:var(--radius);
  border:1px solid var(--border);background:var(--card);
  font-size:14px;font-weight:500;color:var(--fg);
  transition:border-color .15s,background .15s;
}
.social-item:hover{border-color:var(--brand-orange);background:var(--bg-soft)}
.social-item .label-row{flex:1;display:flex;flex-direction:column;gap:1px}
.social-item .sub{font-size:11px;color:var(--brand-orange);font-weight:600}

.map-placeholder{
  background:var(--bg-soft);border:1px dashed var(--border);
  border-radius:var(--radius);height:160px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:8px;color:var(--muted);font-size:13px;
}
.map-placeholder .ico{font-size:32px}

.cta-card{
  background:linear-gradient(135deg,var(--brand-navy),var(--brand-navy-light));
  border-radius:var(--radius-lg);padding:24px;color:#fff;text-align:center;
}
.cta-card h4{color:#fff;font-size:16px;margin-bottom:6px;font-family:'Sora',sans-serif;font-weight:700}
.cta-card p{color:rgba(255,255,255,.65);font-size:13px;margin-bottom:16px}
.cta-card .btn{width:100%;justify-content:center}

/* Suggested companies */
.suggested{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-top:14px}
.suggested .card{margin:0}
.suggested .card .thumb{height:100px}
.suggested .card .body{padding:14px}
.suggested .card h3{font-size:14px;margin-bottom:4px}
.suggested .card .meta{font-size:12px}

/* Sticky on desktop */
@media(min-width:961px){.negocio-side .panel:first-child{position:sticky;top:88px}}

/* ====== ARCHIVE — Filters ====== */
.archive-hero{
  background:linear-gradient(135deg,var(--brand-navy),#0e1f36);
  color:#fff;padding:120px 0 60px;position:relative;
}
.archive-hero .container{max-width:900px}
.archive-hero h1{color:#fff;font-size:clamp(2rem,4vw,3.25rem)}
.archive-hero .lede{margin-top:14px;color:rgba(255,255,255,.7);font-size:17px;max-width:560px}

.filter-bar{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:18px;
  display:flex;gap:14px;flex-wrap:wrap;align-items:flex-end;
  margin:-30px auto 32px;max-width:1100px;position:relative;z-index:2;
  box-shadow:var(--shadow-card);
}
.filter-group{display:flex;flex-direction:column;gap:5px;flex:1;min-width:160px}
.filter-group label{font-size:10.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.filter-group select,
.filter-group input{
  border:1px solid var(--border);border-radius:var(--radius);
  padding:10px 13px;font-size:14px;color:var(--fg);
  background:var(--bg);outline:none;font-family:inherit;
}
.filter-group select:focus,
.filter-group input:focus{border-color:var(--brand-orange)}

.results-header{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:24px;flex-wrap:wrap;gap:12px;
}
.results-count{color:var(--muted);font-size:14px}
.results-count strong{color:var(--brand-navy);font-weight:700}

/* ====== BLOG / SINGLE POST ====== */
.post-hero{padding:120px 0 40px;background:var(--bg)}
.post-hero .container{max-width:780px}
.post-hero .cat-tag{
  display:inline-block;background:var(--brand-orange-soft);color:var(--brand-orange);
  font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  padding:4px 12px;border-radius:var(--radius-pill);margin-bottom:14px;
}
.post-hero h1{font-size:clamp(2rem,4.5vw,3.5rem);line-height:1.15}
.post-hero .meta{
  margin-top:24px;color:var(--muted);font-size:14px;
  display:flex;gap:18px;flex-wrap:wrap;align-items:center;
  padding-top:18px;border-top:1px solid var(--border);
}

.post-featured{padding:0 0 32px}
.post-featured .container{max-width:980px}
.post-featured img{border-radius:var(--radius-lg);width:100%;height:auto}

.post-content{padding:0 0 80px}
.post-content .container{max-width:740px}
.post-content article{font-size:17px;line-height:1.85;color:var(--fg-soft)}
.post-content article p{margin-bottom:22px}
.post-content article h2{font-size:28px;margin:36px 0 14px;color:var(--brand-navy)}
.post-content article h3{font-size:22px;margin:30px 0 12px}
.post-content article ul,
.post-content article ol{padding-left:22px;margin-bottom:22px}
.post-content article ul li,
.post-content article ol li{margin-bottom:8px}
.post-content article ul{list-style:disc}
.post-content article ol{list-style:decimal}
.post-content article a{color:var(--brand-orange);font-weight:600;border-bottom:1px solid var(--brand-orange-soft)}
.post-content article a:hover{border-color:var(--brand-orange)}
.post-content article blockquote{
  margin:28px 0;padding:20px 24px;border-left:3px solid var(--brand-orange);
  background:var(--bg-soft);border-radius:0 var(--radius) var(--radius) 0;
  font-style:italic;color:var(--fg-soft);
}
.post-content article img{border-radius:var(--radius);margin:24px 0}
.post-content article strong{color:var(--brand-navy)}

.post-cta{
  background:var(--brand-navy);color:#fff;
  border-radius:var(--radius-lg);padding:36px;text-align:center;margin:48px 0;
}
.post-cta h3{color:#fff;font-size:22px;margin-bottom:8px}
.post-cta p{color:rgba(255,255,255,.65);margin-bottom:22px}

.related-posts{padding:60px 0;background:var(--bg-soft)}
.related-posts h2{font-size:24px;margin-bottom:28px}

/* ====== CONTACT PAGE ====== */
.contact-hero{padding:140px 0 60px;background:var(--bg)}
.contact-hero .container{max-width:900px}
.contact-grid{display:grid;grid-template-columns:1fr 360px;gap:40px;padding:0 0 96px}
.contact-form{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px}
.contact-info{}
.contact-info .info-block{padding:24px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:14px}

/* ====== FOOTER ====== */
.site-footer{background:var(--brand-navy);color:#fff;padding:72px 0 24px;position:relative}
.site-footer::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--brand-orange),var(--brand-green));
}
.site-footer .grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
.site-footer .logo-block img,
.site-footer .logo-block svg{height:42px;width:auto;margin-bottom:16px}
.site-footer .desc{color:rgba(255,255,255,.55);font-size:13px;line-height:1.7;max-width:300px}
.site-footer .tag-tete{
  display:inline-block;background:var(--brand-green);color:#fff;
  font-size:11px;font-weight:700;padding:4px 12px;border-radius:var(--radius-pill);
  margin-top:14px;letter-spacing:.05em;
}
.site-footer h4{
  font-family:'Sora',sans-serif;font-size:12px;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  color:var(--brand-green);margin-bottom:18px;
}
.site-footer ul li{margin-bottom:10px}
.site-footer ul li a{color:rgba(255,255,255,.55);font-size:13px;transition:color .15s}
.site-footer ul li a:hover{color:var(--brand-orange)}
.site-footer .bottom{
  margin-top:32px;padding-top:24px;border-top:1px solid rgba(255,255,255,.08);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-size:12px;color:rgba(255,255,255,.45);
}
.site-footer .socials{display:flex;gap:10px;margin-top:14px}
.site-footer .socials a{
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  display:flex;align-items:center;justify-content:center;font-size:14px;
  transition:background .15s,transform .15s;
}
.site-footer .socials a:hover{background:var(--brand-orange);transform:translateY(-2px);border-color:var(--brand-orange)}

/* ====== REVEAL ON SCROLL ====== */
.reveal{
  opacity:0;transform:translateY(28px) scale(.98);filter:blur(6px);
  transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1),filter .8s ease;
}
.reveal.in{opacity:1;transform:none;filter:none}

@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;filter:none;transition:none}
  *{animation:none!important;transition:none!important}
}

/* ====== PAGINATION ====== */
.teteserv-pagination{margin:40px 0;display:flex;justify-content:center}
.teteserv-pagination .nav-links{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.teteserv-pagination .page-numbers{
  padding:10px 16px;border-radius:var(--radius);
  border:1px solid var(--border);background:var(--card);
  color:var(--fg-soft);font-weight:600;font-size:14px;
  transition:all .15s;text-decoration:none;
}
.teteserv-pagination .page-numbers.current{background:var(--brand-navy);color:#fff;border-color:var(--brand-navy)}
.teteserv-pagination .page-numbers:hover:not(.current){border-color:var(--brand-orange);color:var(--brand-orange)}

/* ====== TOAST ====== */
.toast{
  position:fixed;bottom:24px;right:24px;z-index:9999;
  background:var(--brand-green);color:#fff;
  padding:14px 22px;border-radius:var(--radius);
  font-size:14px;font-weight:500;
  box-shadow:var(--shadow-card);display:none;
  animation:toastIn .3s ease;
}
@keyframes toastIn{from{transform:translateY(20px);opacity:0}to{transform:none;opacity:1}}

/* ====== NO RESULTS ====== */
.no-results{
  grid-column:1/-1;text-align:center;padding:64px 20px;
  background:var(--bg-soft);border-radius:var(--radius-lg);
}
.no-results .ico{font-size:48px;margin-bottom:14px}
.no-results h3{font-size:22px;margin-bottom:8px}
.no-results p{color:var(--muted)}
.no-results a{color:var(--brand-orange);font-weight:600}

/* ====== RESPONSIVE ====== */
@media(max-width:960px){
  section{padding:72px 0}
  .stats .grid{grid-template-columns:repeat(2,1fr);gap:20px}
  .site-footer .grid{grid-template-columns:1fr 1fr;gap:32px}
  .negocio-body{grid-template-columns:1fr}
  .negocio-side{order:-1}
  .contact-grid{grid-template-columns:1fr}
  .negocio-hero .container{grid-template-columns:1fr;text-align:center}
  .negocio-avatar{margin:0 auto}
}
@media(max-width:768px){
  .site-nav{display:none}
  .cta-header{display:none}
  .menu-toggle{display:flex}
  .site-header .logo img,
  .site-header .logo svg,
  .site-header .custom-logo,
  .site-header .custom-logo-link img{height:32px !important;max-height:32px;max-width:160px}
  .site-header .inner{height:64px}
  .hero{min-height:640px}
  .hero .content{padding:120px 20px 56px}
  .hero h1{font-size:clamp(2rem,7vw,3.25rem);margin-top:20px}
  .hero .lede{font-size:16px;margin-top:18px}
  .hero .ctas{margin-top:32px}
  .hero-search{margin-top:28px;flex-direction:column;padding:10px}
  .hero-search-field{border-right:none;border-bottom:1.5px solid var(--border);width:100%}
  .hero-search-field:last-of-type{border-bottom:none}
  .hero-search-btn{width:100%;padding:14px;justify-content:center;margin-top:6px}
  .stats .grid{grid-template-columns:1fr 1fr;gap:24px}
  .stat .n{font-size:36px}
  .site-footer .grid{grid-template-columns:1fr;gap:28px}
  .site-footer .bottom{flex-direction:column;text-align:center}
  .section-header.split{flex-direction:column;align-items:flex-start}
}
@media(max-width:480px){
  .hero .ctas{flex-direction:column;align-items:stretch}
  .hero .btn{justify-content:center}
}
