/* ============================================================
   Municipalidad de Machalí — sistema visual
   Tricolor: teal · naranja · carmín  ·  "juntos creamos futuro"
   ============================================================ */

/* ---- Tokens ---- */
:root {
  /* tricolor de marca */
  --teal:    #0E83A0;  --teal-d:    #0A6A82;
  --orange:  #F08A00;  --orange-d:  #CE7500;
  --crimson: #D80B3F;  --crimson-d: #B40733;
  --green:   #3FA35B;
  --yellow:  #F4B400;

  /* neutros */
  --ink:     #16262E;
  --ink-2:   #33474F;
  --muted:   #5C7178;
  --line:    #DCE6E9;
  --line-2:  #EAF0F2;
  --field:   #EDF2F4;
  --field-2: #E2EAED;
  --card:    #FFFFFF;

  /* acento conmutable (default teal) */
  --accent:    var(--teal);
  --accent-d:  var(--teal-d);
  --accent-soft: #E3F0F4;

  /* tipografía conmutable */
  --font-display: 'Bricolage Grotesque', system-ui, sans-serif;
  --font-body:    'Public Sans', system-ui, sans-serif;

  /* forma */
  --r-sm: 10px;
  --r:    16px;
  --r-lg: 24px;
  --r-xl: 32px;
  --shadow:    0 2px 4px rgba(16,38,46,.04), 0 8px 24px rgba(16,38,46,.06);
  --shadow-lg: 0 6px 14px rgba(16,38,46,.07), 0 24px 50px rgba(16,38,46,.12);
  --maxw: 1240px;

  /* textura de "ciudad" — line-art abstracto de marca */
  --city-pattern: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140' viewBox='0 0 140 140'%3E%3Cg fill='none' stroke='%23A9C0C7' stroke-width='2' stroke-linejoin='round'%3E%3Cpath d='M10 60v40h34V60l-17-14z'/%3E%3Cpath d='M52 100V46h30v54'/%3E%3Crect x='60' y='56' width='6' height='6'/%3E%3Crect x='70' y='56' width='6' height='6'/%3E%3Cpath d='M92 100V64h26v36'/%3E%3Cpath d='M92 64l13-12 13 12'/%3E%3Ccircle cx='27' cy='124' r='3'/%3E%3Cpath d='M118 118h14M122 124h10'/%3E%3C/g%3E%3C/svg%3E");
  --city-pattern-light: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140' viewBox='0 0 140 140'%3E%3Cg fill='none' stroke='%23FFFFFF' stroke-width='2' stroke-linejoin='round'%3E%3Cpath d='M10 60v40h34V60l-17-14z'/%3E%3Cpath d='M52 100V46h30v54'/%3E%3Crect x='60' y='56' width='6' height='6'/%3E%3Crect x='70' y='56' width='6' height='6'/%3E%3Cpath d='M92 100V64h26v36'/%3E%3Cpath d='M92 64l13-12 13 12'/%3E%3Ccircle cx='27' cy='124' r='3'/%3E%3Cpath d='M118 118h14M122 124h10'/%3E%3C/g%3E%3C/svg%3E");
}

[data-accent="orange"]  { --accent: var(--orange);  --accent-d: var(--orange-d);  --accent-soft:#FCEDD6; }
[data-accent="crimson"] { --accent: var(--crimson); --accent-d: var(--crimson-d); --accent-soft:#FBE0E7; }

[data-font="calida"]   { --font-display:'Poppins', sans-serif;        --font-body:'Nunito Sans', sans-serif; }
[data-font="compacta"] { --font-display:'Space Grotesk', sans-serif;  --font-body:'IBM Plex Sans', sans-serif; }

/* ---- Reset ---- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--field);
  line-height: 1.55;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }
h1, h2, h3, h4 { font-family: var(--font-display); line-height: 1.08; font-weight: 700; letter-spacing: -.01em; color: var(--ink); }
:focus-visible { outline: 3px solid var(--accent); outline-offset: 2px; border-radius: 4px; }

.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: 28px; }

/* tricolor bar utility */
.tricolor { display:flex; height:6px; border-radius:99px; overflow:hidden; }
.tricolor > i { flex:1; }
.tricolor > i:nth-child(1){ background:var(--teal); }
.tricolor > i:nth-child(2){ background:var(--orange); }
.tricolor > i:nth-child(3){ background:var(--crimson); }

.eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-body); font-weight:800; font-size:13px;
  letter-spacing:.12em; text-transform:uppercase; color:var(--accent);
}
.eyebrow::before { content:""; width:22px; height:3px; border-radius:9px; background:currentColor; }

/* ---- Buttons ---- */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  padding:13px 22px; border-radius:99px; font-weight:700; font-size:15.5px;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
  white-space:nowrap;
}
.btn svg { width:18px; height:18px; }
.btn-primary { background:var(--accent); color:#fff; box-shadow:0 6px 16px color-mix(in srgb, var(--accent) 32%, transparent); }
.btn-primary:hover { background:var(--accent-d); transform:translateY(-2px); }
.btn-ghost { background:#fff; color:var(--ink); box-shadow:inset 0 0 0 1.5px var(--line); }
.btn-ghost:hover { box-shadow:inset 0 0 0 1.5px var(--accent); color:var(--accent); transform:translateY(-2px); }
.btn-light { background:rgba(255,255,255,.16); color:#fff; backdrop-filter:blur(4px); }
.btn-light:hover { background:rgba(255,255,255,.26); transform:translateY(-2px); }
.btn-block { width:100%; }

/* ============================================================
   TOP UTILITY BAR
   ============================================================ */
.util {
  background:var(--ink); color:#cdd9dd; font-size:13px;
}
.util .wrap { display:flex; align-items:center; justify-content:space-between; height:42px; gap:18px; }
.util a { display:inline-flex; align-items:center; gap:6px; padding:4px 0; transition:color .15s; white-space:nowrap; }
.util-left .muni-region { white-space:nowrap; }
.util a:hover { color:#fff; }
.util-left { display:flex; align-items:center; gap:18px; }
.util-left .dot { width:7px; height:7px; border-radius:50%; background:var(--green); box-shadow:0 0 0 3px rgba(63,163,91,.2); }
.util-right { display:flex; align-items:center; gap:20px; }
.util-sep { width:1px; height:16px; background:rgba(255,255,255,.16); }
.util-social { display:flex; gap:10px; }
.util-social a { width:26px; height:26px; border-radius:50%; background:rgba(255,255,255,.1); justify-content:center; padding:0; }
.util-social svg { width:14px; height:14px; }
.az { display:flex; align-items:center; gap:2px; }
.az button { color:#cdd9dd; padding:2px 6px; border-radius:6px; font-weight:700; }
.az button:hover { color:#fff; background:rgba(255,255,255,.1); }
@media (max-width:880px){ .util-left .muni-region, .util-right .util-link-hide { display:none; } }

/* ============================================================
   HEADER
   ============================================================ */
.site-header { position:sticky; top:0; z-index:60; background:rgba(255,255,255,.92); backdrop-filter:blur(10px); box-shadow:0 1px 0 var(--line); transition:box-shadow .2s; }
.site-header.scrolled { box-shadow:var(--shadow); }
.header-row { display:flex; align-items:center; gap:28px; height:84px; transition:height .2s; }
.site-header.scrolled .header-row { height:70px; }
.brand { display:flex; align-items:center; gap:12px; flex-shrink:0; }
.brand img { height:52px; width:auto; transition:height .2s; }
.site-header.scrolled .brand img { height:44px; }

.nav { display:flex; align-items:center; gap:4px; margin-inline:auto; }
.nav > .nav-item > a, .nav > .nav-item > button {
  display:inline-flex; align-items:center; gap:6px; padding:10px 15px; border-radius:10px;
  font-weight:600; font-size:15.5px; color:var(--ink-2); transition:color .15s, background .15s; white-space:nowrap;
}
.nav > .nav-item > a:hover, .nav > .nav-item > button:hover { color:var(--accent); background:var(--accent-soft); }
.nav .caret { width:14px; height:14px; transition:transform .2s; opacity:.6; }
.nav-item.open .caret { transform:rotate(180deg); }

.header-actions { display:flex; align-items:center; gap:10px; flex-shrink:0; margin-left:auto; }
.icon-btn { width:44px; height:44px; border-radius:12px; display:flex; align-items:center; justify-content:center; color:var(--ink-2); transition:background .15s, color .15s; }
.icon-btn:hover { background:var(--field); color:var(--accent); }
.icon-btn svg { width:21px; height:21px; }
.burger { display:none; }

/* mega menu */
.megawrap { position:relative; }
.mega {
  position:absolute; top:calc(100% + 14px); left:50%; transform:translateX(-50%) translateY(8px);
  width:min(640px, 92vw); background:#fff; border-radius:var(--r-lg); box-shadow:var(--shadow-lg);
  padding:22px; opacity:0; visibility:hidden; transition:opacity .18s, transform .18s; z-index:70;
  border:1px solid var(--line-2);
}
.nav-item.open .mega { opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.mega::before { content:""; position:absolute; top:-7px; left:50%; transform:translateX(-50%) rotate(45deg); width:14px; height:14px; background:#fff; border-left:1px solid var(--line-2); border-top:1px solid var(--line-2); }
.mega-grid { display:grid; grid-template-columns:1fr 1fr; gap:6px; }
.mega-link { display:flex; gap:13px; padding:12px; border-radius:14px; transition:background .15s; }
.mega-link:hover { background:var(--field); }
.mega-ic { width:42px; height:42px; border-radius:12px; flex-shrink:0; display:flex; align-items:center; justify-content:center; color:#fff; }
.mega-ic svg { width:21px; height:21px; }
.mega-link h4 { font-family:var(--font-body); font-size:15px; font-weight:700; }
.mega-link p { font-size:13px; color:var(--muted); line-height:1.35; margin-top:1px; }

/* search overlay */
.search-overlay { position:fixed; inset:0; z-index:90; background:rgba(16,38,46,.5); backdrop-filter:blur(3px); opacity:0; visibility:hidden; transition:opacity .2s; }
.search-overlay.open { opacity:1; visibility:visible; }
.search-panel { background:#fff; max-width:var(--maxw); margin:0 auto; padding:30px 28px 34px; transform:translateY(-16px); transition:transform .25s; border-radius:0 0 var(--r-lg) var(--r-lg); }
.search-overlay.open .search-panel { transform:translateY(0); }
.search-box { display:flex; align-items:center; gap:14px; border-bottom:3px solid var(--accent); padding:6px 0 14px; }
.search-box svg { width:28px; height:28px; color:var(--accent); flex-shrink:0; }
.search-box input { flex:1; border:none; outline:none; font-size:28px; font-family:var(--font-display); font-weight:600; color:var(--ink); background:none; }
.search-box input::placeholder { color:var(--muted); opacity:.6; }
.search-sugs { display:flex; flex-wrap:wrap; gap:9px; margin-top:18px; }
.search-sugs span { font-size:13px; color:var(--muted); font-weight:700; align-self:center; margin-right:4px; }
.chip { display:inline-flex; align-items:center; gap:7px; padding:8px 14px; border-radius:99px; background:var(--field); font-size:14px; font-weight:600; color:var(--ink-2); transition:all .15s; }
.chip:hover { background:var(--accent); color:#fff; transform:translateY(-2px); }

/* ============================================================
   HERO
   ============================================================ */
.hero { position:relative; overflow:hidden; background:var(--field); }
.hero::after { content:""; position:absolute; inset:0; background-image:var(--city-pattern); background-size:280px; opacity:.5; pointer-events:none; }
.hero .wrap { position:relative; z-index:2; display:grid; grid-template-columns:1.05fr .95fr; gap:50px; align-items:center; padding-top:56px; padding-bottom:64px; }
.hero-copy { max-width:580px; }
.hero h1.hero-title { display:flex; flex-direction:column; margin:14px 0 0; line-height:.94; text-transform:uppercase; font-weight:800; letter-spacing:-.005em; }
.hero-title .t-1 { font-size:clamp(46px, 6vw, 82px); color:var(--teal); }
.hero-title .t-2 { font-size:clamp(30px, 3.7vw, 50px); color:var(--orange); display:flex; align-items:baseline; gap:.34em; flex-wrap:wrap; }
.hero-title .t-2 .t-mucho { font-family:'Caveat', cursive; text-transform:none; color:var(--teal); font-size:1.5em; font-weight:700; letter-spacing:0; transform:rotate(-4deg); margin:0 .12em; }
.hero-title .t-3 { font-size:clamp(26px, 3.25vw, 44px); color:var(--crimson); }
.hero p.lead { font-size:19px; color:var(--ink-2); margin-top:20px; max-width:50ch; }
.hero-cta { display:flex; gap:12px; margin-top:28px; flex-wrap:wrap; }
.hero-meta { display:flex; gap:26px; margin-top:30px; flex-wrap:wrap; }
.hero-meta .m { display:flex; flex-direction:column; }
.hero-meta .m b { font-family:var(--font-display); font-size:26px; color:var(--ink); }
.hero-meta .m span { font-size:13.5px; color:var(--muted); font-weight:600; }

/* hero visual — imagen recortada flotante sobre blob de marca */
.hero-visual { position:relative; display:flex; align-items:center; justify-content:center; }
.hero-art { position:relative; width:100%; max-width:530px; }
.hero-blob { position:absolute; inset:2% -1% 4% -1%; z-index:1; border-radius:46% 54% 58% 42% / 52% 46% 54% 48%;
  background:conic-gradient(from 210deg, var(--teal), var(--orange), var(--crimson), var(--yellow), var(--green), var(--teal));
  filter:saturate(1.05); opacity:.95; }
.hero-blob::after { content:""; position:absolute; inset:0; border-radius:inherit; background-image:var(--city-pattern-light); background-size:118px; opacity:.16; mix-blend-mode:overlay; }
.hero-img { position:relative; z-index:3; width:100%; height:auto; filter:drop-shadow(0 26px 42px rgba(16,38,46,.30)); animation:floaty 6.5s ease-in-out infinite; }
@keyframes floaty { 0%,100%{ transform:translateY(0) rotate(0); } 50%{ transform:translateY(-13px) rotate(-1deg); } }
@media (prefers-reduced-motion: reduce){ .hero-img{ animation:none; } }

/* floating stat chips on hero */
.float-chip {
  position:absolute; background:#fff; border-radius:18px; box-shadow:var(--shadow-lg);
  padding:13px 16px; display:flex; align-items:center; gap:12px; z-index:5;
}
.float-chip .fc-ic { width:42px; height:42px; border-radius:12px; display:flex; align-items:center; justify-content:center; color:#fff; flex-shrink:0; }
.float-chip .fc-ic svg { width:22px; height:22px; }
.float-chip b { display:block; font-family:var(--font-display); font-size:17px; line-height:1.1; white-space:nowrap; }
.float-chip span { font-size:12.5px; color:var(--muted); font-weight:600; white-space:nowrap; }
.float-chip.fc-1 { top:6%; left:-20px; }
.float-chip.fc-2 { bottom:10%; right:-18px; }

/* hero variantes */
[data-hero="limpio"] .hero { background:linear-gradient(160deg, var(--accent-soft), var(--field) 70%); }
[data-hero="limpio"] .hero::after { opacity:.22; }
[data-hero="limpio"] .hero-blob { background:radial-gradient(circle at 50% 42%, #fff, var(--accent-soft) 55%, color-mix(in srgb, var(--accent) 26%, #fff)); filter:none; }
[data-hero="limpio"] .hero-blob::after { opacity:.28; }
[data-hero="foto"] .hero-blob { opacity:0; }

/* ============================================================
   ACCESOS RÁPIDOS (chips row)
   ============================================================ */
.quick { background:#fff; border-block:1px solid var(--line-2); }
.quick .wrap { display:flex; align-items:center; gap:14px; padding-block:18px; overflow-x:auto; scrollbar-width:none; }
.quick .wrap::-webkit-scrollbar { display:none; }
.quick .q-label { font-size:13px; font-weight:800; letter-spacing:.04em; text-transform:uppercase; color:var(--muted); flex-shrink:0; }
.q-link { display:inline-flex; align-items:center; gap:10px; padding:11px 17px; border-radius:99px; background:var(--field); font-weight:600; font-size:14.5px; white-space:nowrap; transition:all .15s; flex-shrink:0; }
.q-link:hover { background:var(--accent); color:#fff; transform:translateY(-2px); box-shadow:0 6px 14px color-mix(in srgb, var(--accent) 26%, transparent); }
.q-link .q-ic { width:24px; height:24px; display:flex; }
.q-link svg { width:24px; height:24px; }

/* ============================================================
   SECTION SHELL
   ============================================================ */
section.block { padding-block:74px; }
.sec-head { display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:34px; flex-wrap:wrap; }
.sec-head h2 { font-size:clamp(28px, 3.4vw, 42px); }
.sec-head p { color:var(--muted); margin-top:8px; max-width:54ch; font-size:16.5px; }
.sec-head .link-more { display:inline-flex; align-items:center; gap:7px; font-weight:700; color:var(--accent); }
.sec-head .link-more svg { width:18px; height:18px; transition:transform .2s; }
.sec-head .link-more:hover svg { transform:translateX(4px); }

/* tabs */
.tabs { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:28px; }
.tab { padding:9px 17px; border-radius:99px; font-weight:700; font-size:14.5px; color:var(--ink-2); background:#fff; box-shadow:inset 0 0 0 1.5px var(--line); transition:all .15s; }
.tab:hover { box-shadow:inset 0 0 0 1.5px var(--accent); color:var(--accent); }
.tab.active { background:var(--accent); color:#fff; box-shadow:none; }

/* ---- trámite cards ---- */
.tramite-grid { display:grid; grid-template-columns:repeat(4, 1fr); gap:20px; }
.tcard {
  position:relative; background:#fff; border-radius:var(--r-lg); padding:24px; box-shadow:var(--shadow);
  display:flex; flex-direction:column; transition:transform .2s, box-shadow .2s; border:1px solid var(--line-2);
}
.tcard:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); border-color:transparent; }
.tcard .badge {
  width:54px; height:54px; border-radius:16px; display:flex; align-items:center; justify-content:center;
  color:#fff; margin-bottom:16px;
}
.tcard .badge svg { width:27px; height:27px; }
.tcard h3 { font-family:var(--font-body); font-size:18px; font-weight:800; }
.tcard p { font-size:14.5px; color:var(--muted); margin-top:7px; flex:1; }
.tcard .go { display:inline-flex; align-items:center; gap:7px; font-weight:700; font-size:14.5px; color:var(--accent); margin-top:18px; }
.tcard .go svg { width:17px; height:17px; transition:transform .2s; }
.tcard:hover .go svg { transform:translateX(4px); }
.tcard .corner-tri { position:absolute; top:18px; right:18px; display:flex; gap:3px; }
.tcard .corner-tri i { width:8px; height:8px; border-radius:50%; }

/* paga en línea — featured strip card */
.pay-card { grid-column:span 2; background:linear-gradient(120deg, var(--accent), var(--accent-d)); color:#fff; border:none; }
.pay-card h3, .pay-card .go { color:#fff; }
.pay-card p { color:rgba(255,255,255,.85); }
.pay-card .badge { background:rgba(255,255,255,.2)!important; }

/* color helpers for badges */
.bg-teal{background:var(--teal);} .bg-orange{background:var(--orange);} .bg-crimson{background:var(--crimson);}
.bg-green{background:var(--green);} .bg-yellow{background:var(--yellow);} .bg-accent{background:var(--accent);}
.c-teal{color:var(--teal);} .c-orange{color:var(--orange);} .c-crimson{color:var(--crimson);}

/* ============================================================
   SERVICIOS DESTACADOS
   ============================================================ */
.serv-section { background:#fff; }
.serv-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.scard { border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow); background:var(--field); display:flex; flex-direction:column; transition:transform .2s, box-shadow .2s; }
.scard:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); }
.scard .ph { position:relative; aspect-ratio:16/10; display:flex; align-items:flex-end; padding:18px; overflow:hidden; }
.scard .ph .ph-tag { position:relative; z-index:2; background:#fff; color:var(--ink); font-weight:800; font-size:12.5px; padding:6px 13px; border-radius:99px; display:inline-flex; align-items:center; gap:7px; }
.scard .ph .ph-tag svg { width:15px; height:15px; }
.scard .ph::after { content:attr(data-ph); position:absolute; top:14px; left:16px; font-size:12px; font-weight:700; color:rgba(255,255,255,.85); z-index:2; letter-spacing:.03em; }
.scard .s-body { padding:22px 22px 24px; display:flex; flex-direction:column; flex:1; }
.scard h3 { font-size:21px; }
.scard p { color:var(--muted); margin-top:8px; font-size:15px; flex:1; }
.scard .s-info { display:flex; gap:16px; margin-top:16px; flex-wrap:wrap; }
.scard .s-info span { display:inline-flex; align-items:center; gap:7px; font-size:13.5px; font-weight:600; color:var(--ink-2); }
.scard .s-info svg { width:16px; height:16px; color:var(--accent); }
.scard .s-cta { margin-top:18px; }

/* placeholder field background (branded) */
.ph-field { background:
    radial-gradient(circle at 20% 20%, color-mix(in srgb,var(--c1) 90%, #fff) 0, var(--c1) 60%),
    var(--c1);
}
.ph-grid { position:absolute; inset:0; background-image:var(--city-pattern); background-size:150px; opacity:.5; }

/* ============================================================
   NOTICIAS
   ============================================================ */
.news-grid { display:grid; grid-template-columns:1.4fr 1fr; gap:24px; }
.news-feature { border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow); background:#fff; display:flex; flex-direction:column; }
.news-feature .ph { aspect-ratio:16/9; position:relative; }
.news-feature .nf-body { padding:26px 26px 28px; }
.news-list { display:flex; flex-direction:column; gap:16px; }
.nrow { display:flex; gap:16px; background:#fff; border-radius:var(--r); padding:14px; box-shadow:var(--shadow); transition:transform .15s, box-shadow .2s; }
.nrow:hover { transform:translateX(4px); box-shadow:var(--shadow-lg); }
.nrow .ph { width:104px; height:88px; border-radius:12px; flex-shrink:0; position:relative; overflow:hidden; }
.nrow .n-body { display:flex; flex-direction:column; }
.cat { display:inline-flex; align-self:flex-start; align-items:center; gap:6px; font-size:11.5px; font-weight:800; letter-spacing:.05em; text-transform:uppercase; padding:4px 10px; border-radius:99px; background:var(--accent-soft); color:var(--accent-d); }
.news-meta { font-size:13px; color:var(--muted); font-weight:600; display:flex; align-items:center; gap:8px; }
.nrow h4 { font-family:var(--font-body); font-size:16px; font-weight:800; margin-top:6px; line-height:1.3; }
.news-feature h3 { font-size:25px; margin-top:12px; }
.news-feature p { color:var(--muted); margin-top:10px; }

/* ============================================================
   CONTACTO / ALCALDÍA CERCA
   ============================================================ */
.contact-band { background:var(--ink); color:#dde6e9; position:relative; overflow:hidden; }
.contact-band::after { content:""; position:absolute; inset:0; background-image:var(--city-pattern-light); background-size:240px; opacity:.06; }
.contact-band .wrap { position:relative; z-index:2; display:grid; grid-template-columns:1fr 1fr; gap:54px; padding-block:64px; align-items:center; }
.contact-band h2 { color:#fff; font-size:clamp(28px,3.2vw,40px); }
.contact-band .lead { color:#b6c4c9; margin-top:14px; font-size:17px; max-width:46ch; }
.contact-list { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:28px; }
.cinfo { display:flex; gap:13px; padding:16px; background:rgba(255,255,255,.05); border-radius:16px; border:1px solid rgba(255,255,255,.08); }
.cinfo .ci-ic { width:42px; height:42px; border-radius:12px; flex-shrink:0; display:flex; align-items:center; justify-content:center; color:#fff; }
.cinfo .ci-ic svg { width:21px; height:21px; }
.cinfo b { display:block; color:#fff; font-family:var(--font-display); font-size:16px; }
.cinfo span { font-size:13.5px; color:#a9babf; }
.emergency { background:linear-gradient(120deg, var(--crimson), var(--crimson-d)); border-radius:var(--r-lg); padding:26px 28px; box-shadow:var(--shadow-lg); }
.emergency .e-top { display:flex; align-items:center; gap:12px; color:#fff; }
.emergency .e-top svg { width:26px; height:26px; }
.emergency .e-top b { font-family:var(--font-display); font-size:19px; }
.emergency .e-nums { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:18px; }
.enum { background:rgba(255,255,255,.14); border-radius:14px; padding:14px 16px; color:#fff; }
.enum b { display:block; font-family:var(--font-display); font-size:28px; line-height:1; }
.enum span { font-size:13px; color:rgba(255,255,255,.85); }
.contact-form { background:#fff; border-radius:var(--r-xl); padding:30px; box-shadow:var(--shadow-lg); color:var(--ink); }
.contact-form h3 { font-size:23px; }
.contact-form p.sub { color:var(--muted); margin-top:6px; font-size:15px; }
.field { margin-top:16px; }
.field label { display:block; font-size:13.5px; font-weight:700; margin-bottom:6px; }
.field input, .field select, .field textarea { width:100%; padding:13px 15px; border-radius:12px; border:1.5px solid var(--line); font:inherit; font-size:15px; background:#fff; color:var(--ink); transition:border .15s, box-shadow .15s; }
.field input:focus, .field select:focus, .field textarea:focus { outline:none; border-color:var(--accent); box-shadow:0 0 0 4px var(--accent-soft); }
.field-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer { background:#0E1A20; color:#9fb2b8; padding-top:60px; }
.foot-top { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; padding-bottom:46px; }
.foot-brand img { height:54px; filter:brightness(0) invert(1); opacity:.95; }
.foot-brand p { margin-top:18px; font-size:14.5px; max-width:34ch; line-height:1.6; }
.foot-social { display:flex; gap:10px; margin-top:20px; }
.foot-social a { width:40px; height:40px; border-radius:11px; background:rgba(255,255,255,.06); display:flex; align-items:center; justify-content:center; transition:all .15s; }
.foot-social a:hover { background:var(--accent); color:#fff; transform:translateY(-2px); }
.foot-social svg { width:18px; height:18px; }
.foot-col h4 { font-family:var(--font-body); color:#fff; font-size:15px; font-weight:800; margin-bottom:16px; letter-spacing:.02em; }
.foot-col a { display:block; padding:7px 0; font-size:14.5px; transition:color .15s, padding .15s; }
.foot-col a:hover { color:#fff; padding-left:5px; }
.foot-bottom { border-top:1px solid rgba(255,255,255,.08); padding:24px 0 34px; display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap; font-size:13.5px; }
.foot-bottom .tricolor { width:120px; }

/* ============================================================
   MOBILE NAV
   ============================================================ */
.mobile-menu { position:fixed; inset:0; z-index:80; visibility:hidden; }
.mobile-menu .mm-scrim { position:absolute; inset:0; background:rgba(16,38,46,.5); opacity:0; transition:opacity .2s; }
.mobile-menu .mm-panel { position:absolute; top:0; right:0; bottom:0; width:min(380px,86vw); background:#fff; transform:translateX(100%); transition:transform .25s; padding:22px; overflow-y:auto; display:flex; flex-direction:column; }
.mobile-menu.open { visibility:visible; }
.mobile-menu.open .mm-scrim { opacity:1; }
.mobile-menu.open .mm-panel { transform:translateX(0); }
.mm-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:8px; }
.mm-head img { height:46px; }
.mm-panel nav { display:flex; flex-direction:column; margin-top:10px; }
.mm-panel nav a { padding:15px 6px; font-weight:700; font-size:18px; border-bottom:1px solid var(--line-2); display:flex; align-items:center; justify-content:space-between; }
.mm-panel nav a:hover { color:var(--accent); }
.mm-cta { margin-top:auto; padding-top:22px; display:flex; flex-direction:column; gap:10px; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .tramite-grid { grid-template-columns:repeat(2,1fr); }
  .serv-grid { grid-template-columns:1fr 1fr; }
  .pay-card { grid-column:span 2; }
}
@media (max-width:960px){
  .nav, .header-actions .desk-cta, .header-actions .icon-search { display:none; }
  .burger { display:flex; }
  .hero .wrap { grid-template-columns:1fr; gap:36px; }
  .hero-visual { max-width:460px; }
  .float-chip.fc-1 { left:6px; } .float-chip.fc-2 { right:6px; }
  .contact-band .wrap, .news-grid { grid-template-columns:1fr; }
}
@media (max-width:680px){
  .wrap { padding-inline:20px; }
  .serv-grid, .tramite-grid { grid-template-columns:1fr; }
  .pay-card { grid-column:span 1; }
  .contact-list, .field-row, .emergency .e-nums { grid-template-columns:1fr; }
  .foot-top { grid-template-columns:1fr 1fr; gap:28px; }
  .foot-brand { grid-column:1/-1; }
  section.block { padding-block:54px; }
  .hero h1 .hl { white-space:normal; }
}
