  /* ── Reset & Tokens ────────────────────────────── */
  :root {
    --primary:       #0a3d6b;
    --primary-mid:   #1557a0;
    --primary-light: #1e6cbf;
    --accent:        #b45309;
    --accent-light:  #d97706;
    --accent-bg:     #fef3c7;
    --dark:   #070f1a;
    --mid:    #111827;
    --bg:     #f4f7fb;
    --bg-alt: #eef2f8;
    --white:  #ffffff;
    --border: #c9d5e8;
    --text:       #0f172a;
    --text-body:  #1e293b;
    --text-muted: #374151;
    --font-d: 'Sora', sans-serif;
    --font-b: 'Inter', sans-serif;
    --radius:    14px;
    --radius-sm: 8px;
    --shadow:    0 4px 28px rgba(10,61,107,.10);
    --tr: .26s cubic-bezier(.4,0,.2,1);
    --whatsapp:  #25d366;
    --whatsapp-h: #128c7e;
  }
  *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
  html { scroll-behavior: smooth; font-size: 16px; }
  body {
    font-family: var(--font-b);
    color: var(--text);
    background: var(--bg);
    line-height: 1.7;
    -webkit-font-smoothing: antialiased;
  }
  a { color: inherit; text-decoration: none; transition: color var(--tr); }
  img { max-width: 100%; height: auto; display: block; }
  ul { list-style: none; }
  h1,h2,h3,h4,h5 { font-family: var(--font-d); line-height: 1.25; color: var(--dark); }
  h1 { font-size: clamp(1.8rem, 5vw, 3.2rem); font-weight: 800; letter-spacing: -1px; }
  h2 { font-size: clamp(1.4rem, 3.5vw, 2.2rem); font-weight: 700; letter-spacing: -0.5px; }
  h3 { font-size: 1.25rem; font-weight: 600; }

  /* ── Accessibility ──────────────────────────────── */
  .skip-link {
    position: absolute;
    top: -100%;
    left: 1rem;
    background: var(--primary);
    color: #fff;
    padding: .6rem 1.2rem;
    border-radius: 0 0 var(--radius) var(--radius);
    font-weight: 700;
    z-index: 9999;
    transition: top .2s;
  }
  .skip-link:focus { top: 0; }
  a:focus-visible, button:focus-visible {
    outline: 3px solid var(--primary);
    outline-offset: 2px;
    border-radius: 4px;
  }

  /* ── Container ──────────────────────────────────── */
  .container { max-width: 1200px; margin: 0 auto; padding: 0 1.5rem; }

  /* ── HEADER / NAV ───────────────────────────────── */
  .site-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-bottom: 1px solid rgba(226, 232, 240, 0.8);
    box-shadow: 0 4px 20px rgba(0,0,0,.04);
    transition: transform var(--tr);
    min-height: 70px;
    will-change: transform;
  }
  .site-header.scrolled {
    background: rgba(255, 255, 255, 0.98);
    box-shadow: 0 10px 30px rgba(0,0,0,.08);
  }
  .navbar {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .85rem 1.5rem;
    gap: 1.5rem;
    min-height: 70px;
  }
  .nav-logo {
    font-family: var(--font-d);
    font-weight: 800;
    font-size: 1.45rem;
    color: var(--primary);
    letter-spacing: -.5px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    gap: .5rem;
  }
  .nav-logo:hover { color: var(--primary-mid); }
  .nav-links {
    display: flex;
    align-items: center;
    gap: .15rem;
    flex-wrap: wrap;
  }
  .nav-links li a {
    font-family: var(--font-d);
    font-weight: 600;
    font-size: .9rem;
    color: var(--mid);
    padding: .6rem .9rem;
    border-radius: var(--radius-sm);
    transition: background var(--tr), color var(--tr);
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    white-space: nowrap;
    position: relative;
  }
  .nav-links li a:hover, .nav-links li a.active {
    background: var(--primary);
    color: var(--white);
  }
  .nav-toggle {
    display: none;
    background: none;
    border: 1.5px solid var(--border);
    border-radius: 8px;
    padding: .45rem .6rem;
    cursor: pointer;
    color: var(--primary);
    line-height: 1;
    min-width: 44px;
    min-height: 44px;
    align-items: center;
    justify-content: center;
    transition: background var(--tr);
  }
  .nav-toggle:hover { background: var(--primary-light); }
  .nav-toggle[aria-expanded="true"] .icon-open  { display: none; }
  .nav-toggle[aria-expanded="false"] .icon-close { display: none; }
  @media (max-width: 768px) {
    .nav-toggle { display: inline-flex; }
    .nav-links {
      display: none;
      flex-direction: column;
      align-items: stretch;
      position: absolute;
      top: calc(100% + 1px);
      inset-x: 0;
      background: var(--white);
      padding: .75rem 1rem 1rem;
      box-shadow: 0 12px 32px rgba(0,0,0,.1);
      border-top: 1px solid var(--border);
      z-index: 999;
      gap: .25rem;
    }
    .nav-links.open { display: flex; }
    .nav-links li a { width: 100%; }
  }

  /* ── Hero ────────────────────────────────────────── */
  .item-hero {
    height: 500px;
    display: flex;
    align-items: flex-end;
    background: var(--dark);
    position: relative;
    overflow: hidden;
  }
  .item-hero-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    z-index: 0;
  }
  .hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(160deg, rgba(7,15,26,.75) 0%, rgba(10,61,107,.60) 100%);
    z-index: 1;
  }
  .hero-content {
    position: relative;
    z-index: 2;
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
    padding: 3rem 1.5rem 4rem;
    color: var(--white);
  }
  .hero-badge {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    background: rgba(255,255,255,.15);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,.25);
    color: #e2e8f0;
    font-size: .8rem;
    font-weight: 600;
    padding: .35rem .85rem;
    border-radius: 99px;
    margin-bottom: 1rem;
    letter-spacing: .3px;
  }
  .hero-content h1 { color: #fff; margin-bottom: .75rem; text-shadow: 0 2px 12px rgba(0,0,0,.3); }
  .hero-content p  { font-size: 1.1rem; color: #cbd5e1; max-width: 680px; }

  /* ── Section titles ─────────────────────────────── */
  .section-label {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    font-size: .85rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: #ffffff;
    margin-bottom: 1rem;
    background: var(--primary-light);
    padding: .35rem .85rem;
    border-radius: 6px;
  }
  .section-title {
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    font-weight: 800;
    color: var(--dark);
    margin-bottom: 3rem;
    position: relative;
    letter-spacing: -0.5px;
  }
  .section-title::after {
    content: '';
    display: block;
    width: 60px; height: 5px;
    background: var(--accent);
    border-radius: 10px;
    margin-top: .75rem;
  }
  .section-title.center { text-align: center; }
  .section-title.center::after { margin: .75rem auto 0; }

  /* ── Cards compartidos ─────────────────────────── */
  .item-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(0,0,0,0.05);
    display: flex;
    flex-direction: column;
    height: 100%;
    border: 1px solid rgba(0,0,0,0.03);
    transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1), box-shadow 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  }
  .item-card:hover { transform: translateY(-10px); box-shadow: 0 30px 60px rgba(0,0,0,0.1); }
  .card-img {
    width: 100%;
    aspect-ratio: 4/3;
    height: auto;
    object-fit: cover;
    display: block;
    background: var(--bg2);
    transition: transform 0.8s cubic-bezier(0.165, 0.84, 0.44, 1);
  }
  .item-card:hover .card-img { transform: scale(1.08); }
  .card-placeholder {
    aspect-ratio: 4/3;
    height: auto;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 4rem;
    background: linear-gradient(135deg, #f0f7ff, #e0e7ff);
  }
  .item-card-body {
    padding: 2rem;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 1rem;
  }
  .item-card-body h3 { font-size: 1.3rem; color: var(--dark); margin: 0; font-weight: 800; line-height: 1.3; }
  .item-card-body h3 a:hover { color: var(--primary); }
  .item-card-body p {
    font-size: 1rem;
    color: var(--text-muted);
    flex: 1;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin: 0;
    line-height: 1.6;
  }
  .card-link {
    color: var(--primary);
    font-weight: 800;
    font-size: .95rem;
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    margin-top: 1rem;
    transition: gap 0.3s ease;
  }
  .card-link:hover { gap: .8rem; }
  .related-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    contain: layout style;
  }
  @media (max-width: 768px) { .related-grid { grid-template-columns: repeat(2, 1fr); } }
  @media (max-width: 480px) { .related-grid { grid-template-columns: 1fr; } }
  .related-grid .card-img,
  .related-grid img { aspect-ratio: 4/3; width: 100%; height: auto; }

  /* ── Keyword tags ───────────────────────────────── */
  .keyword-tag {
    background: var(--primary-light);
    color: #ffffff;
    padding: .4rem 1rem;
    border-radius: 99px;
    font-size: .82rem;
    font-weight: 600;
    border: 1.5px solid #1e6cbf;
    transition: all var(--tr);
    display: inline-block;
  }
  .keyword-tag:hover { background: var(--primary-mid); border-color: var(--primary); }
  .keywords-list { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: .75rem; }

  /* ── Announcements ──────────────────────────────── */
  .announcements-section { background: var(--bg); padding: 8rem 0; }
  .announcements-list { display: flex; flex-direction: column; gap: 1.5rem; max-width: 960px; margin: 0 auto; }
  .ann-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow);
    display: grid;
    grid-template-columns: 1fr 240px;
    border: 1px solid var(--border);
    transition: all var(--tr);
    position: relative;
  }
  .ann-card::before {
    content: '';
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 4px;
    background: var(--primary);
    opacity: 0;
    transition: opacity .3s;
  }
  .ann-card:hover { transform: scale(1.01); box-shadow: var(--shadow-lg); border-color: var(--primary-light); }
  .ann-card:hover::before { opacity: 1; }
  .ann-content { padding: 2rem 2.5rem; display: flex; flex-direction: column; justify-content: center; gap: .75rem; }
  .ann-title { font-family: var(--font-d); font-weight: 800; font-size: 1.2rem; color: var(--dark); letter-spacing: -0.3px; }
  .ann-meta { display: flex; flex-wrap: wrap; gap: 1rem; font-size: .88rem; color: var(--text-muted); }
  .ann-meta-item { display: flex; align-items: center; gap: .4rem; background: var(--bg); padding: .25rem .6rem; border-radius: 6px; }
  .ann-meta-item svg { color: var(--primary); }
  .ann-desc { font-size: 1rem; color: var(--text); line-height: 1.6; }
  .ann-img { width: 100%; height: 100%; min-height: 180px; overflow: hidden; background: var(--bg2); }
  .ann-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s; }
  .ann-card:hover .ann-img img { transform: scale(1.05); }
  @media (max-width: 640px) {
    .ann-card { grid-template-columns: 1fr; }
    .ann-img { height: 200px; order: -1; }
  }
  .ann-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    margin-top: 1.75rem;
    flex-wrap: wrap;
  }
  .ann-page-btn {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 2px solid var(--border);
    background: var(--white);
    color: #334155;
    font-size: .85rem;
    font-weight: 700;
    cursor: pointer;
    transition: all var(--tr);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-d);
  }
  .ann-page-btn:hover { border-color: var(--primary); color: var(--primary); }
  .ann-page-btn.active { background: var(--primary); border-color: var(--primary); color: #ffffff; }

  /* ── Coverage ───────────────────────────────────── */
  .coverage-section { padding: 10rem 0; background: var(--bg); position: relative; overflow: hidden; }
  .coverage-section::before {
    content: '';
    position: absolute;
    top: 0; left: 50%; transform: translateX(-50%);
    width: 100vw; height: 100%;
    background: radial-gradient(circle at top, rgba(15,76,129,0.03) 0%, transparent 70%);
    pointer-events: none;
  }
  .coverage-zones {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 2rem;
    margin-bottom: 4rem;
  }
  .coverage-city-btn {
    background: var(--white);
    border: 1px solid rgba(0,0,0,0.04);
    padding: 2.5rem;
    border-radius: 32px;
    cursor: pointer;
    transition: all 0.5s cubic-bezier(0.16, 1, 0.3, 1);
    text-align: left;
    width: 100%;
    display: block;
    box-shadow: 0 10px 30px rgba(0,0,0,0.02);
    position: relative;
    z-index: 1;
  }
  .coverage-city-btn:hover {
    transform: translateY(-12px);
    box-shadow: 0 40px 80px rgba(15,76,129,0.08);
    border-color: var(--primary-light);
  }
  .coverage-city-btn.city-expanded {
    background: var(--white);
    border-color: var(--primary);
    box-shadow: 0 30px 60px rgba(15,76,129,0.06);
  }
  .city-header { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; }
  .city-header h3 { 
    font-size: 1.5rem; 
    color: var(--dark); 
    font-family: var(--font-d); 
    margin: 0; 
    font-weight: 900; 
    letter-spacing: -0.5px;
  }
  .city-arrow { 
    width: 44px; height: 44px;
    background: var(--bg2);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    color: var(--primary); 
    transition: all .3s; 
    font-size: 1.2rem;
  }
  .coverage-city-btn:hover .city-arrow { background: var(--primary); color: #fff; transform: scale(1.1); }
  .coverage-city-btn.city-expanded .city-arrow { transform: rotate(180deg); background: var(--primary); color: #fff; }
  
  .city-hint { 
    font-size: .95rem; 
    color: var(--text-muted); 
    margin-top: .75rem; 
    font-weight: 700; 
    display: flex; 
    align-items: center; 
    gap: .6rem; 
  }
  .city-hint::before {
    content: '📍';
    font-size: 1.1rem;
  }
  
  .city-districts {
    margin-top: 2rem;
    border-top: 2px dashed var(--border);
    padding-top: 1.5rem;
    display: none;
    animation: fadeIn .4s ease;
  }
  @keyframes fadeIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
  
  .district-tag {
    display: inline-block;
    color: var(--primary);
    padding: .4rem .85rem;
    border-radius: 8px;
    font-size: .8rem;
    margin: .25rem;
    font-weight: 700;
    cursor: pointer;
    transition: all .2s;
    border: 1.5px solid var(--border);
    box-shadow: 0 2px 4px rgba(0,0,0,0.02);
  }
  .district-tag:hover { background: var(--primary); color: var(--white); border-color: var(--primary); transform: translateY(-2px); }

  #coverage-map {
    height: 550px;
    border-radius: var(--radius-lg);
    border: 1px solid var(--border);
    overflow: hidden;
    position: relative;
    box-shadow: var(--shadow-lg);
  }
  #coverage-map .leaflet-top,
  #coverage-map .leaflet-bottom { z-index: 400 !important; }
  #coverage-map .leaflet-pane  { z-index: 200 !important; }
  .coverage-section { position: relative; z-index: 0; }

  /* ── News / Blog ───────────────────────────────── */
  .news-section { padding: 10rem 0; background: #fff; }
  .news-grid { 
    display: grid; 
    grid-template-columns: repeat(3, 1fr); 
    gap: 3.5rem; 
  }
  @media (max-width: 1024px) { .news-grid { gap: 2.5rem; } }
  @media (max-width: 992px) { .news-grid { grid-template-columns: repeat(2, 1fr); } }
  @media (max-width: 640px) { .news-grid { grid-template-columns: 1fr; } }
  
  .news-card {
    background: #ffffff;
    border-radius: 32px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.6s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.6s;
    border: 1px solid rgba(0,0,0,0.05);
    box-shadow: 0 10px 40px rgba(0,0,0,0.02);
    height: 100%;
  }
  .news-card:hover {
    transform: translateY(-20px);
    box-shadow: 0 50px 100px rgba(15,76,129,0.12);
    border-color: var(--primary-light);
  }
  .news-card-img { 
    width: 100%;
    aspect-ratio: 16 / 10;
    overflow: hidden; 
    background: var(--bg2); 
    position: relative; 
  }
  .news-card-img img { 
    width: 100%; 
    height: 100%; 
    object-fit: cover; 
    display: block; 
    transition: transform 1.2s cubic-bezier(0.16, 1, 0.3, 1); 
  }
  .news-card:hover .news-card-img img { transform: scale(1.12); }
  
  .news-card-body { 
    padding: 3rem; 
    flex: 1; 
    display: flex; 
    flex-direction: column; 
    gap: 1.25rem; 
  }
  .news-card-date {
    font-size: .8rem;
    font-weight: 800;
    color: var(--accent);
    text-transform: uppercase;
    letter-spacing: 3px;
    display: block;
  }
  .news-card-body h3 {
    font-size: 1.6rem;
    color: var(--dark);
    line-height: 1.2;
    font-weight: 900;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    letter-spacing: -0.5px;
  }
  .news-card-body p {
    font-size: 1.1rem;
    color: var(--text-muted);
    line-height: 1.7;
    flex: 1;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  .news-card-body a.read-more {
    margin-top: 2rem;
    color: var(--primary);
    font-weight: 900;
    font-size: 1rem;
    display: inline-flex;
    align-items: center;
    gap: .75rem;
    transition: all .3s ease;
  }
  .news-card-body a.read-more:hover { gap: 1.2rem; color: var(--primary-h); }
  .news-card-body a.read-more::after {
    content: '→';
    font-size: 1.2rem;
  }

  /* ── FOOTER ─────────────────────────────────────── */
  .site-footer {
    background: var(--dark);
    color: rgba(255,255,255,.85);
    padding: 4.5rem 0 2rem;
    border-top: 1px solid rgba(255,255,255,.08);
    margin-top: 0;
  }
  .footer-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 3rem;
    margin-bottom: 3rem;
  }
  .footer-brand h3 {
    font-family: var(--font-d);
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--white);
    letter-spacing: -.3px;
    margin-bottom: .75rem;
  }
  .footer-brand p { font-size: .9rem; line-height: 1.6; color: rgba(255,255,255,.85); }
  .footer-social { display: flex; gap: .6rem; margin-top: 1.25rem; }
  .footer-social a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: rgba(255,255,255,.1);
    color: var(--white);
    font-size: .85rem;
    font-weight: 700;
    transition: background var(--tr), transform var(--tr);
  }
  .footer-social a:hover { background: var(--primary); transform: translateY(-2px); }
  .footer-links h4,
  .footer-contact h4 {
    color: var(--white);
    font-size: .85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .8px;
    margin-bottom: 1.25rem;
  }
  .footer-links ul { display: flex; flex-direction: column; gap: .6rem; }
  .footer-links ul li a {
    font-size: .9rem;
    color: rgba(255,255,255,.85);
    transition: color var(--tr);
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    min-height: 32px;
  }
  .footer-links ul li a::before { content: '›'; color: var(--accent); }
  .footer-links ul li a:hover { color: var(--white); }
  .footer-contact p { font-size: .88rem; color: rgba(255,255,255,.85); margin-bottom: .6rem; display: flex; align-items: flex-start; gap: .5rem; }
  .footer-bottom {
    text-align: center;
    padding-top: 1.75rem;
    border-top: 1px solid rgba(255,255,255,.2);
    color: rgba(255,255,255,.8);
    font-size: .82rem;
  }

  /* ── WhatsApp Popup + Llamar ─────────────────────── */
  .float-buttons-wrap{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9990;display:flex;flex-direction:column;align-items:flex-end;gap:0}
  .fab-group{display:flex;flex-direction:column;align-items:center;gap:.65rem}
  .fab{width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px rgba(0,0,0,.22);transition:transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .22s;text-decoration:none;border:none;cursor:pointer;flex-shrink:0}
  .fab:hover{transform:scale(1.1)}
  .wa-fab-toggle{background:#25d366}.wa-fab-toggle:hover{background:#1ebe5d;box-shadow:0 8px 28px rgba(37,211,102,.5)}
  .call-float-btn{background:#0f4c81}.call-float-btn:hover{background:#1565a0;box-shadow:0 8px 28px rgba(15,76,129,.45)}
  .wa-popup{position:absolute;bottom:calc(100% + .75rem);right:0;width:320px;background:#fff;border-radius:14px;box-shadow:0 12px 48px rgba(0,0,0,.18);overflow:hidden;opacity:0;transform:translateY(16px) scale(.97);pointer-events:none;transition:opacity .25s ease,transform .25s cubic-bezier(.34,1.2,.64,1)}
  .wa-popup.open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
  .wa-popup-header{background:#075e54;padding:1rem 1rem .9rem;display:flex;align-items:center;gap:.75rem}
  .wa-popup-header-icon{width:38px;height:38px;background:rgba(255,255,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .wa-popup-header-text{flex:1}.wa-popup-header-text strong{display:block;color:#fff;font-size:.95rem}.wa-popup-header-text span{color:rgba(255,255,255,.7);font-size:.78rem}
  .wa-popup-close{background:none;border:none;color:rgba(255,255,255,.75);font-size:1rem;cursor:pointer;padding:.25rem;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;transition:background .2s}.wa-popup-close:hover{background:rgba(255,255,255,.15);color:#fff}
  .wa-popup-body{padding:1rem}
  .wa-popup-greeting{font-size:.82rem;color:#475569;margin:0 0 .85rem;line-height:1.5}
  .wa-popup-agents{display:flex;flex-direction:column;gap:.6rem}
  .wa-popup-agent-btn{display:flex;align-items:center;gap:.75rem;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;padding:.65rem .85rem;text-decoration:none;transition:border-color .2s,background .2s,transform .2s}
  .wa-popup-agent-btn:hover{background:#f0fdf4;border-color:#25d366;transform:translateX(-2px)}
  .wa-popup-agent-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#25d366,#075e54);color:#fff;font-size:1.1rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;text-transform:uppercase}
  .wa-popup-agent-info{flex:1;min-width:0}.wa-popup-agent-info strong{display:block;font-size:.88rem;color:#1e293b;font-weight:600}.wa-popup-agent-info span{font-size:.76rem;color:#64748b}
  .wa-popup-agent-status{display:flex;align-items:center;gap:.3rem;font-size:.72rem;color:#14532d;font-weight:700;white-space:nowrap}
  .wa-status-dot{width:8px;height:8px;background:#16a34a;border-radius:50%;display:inline-block;animation:waPulse 2s infinite}
  @keyframes waPulse{0%,100%{opacity:1}50%{opacity:.4}}
  .wa-popup-footer{background:#f8fafc;border-top:1px solid #e2e8f0;padding:.65rem 1rem;font-size:.78rem;color:#64748b}
  @media(max-width:400px){.wa-popup{width:calc(100vw - 3rem);right:0}}

  /* ── Description content ────────────────────────── */
  .item-content { font-size: 1.05rem; color: var(--text); line-height: 1.8; overflow-x: auto; overflow-wrap: break-word; word-wrap: break-word; width: 100%; max-width: 100%; }
  .item-content h2 { color: var(--dark); margin: 2rem 0 1rem; font-size: 1.5rem; }
  .item-content h3 { color: var(--dark); margin: 1.5rem 0 .75rem; }
  .item-content p { margin-bottom: 1.1rem; max-width: 100%; }
  .item-content ul, .item-content ol { padding-left: 1.5rem; margin-bottom: 1.1rem; }
  .item-content li { margin-bottom: .4rem; }
  .item-content img, .item-content table, .item-content iframe { max-width: 100%; height: auto; border-radius: var(--radius); margin: 1.5rem 0; }
  .item-content table { width: 100% !important; border-collapse: collapse; }

  /* ── Shared btn ─────────────────────────────────── */
  .btn-primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    background: var(--primary);
    color: var(--white);
    padding: .85rem 1.75rem;
    border-radius: var(--radius);
    font-family: var(--font-d);
    font-weight: 700;
    font-size: .95rem;
    border: none;
    cursor: pointer;
    transition: background var(--tr), transform var(--tr), box-shadow var(--tr);
    min-height: 44px;
    text-decoration: none;
  }
  .btn-primary:hover {
    background: var(--primary-h);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(15,76,129,.3);
  }
  .btn-wa {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .6rem;
    background: #075e54 !important;
    color: #ffffff !important;
    padding: .85rem 1.75rem;
    border-radius: var(--radius);
    font-family: var(--font-d);
    font-weight: 700;
    font-size: .95rem;
    border: none;
    cursor: pointer;
    transition: all var(--tr);
    min-height: 44px;
    text-decoration: none;
    box-shadow: 0 4px 16px rgba(7,94,84,.35);
    letter-spacing: .2px;
  }
  .btn-wa:hover {
    background: #054a42 !important;
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(7,94,84,.5);
  }

  /* ── Brand badge ─────────────────────────────────── */
  .brand-title {
    font-size: .78rem;
    color: var(--primary);
    text-transform: uppercase;
    letter-spacing: 2px;
    font-weight: 700;
  }

  /* ── Stars ─────────────────────────────────────── */
  .star-rating { display: inline-flex; align-items: center; gap: .35rem; }
  .stars { color: #f59e0b; font-size: .95rem; letter-spacing: 1px; }
  .star-count { font-size: .82rem; color: var(--text-muted); }

  /* ── Responsive helpers ─────────────────────────── */
  @media (max-width: 640px) {
    .item-hero { height: 300px; }
    .hero-content { padding: 2rem 1.25rem 3rem; }
    .section-title { margin-bottom: 1.75rem; }
    #coverage-map { height: 320px; }
  }

  /* ── Product-specific styles ───────────────────── */
  .product-main { background: #fff; padding: 3.5rem 0; }
  .product-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 4rem; align-items: start; }
  @media (max-width: 960px) { .product-grid { grid-template-columns: 1fr; gap: 2.5rem; } }

  .gallery-wrap { display: flex; gap: .85rem; }
  .gallery-thumbs { display: flex; flex-direction: column; gap: .5rem; width: 76px; flex-shrink: 0; }
  .thumb-item {
    width: 76px; height: 90px;
    border: 2px solid var(--border);
    cursor: pointer;
    transition: all var(--tr);
    overflow: hidden;
    opacity: .6;
    border-radius: 8px;
    background: var(--bg2);
  }
  .thumb-item:hover { opacity: .85; border-color: #94a3b8; }
  .thumb-item.active { border-color: var(--primary); opacity: 1; }
  .thumb-item img { width: 100%; height: 100%; object-fit: cover; }
  .gallery-main {
    flex: 1;
    position: relative;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    height: 460px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: zoom-in;
  }
  .gallery-main img { max-height: 440px; object-fit: contain; padding: 1rem; width: 100%; }
  .gallery-badge {
    position: absolute;
    top: 1rem; left: 1rem;
    background: #dc2626;
    color: #fff;
    font-size: .78rem;
    font-weight: 800;
    padding: .3rem .7rem;
    border-radius: 6px;
    letter-spacing: .5px;
  }

  .product-info { display: flex; flex-direction: column; gap: 1.25rem; }
  .product-name { font-size: clamp(1.5rem, 3vw, 2.1rem); font-weight: 800; color: var(--dark); line-height: 1.2; }

  .product-trust { display: flex; align-items: center; gap: 1.25rem; font-size: .85rem; color: var(--text-muted); flex-wrap: wrap; }
  .trust-item { display: flex; align-items: center; gap: .35rem; }
  .trust-item svg { color: #059669; }

  .price-wrap { display: flex; align-items: baseline; gap: .85rem; flex-wrap: wrap; }
  .price-current { font-family: var(--font-d); font-size: 2.7rem; font-weight: 800; color: var(--primary); line-height: 1; }
  .price-currency { font-size: 1.3rem; vertical-align: top; }
  .price-original { font-size: 1.15rem; color: var(--text-muted); text-decoration: line-through; }
  .price-discount-badge {
    background: #dc2626;
    color: #fff;
    font-size: .78rem;
    font-weight: 800;
    padding: .25rem .6rem;
    border-radius: 6px;
    align-self: center;
  }

  .option-group-label { font-size: .85rem; font-weight: 700; color: var(--dark); margin-bottom: .6rem; }
  .options-wrap { display: flex; gap: .5rem; flex-wrap: wrap; }
  .option-btn {
    border: 1.5px solid var(--border);
    padding: .55rem .9rem;
    font-size: .85rem;
    font-weight: 700;
    cursor: pointer;
    transition: all var(--tr);
    background: #fff;
    border-radius: 8px;
    min-width: 64px;
    text-align: center;
    font-family: var(--font-b);
    min-height: 40px;
  }
  .option-btn:hover { border-color: var(--primary); color: var(--primary); }
  .option-btn.active { border-color: var(--primary); background: var(--primary-light); color: var(--primary); }

  .buy-actions { display: flex; flex-direction: column; gap: .75rem; }
  .buy-actions .btn-wa { font-size: 1rem; padding: 1rem 1.5rem; background: #115e59; }

  .specs-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .75rem 1.25rem;
    padding: 1.4rem;
    background: var(--bg2);
    border-radius: var(--radius);
    border: 1px solid var(--border);
  }
  @media (max-width: 480px) { .specs-list { grid-template-columns: 1fr; } }
  .spec-item { font-size: .88rem; color: var(--text); border-bottom: 1px solid rgba(0,0,0,.06); padding-bottom: .5rem; }
  .spec-item b { color: var(--dark); display: block; font-size: .78rem; text-transform: uppercase; letter-spacing: .3px; margin-bottom: .15rem; }

  .seller-info { 
    font-size: .9rem; 
    color: var(--text); 
    padding: 1rem 1.25rem; 
    background: #f8fafc; 
    border-radius: 12px; 
    border: 1px solid #e2e8f0; 
    box-shadow: inset 0 1px 2px rgba(0,0,0,0.02);
    display: flex;
    flex-direction: column;
    gap: .25rem;
  }
  .seller-info b { color: var(--primary); font-weight: 800; font-size: .8rem; text-transform: uppercase; letter-spacing: .5px; }

  .product-desc-section { padding: 5rem 0; background: #fff; }
  .product-desc-wrap { max-width: 900px; margin: 0 auto; }

  @media (max-width: 640px) {
    .gallery-wrap { flex-direction: column; }
    .gallery-thumbs { flex-direction: row; width: 100%; }
    .thumb-item { width: 64px; height: 70px; }
    .gallery-main { height: 300px; }
  }
