*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --blue:#00418D;
  --blue-50:oklch(97% 0.015 260);
  --blue-100:oklch(94% 0.03 260);
  --blue-200:oklch(88% 0.045 260);
  --blue-300:oklch(75% 0.06 260);
  --blue-400:oklch(60% 0.08 260);
  --blue-500:#00418D;
  --blue-600:oklch(30% 0.08 260);
  --blue-700:oklch(22% 0.06 260);
  --blue-800:#00418D;
  --white:#ffffff;
  --bg:#f5f7fa;
  --surface:#ffffff;
  --fg:#1a1a2e;
  --muted:#5b6778;
  --border:#dce0e8;
  --radius:3px;
  --radius-lg:3px;
  --shadow:0 1px 2px rgba(0,0,0,.06);
  --shadow-md:0 4px 12px rgba(0,0,0,.07);
  --font-display:"Raleway",sans-serif;
  --font-body:"Raleway",sans-serif;
  --font-mono:"Raleway",sans-serif;
  --max-w:1200px;
  --nav-h:56px
}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--fg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased
}
a{color:var(--blue);text-decoration:none}
img{max-width:100%;height:auto;display:block}
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 24px}

/* Nav — blue background, white text */
.nav{
  position:sticky;top:0;z-index:100;
  background:var(--blue);color:var(--white)
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  max-width:1280px;margin:0 auto;padding:0 16px
}
.nav-logo{display:flex;align-items:center;gap:10px;color:var(--white);font-weight:700;font-size:1rem;flex-shrink:0}
.nav-logo img{height:70px;width:auto;}
.nav-links{display:flex;gap:2px;list-style:none;align-items:center}
.nav-links a{
  display:flex;padding:6px 10px;color:rgba(255,255,255,.85);
  font-size:.85rem;font-weight:500;border-radius:var(--radius);
  transition:all .15s;white-space:nowrap;letter-spacing:.01em
}
.nav-links a:hover{background:rgba(255,255,255,.12);color:var(--white)}
.nav-links a.active{font-weight:600;position:relative}
.nav-links a.active::after{
  content:'';position:absolute;bottom:0;left:10px;right:10px;
  height:3px;background:rgba(230, 247, 81, 0.75);border-radius:2px
}
.nav-toggle{display:none;background:none;border:none;color:var(--white);font-size:1.5rem;cursor:pointer;padding:4px}

/* Dropdown on blue nav */
.nav-dropdown-wrap{position:relative}
.nav-dropdown{
  position:absolute;top:100%;left:0;min-width:200px;
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--radius-lg);box-shadow:var(--shadow-md);
  display:none;z-index:101;padding:4px
}
.nav-dropdown.open{display:block}
.nav-dropdown a{
  display:flex;align-items:center;gap:8px;
  padding:8px 12px;color:var(--fg);
  font-size:.8rem;border-radius:6px;white-space:nowrap
}
.nav-dropdown a:hover{background:var(--blue-50);color:var(--blue)}
.nav-dropdown svg{flex-shrink:0;opacity:.6}
@media (hover:hover){.nav-dropdown-wrap:hover .nav-dropdown{display:block}}

.nav-ext-link{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;border-radius:var(--radius);
  font-size:.78rem;font-weight:600;
}
.nav-ext-link img{height:40px;width:auto;object-fit:contain;flex-shrink:0}
.nav-ext-link:hover{background:rgba(255,255,255,.12);color:var(--white)}
.nav-ext-link.highlight:hover{background:rgba(255,255,255,.12);color:var(--white)}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 24px;border-radius:var(--radius-lg);
  font-family:var(--font-body);font-size:.875rem;font-weight:600;
  border:none;cursor:pointer;transition:all .2s;justify-content:center
}
.btn-primary{background:var(--blue);color:var(--white);padding:8px 18px}
.btn-primary:hover{background:var(--blue-600)}
.btn-gold{background:rgba(230, 247, 81, 0.75);color:var(--fg)}
.btn-gold:hover{background:rgba(230, 247, 81, 0.75)}
.btn-outline{background:transparent;border:2px solid var(--blue);color:var(--blue)}
.btn-outline:hover{background:var(--blue);color:var(--white)}
.btn-white{background:var(--white);color:var(--blue)}
.btn-white:hover{background:var(--blue-50)}

/* Hero — solid blue with grid */
.hero{
  position:relative;overflow:hidden;
  background:var(--blue);
  color:var(--white);padding:0
}
.hero-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;
  max-width:1360px;margin:0 auto;padding:48px 24px
}
.hero-text h1{font-size:clamp(1.3rem,2.6vw,1.85rem);font-weight:700;margin-bottom:10px;line-height:1.2}
.hero-text p{font-size:.92rem;line-height:1.7;opacity:.75;margin-bottom:16px}
.hero-text .hero-date{font-size:.72rem;opacity:.5;letter-spacing:.5px;display:block;margin-bottom:6px}
.hero-text .hero-link{display:inline-flex;align-items:center;gap:8px;color:rgba(230, 247, 81, 0.75);font-weight:600;font-size:.85rem;padding:8px 18px;background:rgba(255,255,255,.1);border-radius:var(--radius);transition:all .2s}
.hero-text .hero-link:hover{background:rgba(255,255,255,.2)}
.hero-media{padding:0;position:relative}
.hero-slider{
  border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,.3);
  aspect-ratio:16/10;background:var(--blue-600);
  position:relative
}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity .8s;z-index:0}
.hero-slide.active{opacity:1;z-index:1}
.hero-slide img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-slide-overlay{
  position:absolute;bottom:0;left:0;right:0;
  padding:20px 20px 48px;
  background:linear-gradient(transparent 20%,rgba(0,0,0,.85));
  z-index:2
}
.hero-slide-date{font-size:.68rem;opacity:.6;letter-spacing:.5px;display:block;margin-bottom:2px}
.hero-slide-overlay .cat{font-size:.68rem;font-weight:600;opacity:.8;display:inline-block;padding:2px 8px;border-radius:4px;background:rgba(255,255,255,.12);margin-bottom:4px;letter-spacing:.3px}
.hero-slide-overlay h2{font-size:clamp(.85rem,1.2vw,1rem);margin-bottom:2px;line-height:1.25;font-weight:600}
.hero-slide-overlay p{display:none}
.hero-slider-nav{
  position:absolute;bottom:16px;left:50%;transform:translateX(-50%);
  display:flex;gap:8px;z-index:3
}
.hero-slider-nav button{
  width:10px;height:10px;border-radius:50%;border:2px solid rgba(255,255,255,.6);
  background:transparent;cursor:pointer;transition:all .3s;padding:0
}
.hero-slider-nav button.active{background:var(--white);border-color:var(--white)}
.hero-slider-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.2);backdrop-filter:blur(4px);
  border:1px solid rgba(255,255,255,.3);color:var(--white);
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:all .2s;z-index:3
}
.hero-slider-arrow:hover{background:rgba(255,255,255,.35)}
.hero-slider-arrow.prev{left:16px}
.hero-slider-arrow.next{right:16px}
.hero-slider-arrow svg{width:22px;height:22px}

/* Section headers — asymmetric */
.section{padding:48px 0}
.section-full{display:flex;flex-direction:column;gap:32px}
.section-full .section-header{text-align:center;max-width:700px;margin:0 auto}
.section-full .section-header h2{font-size:clamp(1.3rem,2.2vw,1.6rem);color:var(--blue);font-weight:700;margin-bottom:6px}
.section-full .section-header p{color:var(--muted);font-size:.9rem;margin-bottom:12px}
.section-full .content-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}

/* Split layout — 2 cols, asymmetric */
.split-wrap{max-width:var(--max-w);margin:0 auto;padding:0 24px}
.split-section{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center}
.split-section-visual{border-radius:var(--radius-lg);overflow:hidden;background:var(--blue-100);width:100%;justify-self:center}
.split-section-visual img{width:100%;height:100%;object-fit:cover}
.split-section-text{display:flex;flex-direction:column;justify-content:center;padding:24px 0;gap:2px}
.split-section-text h2{font-family:var(--font-display);font-size:clamp(1.4rem,2.8vw,2rem);color:var(--blue);margin-bottom:8px;font-weight:700;line-height:1.2}
.split-section-text p{color:var(--muted);font-size:.92rem;line-height:1.7;margin-bottom:14px}
.split-section-text .meta{font-size:.78rem;color:var(--muted);margin-bottom:8px}
.split-section-text .tag{display:inline-block;padding:2px 10px;border-radius:10px;background:rgba(230, 247, 81, 0.75);color:var(--fg);font-size:.72rem;font-weight:600;margin-bottom:8px}
.split-section-fw{max-width:var(--max-w);margin:0 auto;padding:0 24px}

/* Stats — full width blue bar */
.stats{background:var(--blue);color:var(--white);padding:48px 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;max-width:var(--max-w);margin:0 auto;padding:0 24px}
.stat{text-align:center}
.stat-number{font-family:var(--font-display);font-size:2.25rem;font-weight:700}
.stat-label{opacity:.8;font-size:.85rem;margin-top:4px}

/* Cards — 3 types */
.news-link{display:block;text-decoration:none;color:inherit;margin-bottom:12px}
.news-link:hover .card-horiz{border-color:var(--blue);box-shadow:var(--shadow-md)}
.news-link:hover .card-horiz-img img{transform:scale(1.03)}
.card-horiz{display:grid;grid-template-columns:240px 1fr;gap:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow .2s,border-color .2s}
.card-horiz-img{aspect-ratio:16/12;overflow:hidden}
.card-horiz-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.card-horiz-body{padding:20px 24px;display:flex;flex-direction:column;justify-content:center}
.card-horiz-body h3{font-size:1rem;margin-bottom:6px;line-height:1.3;color:var(--fg)}
.card-horiz-body p{font-size:.85rem;color:var(--muted);line-height:1.6;margin-bottom:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-horiz-body .date{font-size:.75rem;color:var(--muted);margin-bottom:4px}

.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.service-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow .2s;position:relative}
.service-item::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px}
.service-item:hover{box-shadow:var(--shadow-md)}
.service-item-body{padding:24px;text-align:center}
.service-item-icon{width:48px;height:48px;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--blue-50);color:var(--blue)}
.service-item h3{font-size:.95rem;margin-bottom:6px}
.service-item p{font-size:.82rem;color:var(--muted);line-height:1.5}
.service-item.urban::after{background:var(--blue)}
.service-item.enviro::after{background:#2d9b4e}
.service-item.social::after{background:rgba(230, 247, 81, 0.75)}
.service-item.public::after{background:var(--blue-400)}
.service-item.risk::after{background:#dc3545}
.service-item.cadastre::after{background:#6f42c1}

.council-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow .2s}
.council-card:hover{box-shadow:var(--shadow-md);border-color:var(--blue-200)}
.council-photo{width:100%;aspect-ratio:4/3;overflow:hidden;background:var(--blue-100)}
.council-photo img{width:100%;height:100%;object-fit:cover}
.council-info{padding:16px}
.council-info h4{font-size:.88rem;margin-bottom:2px}
.council-info p{font-size:.78rem;color:var(--muted)}
.council-info .role{display:inline-block;padding:2px 10px;border-radius:10px;background:rgba(230, 247, 81, 0.75);color:var(--fg);font-size:.68rem;font-weight:600;margin-top:4px}

.card{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden;transition:box-shadow .2s}
.card:hover{box-shadow:var(--shadow-md);border-color:var(--blue-200)}
.card-img{aspect-ratio:16/10;overflow:hidden;background-size:cover;background-position:center}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.card:hover .card-img img{transform:scale(1.03)}
.card-body{padding:20px}
.card-body h3{font-size:1.05rem;margin-bottom:8px;line-height:1.3}
.card-body p{font-size:.875rem;color:var(--muted);line-height:1.6}
.card-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.card-footer .date{font-size:.75rem;color:var(--muted)}

.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}

.quick-links{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.quick-link{display:flex;align-items:center;gap:14px;padding:20px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all .2s;color:var(--fg)}
.quick-link:hover{background:var(--blue-50);border-color:var(--blue);color:var(--blue)}
.quick-link .icon{font-size:1.5rem}
.quick-link span{font-weight:500;font-size:.88rem}

.form-group{margin-bottom:20px}
.form-group label{display:block;font-weight:600;font-size:.875rem;margin-bottom:6px;color:var(--fg)}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-body);font-size:.9rem;transition:border-color .2s;background:var(--surface)}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-100)}
.form-group textarea{min-height:120px;resize:vertical}

.accordion{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.accordion details{border-bottom:1px solid var(--border)}
.accordion details:last-child{border-bottom:none}
.accordion summary{width:100%;padding:16px 20px;background:var(--surface);border:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-family:var(--font-body);font-weight:600;font-size:.95rem;text-align:left;color:var(--fg);transition:background .2s;list-style:none}
.accordion summary::-webkit-details-marker{display:none}
.accordion summary::after{content:'+';font-size:1.2rem;color:var(--blue);transition:transform .2s;font-weight:700}
.accordion details[open] summary::after{content:'−'}
.accordion summary:hover{background:var(--blue-50)}
.accordion-body,.accordion-content{padding:16px 20px}
.accordion-body p,.accordion-content p{font-size:.875rem;color:var(--muted);line-height:1.7;margin-bottom:8px}
.accordion-body ul,.accordion-content ul{margin:8px 0 8px 20px;font-size:.875rem;color:var(--muted);line-height:1.7}
.accordion-body ul li,.accordion-content ul li{margin-bottom:4px}

.gallery-item{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer;aspect-ratio:1/1}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gallery-item:hover img{transform:scale(1.06)}
.gallery-item .overlay{position:absolute;inset:0;background:linear-gradient(transparent 50%,rgba(0,0,0,.5));opacity:0;transition:opacity .3s;display:flex;align-items:flex-end;padding:16px;color:var(--white);font-size:.85rem;font-weight:500;pointer-events:none}
.gallery-item:hover .overlay{opacity:1}

/* Video card */
.video-card{border-radius:var(--radius-lg);overflow:hidden;background:var(--surface);border:1px solid var(--border);transition:box-shadow .2s}
.video-card:hover{box-shadow:var(--shadow-md);border-color:var(--blue-200)}
.video-card .thumb{aspect-ratio:16/9;background:var(--blue-200);position:relative;overflow:hidden}
.video-card iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}
.video-card .body{padding:14px 16px}
.video-card .body h4{font-size:.82rem;margin-bottom:2px;color:var(--fg);font-weight:600;line-height:1.3}
.video-card .body p{font-size:.72rem;color:var(--muted);display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.video-card .body .video-badge{display:inline-block;padding:1px 8px;border-radius:8px;font-size:.62rem;font-weight:600;margin-bottom:4px}
.video-card .body .video-badge.deportes{background:#dbeafe;color:#1d4ed8}
.video-card .body .video-badge.obras{background:#fef3c7;color:#92400e}
.video-card .body .video-badge.comunidad{background:#d1fae5;color:#065f46}
.video-card .body .video-badge.entrevistas{background:#ede9fe;color:#5b21b6}

/* Feature highlight */
.feature-highlight{background:var(--blue);color:var(--white);border-radius:var(--radius-lg);padding:48px;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;margin:48px 0}
.feature-highlight h3{font-family:var(--font-display);font-size:clamp(1.2rem,2.2vw,1.6rem);margin-bottom:12px;font-weight:700}
.feature-highlight p{opacity:.85;font-size:.92rem;line-height:1.7;margin-bottom:20px}

/* Editorial — magazine style */
.editorial-link{display:block;text-decoration:none;color:inherit;margin-bottom:20px}
.editorial-link:hover .editorial-card{border-color:var(--blue);background:var(--blue-50)}
.editorial-link:hover .editorial-card-img img{transform:scale(1.04)}
.editorial-card{display:grid;grid-template-columns:120px 1fr;gap:16px;align-items:stretch;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;padding:12px;background:var(--surface);transition:border-color .2s,background .2s}
.editorial-card-img{width:120px;min-height:90px;border-radius:6px;overflow:hidden;flex-shrink:0}
.editorial-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.editorial-card-body{min-width:0}
.editorial-card-body h3{font-size:.92rem;margin-bottom:3px;color:var(--fg);font-weight:600;line-height:1.3}
.editorial-card-body .meta{font-size:.72rem;color:var(--muted);margin-bottom:4px}
.editorial-card-body p{font-size:.8rem;color:var(--muted);line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.editorial-card.featured{display:block;border-left:none;background:var(--blue-50);border:1px solid var(--border);padding:24px;margin-bottom:32px}
.editorial-card.featured h3{font-size:1.1rem;margin-bottom:6px}
.editorial-card.featured p{font-size:.88rem;-webkit-line-clamp:none}
.editorial-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}

/* Empty state */
.empty-state{text-align:center;padding:60px 20px;color:var(--muted)}
.empty-state svg{margin-bottom:16px;opacity:.4}
.empty-state p{font-size:.95rem}

/* Filter bar */
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}
.filter-btn{padding:6px 16px;border:1px solid var(--border);border-radius:20px;background:var(--surface);cursor:pointer;font-family:var(--font-body);font-size:.82rem;transition:all .2s;color:var(--fg)}
.filter-btn.active,.filter-btn:hover{background:var(--blue);color:var(--white);border-color:var(--blue)}

/* Video category */
.video-cat{display:inline-block;padding:2px 10px;border-radius:10px;font-size:.68rem;font-weight:600;margin-bottom:6px}

.inline-list{list-style:none}
.inline-list li{margin-bottom:6px;font-size:.85rem;color:var(--muted);display:flex;gap:8px;align-items:flex-start}

.council-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:24px}
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.phase-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}
.phase-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;position:relative;transition:box-shadow .2s}
.phase-card:hover{box-shadow:var(--shadow-md)}
.phase-card-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border);background:var(--blue-50)}
.phase-card-header h3{font-size:.88rem;font-weight:600;margin:0}
.phase-card-status{font-size:.68rem;font-weight:600;padding:3px 10px;border-radius:12px;white-space:nowrap}
.phase-card-status.done{background:#d1fae5;color:#065f46}
.phase-card-status.current{background:var(--blue-100);color:var(--blue)}
.phase-card-status.next{background:rgba(230, 247, 81, 0.75);color:var(--fg)}
.phase-card-body{padding:20px}
.phase-card-body .date{font-size:.78rem;color:var(--muted);margin-bottom:8px;display:block}
.phase-card-body p{font-size:.85rem;color:var(--muted);line-height:1.7}
.phase-card-img{margin:0 -20px -20px;aspect-ratio:16/8;overflow:hidden;background:var(--blue-100)}
.phase-card-img img{width:100%;height:100%;object-fit:cover}

/* Alcalde profile */
.profile-header{display:grid;grid-template-columns:280px 1fr;gap:40px;align-items:start;margin-bottom:48px}
.profile-img{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);aspect-ratio:3/4}
.profile-img img{width:100%;height:100%;object-fit:cover}
.profile-info h1{font-family:var(--font-display);font-size:clamp(1.6rem,2.8vw,2.2rem);color:var(--blue);margin-bottom:4px;font-weight:700}
.profile-info .title{font-size:1rem;color:var(--muted);margin-bottom:16px}
.profile-info .bio{font-size:.92rem;line-height:1.8;color:var(--fg);margin-bottom:20px}
.profile-actions{display:flex;gap:12px;flex-wrap:wrap}

/* Back to top */
.back-top{position:fixed;bottom:32px;right:32px;width:44px;height:44px;border-radius:50%;background:var(--blue);color:var(--white);border:none;cursor:pointer;display:none;align-items:center;justify-content:center;box-shadow:var(--shadow-md);z-index:50;transition:all .2s}
.back-top.visible{display:flex}
.back-top:hover{background:var(--blue-600)}

/* Cookie consent */
.cookie-bar{position:fixed;bottom:0;left:0;right:0;background:var(--blue-800);color:rgba(255,255,255,.9);padding:16px 24px;display:none;z-index:300;font-size:.85rem}
.cookie-bar.visible{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.cookie-bar p{max-width:800px;line-height:1.6}
.cookie-bar .btn{flex-shrink:0}

/* Tags */
.tag{display:inline-block;padding:3px 10px;border-radius:12px;font-size:.7rem;font-weight:600}
.tag-blue{background:var(--blue-100);color:var(--blue)}
.tag-gold{background:rgba(230, 247, 81, 0.75);color:var(--fg)}
.tag-green{background:#d1fae5;color:#065f46}

/* Gov card — institutional government card */
.gov-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.gov-card-link{display:block;text-decoration:none;color:inherit}
.gov-card-link:hover .gov-card{box-shadow:var(--shadow-md);border-color:var(--blue)}
.gov-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);overflow:hidden;
  transition:box-shadow .2s,border-color .2s;height:100%
}
.gov-card-img{aspect-ratio:16/10;overflow:hidden;position:relative;background:var(--blue-100)}
.gov-card-img iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}
.gov-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gov-card-link:hover .gov-card-img img{transform:scale(1.03)}
.gov-card-body{padding:18px 20px;display:flex;flex-direction:column;gap:6px}
.gov-card-cat{display:inline-block;padding:2px 10px;border-radius:10px;font-size:.68rem;font-weight:600;background:var(--blue-50);color:var(--blue);align-self:flex-start;line-height:1.4}
.gov-card-body h3{font-size:.92rem;font-weight:600;line-height:1.3;margin:0;color:var(--fg)}
.gov-card-body p{font-size:.8rem;color:var(--muted);line-height:1.6;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.gov-card-date{font-size:.72rem;color:var(--muted)}

/* Nota single article styles */
.nota-hero-img{width:100%;aspect-ratio:16/9;max-height:480px;overflow:hidden;border-radius:var(--radius-lg) var(--radius-lg) 0 0;position:relative}
.nota-hero-img img{width:100%;height:100%;object-fit:cover;display:block}
.nota-hero-img::after{content:'';position:absolute;bottom:0;left:0;right:0;height:50%;background:linear-gradient(transparent,rgba(0,0,0,.5))}
.nota-meta{display:flex;flex-wrap:wrap;gap:8px 20px;font-size:.82rem;color:var(--muted);margin-top:4px}
.nota-meta span{display:inline-flex;align-items:center;gap:5px;font-family:Helvetica,Arial,sans-serif}
.nota-body{max-width:800px;margin:0 auto}
.nota-body p{font-size:.95rem;line-height:1.85;color:var(--fg);margin-bottom:18px}
.nota-body p:last-child{margin-bottom:0}
.nota-body h2{font-size:1.1rem;color:var(--blue);margin:24px 0 10px;font-weight:700}
.nota-body blockquote{border-left:3px solid rgba(230, 247, 81, 0.75);padding:16px 24px;margin:24px 0;background:var(--blue-50);border-radius:0 var(--radius) var(--radius) 0;font-style:italic;color:var(--fg);font-size:.9rem;position:relative}
.nota-body blockquote::before{content:'"';font-size:2.5rem;color:rgba(230, 247, 81, 0.75);opacity:.4;position:absolute;top:-4px;left:12px;font-family:Georgia,serif;line-height:1}
.nota-share{padding:24px 0;margin:32px 0 0;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.nota-share span{font-size:.78rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.nota-share a{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--blue-100);color:var(--blue);transition:background .15s}
.nota-share a:hover{background:var(--blue);color:var(--white)}
.nota-share a svg{width:16px;height:16px}
.nota-author-card{display:flex;align-items:center;gap:14px;padding:16px 20px;background:var(--blue-50);border-radius:var(--radius);margin-top:20px}
.nota-author-card div strong{font-size:.88rem;color:var(--fg);display:block;font-family:Helvetica,Arial,sans-serif}
.nota-author-card div span{font-size:.78rem;color:var(--muted);font-family:Helvetica,Arial,sans-serif}
.nota-back{display:inline-flex;align-items:center;gap:6px;font-size:.85rem;color:var(--blue);font-weight:500;margin-top:24px}
.nota-back svg{width:16px;height:16px}
.nota-related{margin-top:48px;padding-top:32px;border-top:2px solid var(--border)}
.nota-related h3{font-size:1rem;color:var(--blue);margin-bottom:16px;font-weight:700}
.nota-related-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.nota-related-card{display:block;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:box-shadow .15s,border-color .15s;text-decoration:none}
.nota-related-card:hover{box-shadow:var(--shadow-sm);border-color:var(--blue-200)}
.nota-related-card img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block}
.nota-related-card .body{padding:10px 12px 12px}
.nota-related-card .body h4{font-size:.82rem;color:var(--fg);font-weight:600;line-height:1.3;margin-bottom:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.nota-related-card .body .date{font-size:.7rem;color:var(--muted)}
.nota-related-card .body .badge{display:inline-block;padding:1px 8px;border-radius:8px;font-size:.62rem;font-weight:600;margin-bottom:4px}
.nota-related-card .body .badge.noticia{background:var(--blue-100);color:var(--blue)}
.nota-related-card .body .badge.editorial{background:rgba(230, 247, 81, 0.75);color:var(--fg)}
.nota-loading{text-align:center;padding:80px 20px;color:var(--muted)}
.nota-loading svg{animation:spin .8s linear infinite;margin-bottom:12px}
@keyframes spin{to{transform:rotate(360deg)}}

/* Empty state */
.empty-state{text-align:center;padding:60px 20px;color:var(--muted)}
.empty-state svg{margin-bottom:16px;opacity:.4}
.empty-state p{font-size:.95rem}

.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}

/* Filter bar for videos */
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}
.filter-btn{
  padding:6px 16px;border:1px solid var(--border);border-radius:20px;
  background:var(--surface);cursor:pointer;font-family:var(--font-body);
  font-size:.82rem;transition:all .2s;color:var(--fg)
}
.filter-btn.active,.filter-btn:hover{background:var(--blue);color:var(--white);border-color:var(--blue)}

/* Video category label */
.video-cat{display:inline-block;padding:2px 10px;border-radius:10px;font-size:.68rem;font-weight:600;margin-bottom:6px}
.video-cat.deportes{background:#dbeafe;color:#1d4ed8}
.video-cat.obras{background:#fef3c7;color:#92400e}
.video-cat.comunidad{background:#d1fae5;color:#065f46}
.video-cat.entrevistas{background:#ede9fe;color:#5b21b6}

/* Form note on encuesta */
.form-note{font-size:.8rem;color:var(--muted);margin-top:8px;font-style:italic}

.inline-list{list-style:none}
.inline-list li{margin-bottom:6px;font-size:.85rem;color:var(--muted);display:flex;gap:8px;align-items:flex-start}

/* Footer — 5 columns */
.footer{background:var(--blue-800);color:rgba(255,255,255,.8);padding:48px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:24px;max-width:var(--max-w);margin:0 auto;padding:0 24px}
.footer h4{color:var(--white);font-size:.88rem;margin-bottom:14px;font-weight:600;letter-spacing:.02em;text-transform:uppercase}
.footer p{font-size:.82rem;line-height:1.7;color:rgba(255,255,255,.7)}
.footer-links{list-style:none}
.footer-links li{margin-bottom:6px}
.footer-links a{color:rgba(255,255,255,.65);font-size:.82rem;transition:color .15s}
.footer-links a:hover{color:rgba(230, 247, 81, 0.75)}
.footer-contact-item{display:flex;gap:8px;margin-bottom:8px;align-items:flex-start}
.footer-contact-item svg{flex-shrink:0;margin-top:3px;color:rgba(230, 247, 81, 0.75)}
.footer-social{display:flex;gap:10px;margin-top:14px}
.footer-social a{
  display:flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;
  background:rgba(255,255,255,.08);color:rgba(255,255,255,.7);
  font-size:.9rem;transition:all .2s
}
.footer-social a:hover{background:rgba(230, 247, 81, 0.75);color:var(--blue-800)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);
  padding:18px;text-align:center;font-size:.78rem;
  margin-top:32px;color:rgba(255,255,255,.5)
}
.footer-bottom a{color:rgba(255,255,255,.7)}

/* Breadcrumb */
.breadcrumb{background:var(--blue-50);padding:12px 0;font-size:.85rem;border-bottom:1px solid var(--border)}
.breadcrumb-inner{max-width:var(--max-w);margin:0 auto;padding:0 24px}
.breadcrumb a{color:var(--blue)}
.breadcrumb span{color:var(--muted)}

/* Page hero — compact, left-aligned, white, gold top border */
.page-hero{border-top:3px solid rgba(230, 247, 81, 0.75);background:var(--white);padding:28px 0}
.page-hero h1{font-size:clamp(1.3rem,2.4vw,1.75rem);color:var(--blue);font-weight:700;margin-bottom:4px}
.page-hero p{color:var(--muted);font-size:.92rem;max-width:600px}

/* Content text */
.content-text p{margin-bottom:16px;font-size:.92rem;line-height:1.8;color:var(--fg)}
.content-text p:last-child{margin-bottom:0}
.content-text strong{color:var(--blue)}

/* Contact cards */
.contact-cards{display:grid;gap:16px}
.contact-cards .card h3{font-size:.9rem;color:var(--blue);margin-bottom:4px}
.contact-cards .card p{font-size:.875rem}
.contact-cards .card{margin-bottom:0}

/* Table */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:.875rem}
thead{background:var(--blue);color:var(--white)}
th{padding:12px 16px;text-align:left;font-weight:600}
td{padding:10px 16px;border-bottom:1px solid var(--border);font-size:.85rem}
tr:hover td{background:var(--blue-50)}

/* Search */
.search-box{display:flex;gap:8px;margin-bottom:24px}
.search-box input{flex:1;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-body)}
.search-box input:focus{outline:none;border-color:var(--blue)}

/* Icon wrapper */
.icon-svg{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0}
.icon-svg.lg{width:40px;height:40px}
.icon-svg.sm{width:18px;height:18px}

/* Btn-white for light backgrounds */
.btn-white{background:var(--white);color:var(--blue);border:1px solid var(--border)}
.btn-white:hover{background:var(--blue-50)}

/* Skip to content */
.skip-link{position:absolute;top:-100%;left:8px;padding:8px 16px;background:var(--blue);color:var(--white);z-index:999;border-radius:0 0 var(--radius) var(--radius);font-weight:600;font-size:.85rem}
.skip-link:focus{top:0}

/* Back to top */
.back-top{position:fixed;bottom:24px;right:24px;width:40px;height:40px;border-radius:50%;background:var(--blue);color:var(--white);display:none;align-items:center;justify-content:center;cursor:pointer;z-index:99;border:none;opacity:.8;transition:opacity .2s}
.back-top.visible{display:flex}

/* Footer logo */
.footer-logo{max-width:180px;height:auto;display:block;margin-bottom:8px}

/* Cookie bar */
.cookie-bar{position:fixed;bottom:0;left:0;right:0;background:var(--fg);color:var(--white);padding:12px 24px;display:none;align-items:center;justify-content:space-between;gap:16px;z-index:999;font-size:.85rem}
.cookie-bar.visible{display:flex}

/* Lightbox Gallery */
.lightbox{position:fixed;inset:0;z-index:1000;display:none;background:rgba(0,0,0,.98)}
.lightbox.open{display:block}
.lightbox-inner{position:relative;width:100%;height:100%;background-size:contain;background-position:center;background-repeat:no-repeat}
.lightbox-img{display:none}
.lightbox-close{position:fixed;top:16px;right:16px;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.12);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:1001}
.lightbox-close:hover{background:rgba(230, 247, 81, 0.75);color:var(--blue-800)}
.lightbox-close svg{width:22px;height:22px}
.lightbox-nav{position:fixed;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.12);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:1001}
.lightbox-nav:hover{background:rgba(230, 247, 81, 0.75);color:var(--blue-800)}
.lightbox-nav svg{width:22px;height:22px}
.lightbox-nav.prev{left:16px}
.lightbox-nav.next{right:16px}
.lightbox-counter{position:fixed;bottom:16px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.6);font-size:.8rem;font-weight:500;letter-spacing:.05em;z-index:1001}

@media(max-width:768px){
  .lightbox-nav{width:40px;height:40px}
  .lightbox-nav svg{width:18px;height:18px}
  .lightbox-nav.prev{left:8px}
  .lightbox-nav.next{right:8px}
  .lightbox-close{top:8px;right:8px}
  .lightbox-counter{bottom:8px;font-size:.7rem}
}

/* Survey / Encuesta */
.main-content{padding:48px 0}
.main-content .lead{font-size:1.05rem;color:var(--fg);font-weight:500;margin-bottom:12px}
.content-text--center{max-width:720px;margin:0 auto 36px;text-align:center}
.survey-form{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:28px}
.survey-question{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;transition:box-shadow .2s}
.survey-question:hover{box-shadow:var(--shadow-md)}
.survey-question-number{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--blue);color:var(--white);font-size:.78rem;font-weight:700;margin-bottom:10px}
.survey-label{display:block;font-weight:600;font-size:.95rem;color:var(--fg);margin-bottom:14px;line-height:1.4}
.survey-options{display:flex;flex-wrap:wrap;gap:10px}
.survey-options.vertical{flex-direction:column}
.survey-option{position:relative}
.survey-option input{position:absolute;opacity:0;pointer-events:none}
.survey-option label{display:flex;align-items:center;gap:8px;padding:10px 18px;border:2px solid var(--border);border-radius:var(--radius);font-size:.85rem;font-weight:500;color:var(--fg);cursor:pointer;transition:all .2s;background:var(--bg);user-select:none}
.survey-option label:hover{border-color:var(--blue-300);background:var(--blue-100)}
.survey-option input:checked+label{border-color:var(--blue);background:var(--blue-100);color:var(--blue)}
.survey-option.radio label::before{content:'';width:18px;height:18px;border-radius:50%;border:2px solid var(--border);flex-shrink:0;transition:all .2s;background:var(--surface)}
.survey-option.radio input:checked+label::before{border-color:var(--blue);background:var(--blue);box-shadow:inset 0 0 0 4px var(--surface)}
.survey-option.check label::before{content:'';width:18px;height:18px;border-radius:4px;border:2px solid var(--border);flex-shrink:0;transition:all .2s;background:var(--surface)}
.survey-option.check input:checked+label::before{border-color:var(--blue);background:var(--blue);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:12px}
.survey-scale{display:flex;gap:6px}
.survey-scale-item{flex:1;text-align:center}
.survey-scale-item input{position:absolute;opacity:0;pointer-events:none}
.survey-scale-item label{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px 10px;border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .2s;background:var(--bg);user-select:none}
.survey-scale-item label:hover{border-color:var(--blue-300);background:var(--blue-100)}
.survey-scale-item input:checked+label{border-color:var(--blue);background:var(--blue-100)}
.survey-scale-item .scale-num{font-size:1.3rem;font-weight:700;color:var(--fg);line-height:1}
.survey-scale-item input:checked+label .scale-num{color:var(--blue)}
.survey-scale-item .scale-label{font-size:.7rem;color:var(--muted);line-height:1.2}
.survey-scale-item input:checked+label .scale-label{color:var(--blue)}
.survey-field{width:100%;padding:14px 16px;border:2px solid var(--border);border-radius:var(--radius);font-family:var(--font-body);font-size:.9rem;min-height:120px;resize:vertical;background:var(--bg);transition:border-color .2s}
.survey-field:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-100)}
.survey-actions{display:flex;justify-content:center;padding-top:8px}
.survey-actions .btn{padding:14px 36px;font-size:1rem}
.survey-success{max-width:500px;margin:0 auto;text-align:center;padding:60px 24px;background:var(--surface);border:2px solid rgba(230, 247, 81, 0.75);border-radius:var(--radius-lg)}
.survey-success svg{margin-bottom:16px}
.survey-success h2{font-family:var(--font-display);font-size:1.6rem;color:var(--blue);margin-bottom:12px}
.survey-success p{color:var(--muted);font-size:.95rem;line-height:1.6}
.survey-check-group{display:flex;flex-wrap:wrap;gap:10px}

/* Valores institucionales */
.valor-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px 24px;display:flex;flex-direction:column;gap:8px;transition:box-shadow .2s}
.valor-card:hover{border-color:var(--blue-200);box-shadow:var(--shadow-md)}
.valor-icon{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;color:var(--white);margin-bottom:4px}
.valor-card h3{font-size:1.1rem;font-weight:600}
.valor-card p{font-size:.9rem;color:var(--muted);line-height:1.6}
.ethos-list{list-style:none;display:flex;flex-direction:column;gap:16px;max-width:800px;margin:0 auto}
.ethos-list li{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;display:flex;gap:16px;align-items:flex-start}
.ethos-num{width:36px;height:36px;border-radius:50%;background:var(--blue);color:var(--white);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1rem;font-weight:700;flex-shrink:0;line-height:1}
.ethos-list li p{font-size:.95rem;line-height:1.6;color:var(--fg)}
.mision-vision{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:32px}
.mv-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:32px}
.mv-card h3{font-family:var(--font-display);font-size:1.4rem;margin-bottom:12px;display:flex;align-items:center;gap:10px}
.mv-card p{font-size:1.05rem;line-height:1.8;color:var(--fg)}

/* Survey responsive */
@media(max-width:600px){
  .survey-scale{flex-wrap:wrap}
  .survey-scale-item{flex:0 0 calc(33.333% - 6px)}
  .survey-question{padding:18px}
  .survey-options{gap:8px}
  .survey-option label{padding:8px 14px;font-size:.82rem}
}

/* Responsive */
@media(max-width:968px){
  .nav-links{
    display:none;position:absolute;top:var(--nav-h);left:0;right:0;
    background:var(--blue);flex-direction:column;padding:8px;
    max-height:calc(100vh - var(--nav-h));
    overflow-y:auto;-webkit-overflow-scrolling:touch
  }
  .nav-links.open{display:flex}
  .nav-toggle{display:block}
  .nav-links > li{width:100%}
  .nav-links a{font-size:.88rem;padding:10px 14px;white-space:normal;color:rgba(255,255,255,.85)}
  .nav-links a.active::after{display:none}
  .nav-links a.active{background:rgba(255,255,255,.15);border-radius:var(--radius)}
  .nav-dropdown-wrap > a::after{float:right}
  .nav-dropdown{position:static;box-shadow:none;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.08);padding:4px 0 4px 8px;margin-top:4px}
  .nav-dropdown a{color:rgba(255,255,255,.8) !important;font-size:.85rem;padding:8px 12px}
  .nav-dropdown a:hover{background:rgba(255,255,255,.1);color:var(--white) !important}
  .nav-dropdown svg{color:rgba(255,255,255,.6)}
  .nav-ext-link{font-size:.85rem;padding:10px 14px;width:100%;justify-content:center}
  .hero-grid{grid-template-columns:1fr;gap:24px;padding:32px 24px}
  .hero-text h1{font-size:1.1rem}
  .hero-text p{font-size:.85rem}
  .gov-card-grid{grid-template-columns:1fr}
  .hero-slider-arrow{width:36px;height:36px}
  .hero-slider-arrow svg{width:16px;height:16px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .feature-highlight{grid-template-columns:1fr;padding:32px}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .quick-links{grid-template-columns:repeat(2,1fr)}
  .profile-header{grid-template-columns:1fr;text-align:center}
  .profile-actions{justify-content:center}
  .cookie-bar{flex-direction:column;text-align:center}
  .split-section{grid-template-columns:1fr;gap:20px}
  .split-section-visual{max-width:100%}
  .card-horiz{grid-template-columns:1fr}
  .card-horiz-img{aspect-ratio:16/10;max-height:none;min-height:180px}
  .editorial-card{grid-template-columns:1fr;gap:10px}
  .editorial-card-img{width:100%;height:160px}
  .service-grid{grid-template-columns:1fr 1fr}
  .council-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}
  .editorial-grid{grid-template-columns:1fr}
  .home-video-grid{grid-template-columns:1fr!important}
}
@media(max-width:768px){
  .footer-grid{grid-template-columns:1fr}
  .service-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .hero-slider-arrow{width:36px;height:36px;top:auto;bottom:16px;transform:none;background:rgba(0,0,0,.5);backdrop-filter:none;border-color:rgba(255,255,255,.2)}
  .hero-slider-arrow svg{width:18px;height:18px}
  .hero-slider-arrow.prev{left:16px}
  .hero-slider-arrow.next{right:16px}
}
@media(max-width:480px){
  .quick-links{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr}
  .video-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .council-grid{grid-template-columns:1fr}
}
