/* ===========================================================
   Guarne y el Área Metropolitana — Campaña
   Paleta oficial de Guarne: verde (sinople), oro, rojo (gules),
   azul (cielo) y blanco. Tipografías: Bricolage Grotesque + Archivo.
   =========================================================== */
:root{
  --paper:#F7F3E9;
  --card:#FBF8F0;
  --white:#ffffff;
  --ink:#1B2A20;
  --muted:#586559;
  --green:#1B6E37;
  --green-deep:#103D22;
  --gold:#E3A81E;
  --gold-ink:#B07D10;
  --red:#C0322B;
  --blue:#2C6FA8;
  --blue-deep:#1F5680;
  --band:#ECE4D2;
  --line:rgba(27,42,32,.12);
  --display:'Bricolage Grotesque',system-ui,sans-serif;
  --body:'Archivo',system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--body);-webkit-font-smoothing:antialiased;line-height:1.5;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit}
.container{max-width:1100px;margin:0 auto;padding:0 28px}
.block{padding:84px 0}
h1,h2,h3,h4{font-family:var(--display);letter-spacing:-.015em;margin:0}

/* Ribbon */
.ribbon{position:sticky;top:0;z-index:50;background:var(--green-deep);color:#EBE3CF;display:flex;align-items:center;justify-content:center;gap:14px;padding:9px 18px;font-weight:600;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;text-align:center}
.ribbon .dot{width:7px;height:7px;border-radius:50%;background:var(--gold);animation:softpulse 2.4s ease-in-out infinite}
@keyframes softpulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:.35}}
@keyframes floatUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

/* Section label */
.label{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.label span{font-weight:700;font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-ink);white-space:nowrap}
.label .rule{height:1px;flex:1;background:var(--line)}

/* Hero */
.hero{background:var(--green-deep);color:var(--paper);padding:58px 0 86px;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;right:-120px;top:-120px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(227,168,30,.18),transparent 70%)}
.hero .container{position:relative;z-index:1;animation:floatUp .7s ease both}
.hero .escudo{height:74px;width:auto;margin-bottom:22px;filter:drop-shadow(0 6px 16px rgba(0,0,0,.35))}
.badge{display:inline-flex;align-items:center;gap:9px;border:1px solid rgba(247,243,233,.3);border-radius:999px;padding:8px 16px;font-weight:600;font-size:13px;letter-spacing:.06em;color:#EAD9A8}
.badge .dot{width:7px;height:7px;border-radius:50%;background:var(--gold)}
.hero h1{font-weight:800;font-size:clamp(40px,7vw,82px);line-height:.98;letter-spacing:-.02em;margin:24px 0 0;max-width:15ch}
.hero h1 .hl{color:var(--gold)}
.lead{font-size:clamp(18px,2.2vw,23px);line-height:1.5;max-width:46ch;margin:26px 0 0;color:#D8D0BB}
.cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:38px}
.btn{text-decoration:none;font-weight:700;font-size:16px;padding:15px 26px;border-radius:999px;display:inline-block;border:none;cursor:pointer}
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-ghost{border:1px solid rgba(247,243,233,.42);color:var(--paper);font-weight:600}
.hero-stats{display:flex;flex-wrap:wrap;gap:34px;margin-top:52px;padding-top:30px;border-top:1px solid rgba(247,243,233,.18)}
.hero-stats .num{font-family:var(--display);font-weight:700;font-size:34px;line-height:1;color:var(--gold)}
.hero-stats .cap{font-size:13px;letter-spacing:.04em;color:#BDB6A2;margin-top:6px}

h2.title{font-weight:700;font-size:clamp(30px,4.6vw,52px);line-height:1.02}
.sub{font-size:18px;line-height:1.55;color:var(--muted);max-width:60ch;margin:16px 0 36px}

/* Stat cards */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}
.card{background:var(--card);border:1px solid rgba(27,42,32,.1);border-radius:18px;padding:26px}
.card .big{font-family:var(--display);font-weight:800;font-size:46px;line-height:1}
.card .h{font-weight:700;font-size:14px;margin:10px 0 8px}
.card p{font-size:14.5px;line-height:1.5;color:var(--muted);margin:0}

/* Manifiesto */
.sec-green{background:var(--green);color:#F3EFE2;margin-top:50px}
.sec-green .label span{color:#F0C44B}
.sec-green .label .rule{background:rgba(243,239,226,.25)}
.sec-green h2{font-weight:800;font-size:clamp(34px,5.6vw,64px);line-height:1;letter-spacing:-.02em;max-width:16ch}
.sec-green .intro{font-size:19px;line-height:1.55;max-width:54ch;margin:22px 0 8px;color:#D9D4C0}
.benefits{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-top:34px}
.benefit{background:rgba(243,239,226,.08);border:1px solid rgba(243,239,226,.18);border-radius:18px;padding:24px}
.benefit .k{font-family:var(--display);font-weight:700;font-size:15px;letter-spacing:.04em;color:#F0C44B}
.benefit h3{font-weight:700;font-size:22px;margin:12px 0 8px}
.benefit p{font-size:15px;line-height:1.5;color:#D9D4C0;margin:0}
.manifesto-cta{margin-top:30px;background:var(--gold);color:var(--ink);border-radius:18px;padding:22px 26px;font-weight:600;font-size:18px;line-height:1.5;max-width:62ch}

/* Myth table */
.myth{border:1px solid var(--line);border-radius:20px;overflow:hidden;background:var(--card)}
.myth .head{display:grid;grid-template-columns:1fr 1fr;background:var(--ink);color:var(--paper)}
.myth .head div{padding:14px 22px;font-weight:700;font-size:14px;letter-spacing:.08em;text-transform:uppercase}
.myth .head .m{color:#E9A79B}
.myth .head .r{color:#9FD3B3;border-left:1px solid rgba(247,243,233,.16)}
.myth .row{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid rgba(27,42,32,.1)}
.myth .row .m{padding:22px;background:#FBEDEA;font-weight:700;font-size:17px;line-height:1.35;color:var(--red)}
.myth .row .r{padding:22px;border-left:1px solid rgba(27,42,32,.1)}
.myth .row .r p{margin:0;font-size:15.5px;line-height:1.5;color:#33403A}

/* Pillars */
.pillars{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}
.pillar{border-radius:18px;padding:26px;color:#fff}
.pillar .k{font-weight:700;font-size:13px;letter-spacing:.14em}
.pillar h4{font-weight:700;font-size:22px;margin:12px 0 8px}
.pillar p{font-size:15px;line-height:1.5;margin:0}
.pillar.blue{background:var(--blue)}.pillar.blue .k{color:#AFD0EC}.pillar.blue p{color:#D3E2F1}
.pillar.green{background:var(--green)}.pillar.green .k{color:#A8D6B6}.pillar.green p{color:#D2E0CE}
.pillar.gold{background:var(--gold);color:#3A2C05}.pillar.gold .k{color:#8A6A10}.pillar.gold p{color:#4A3A0A}

/* Board (Tablero) */
.sec-band{background:var(--band)}
.board{display:grid;grid-template-columns:1.15fr .85fr;gap:30px;align-items:start}
.facts{display:grid;gap:14px}
.fact{background:var(--card);border:1px solid rgba(27,42,32,.1);border-radius:14px;padding:22px}
.fact.gold{border-left:4px solid var(--gold)}
.fact.green{border-left:4px solid var(--green)}
.fact.red{border-left:4px solid var(--red)}
.fact h4{font-weight:700;font-size:19px;margin:0 0 6px}
.fact p{margin:0;font-size:15px;line-height:1.5;color:var(--muted)}
.mayor{background:var(--green-deep);border-radius:22px;overflow:hidden;color:#F3EFE2}
.mayor .photo{height:300px;background:#0C3019;position:relative}
.mayor .photo img{width:100%;height:100%;object-fit:cover}
.mayor .photo .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;padding:20px;font-size:13px;color:#7E8C7C;font-family:var(--body)}
.mayor .body{padding:24px}
.mayor .k{font-weight:700;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.mayor .name{font-family:var(--display);font-weight:700;font-size:21px;margin:8px 0 2px}
.mayor .role{font-size:13.5px;color:#BDB6A2;margin-bottom:16px}
.mayor blockquote{font-size:16.5px;line-height:1.5;font-style:italic;margin:0;color:#E7DEC8}

/* Video */
.vgrid{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:start}
.spot{position:relative;border-radius:18px;overflow:hidden;background:#0C3019;aspect-ratio:9/16;max-height:520px;margin:0 auto}
.spot .frame{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;color:#7E8C7C;font-size:13px;padding:20px}
.spot .frame img{width:100%;height:100%;object-fit:cover}
.spot .grad{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,24,16,.15),rgba(8,24,16,.65))}
.spot .rec{position:absolute;top:14px;left:14px;display:flex;align-items:center;gap:7px;background:rgba(192,50,43,.92);color:#fff;font-weight:700;font-size:11px;letter-spacing:.1em;padding:6px 10px;border-radius:6px}
.spot .play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:74px;height:74px;border-radius:50%;background:rgba(247,243,233,.92);display:flex;align-items:center;justify-content:center}
.spot .play i{width:0;height:0;border-left:22px solid var(--green-deep);border-top:14px solid transparent;border-bottom:14px solid transparent;margin-left:5px}
.spot .lower{position:absolute;left:0;right:0;bottom:0;padding:18px}
.spot .lower .nm{font-family:var(--display);font-weight:700;font-size:20px;color:#fff;line-height:1.1}
.spot .lower .rl{font-size:13px;color:#E7DEC8}
.spot .lower .quote{margin-top:10px;background:rgba(227,168,30,.96);color:var(--ink);font-weight:700;font-size:14px;line-height:1.3;display:inline-block;padding:7px 12px;border-radius:8px}
.shots{display:grid;gap:12px}
.shot{background:var(--card);border:1px solid rgba(27,42,32,.1);border-radius:14px;padding:18px 20px}
.shot.dark{background:var(--green-deep);color:#F3EFE2}
.shot .top{display:flex;justify-content:space-between;align-items:baseline}
.shot .top b{font-weight:700;font-size:14px}
.shot .top .tc{font-weight:600;font-size:12px;color:var(--gold-ink)}
.shot.dark .top .tc{color:var(--gold)}
.shot p{margin:8px 0 0;font-size:14px;line-height:1.5;color:var(--muted)}
.shot.dark p{color:#D9D4C0}

/* Piezas */
.sec-blue{background:var(--blue-deep);color:#EAF1F8}
.sec-blue .label span{color:#AFD0EC}
.sec-blue .label .rule{background:rgba(234,241,248,.22)}
.sec-blue .sub{color:#CDDEEF}
.ideas{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:18px}
.idea{background:rgba(234,241,248,.08);border:1px solid rgba(234,241,248,.18);border-radius:18px;padding:26px}
.idea .emoji{font-family:var(--display);font-weight:800;font-size:40px;color:#AFD0EC;line-height:1}
.idea h3{font-weight:700;font-size:21px;margin:14px 0 10px}
.idea p{font-size:14.5px;line-height:1.55;color:#CDDEEF;margin:0 0 12px}
.idea .meta{font-size:13.5px;line-height:1.5;color:#AFD0EC;margin:0}

/* Quiz */
.quiz-head{text-align:center;margin-bottom:30px}
.quiz-head .k{font-weight:700;font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-ink)}
.quiz-head h2{font-weight:700;font-size:clamp(28px,4.4vw,46px);line-height:1.05;margin:12px 0 0}
.quiz-head p{font-size:16.5px;line-height:1.55;color:var(--muted);max-width:48ch;margin:14px auto 0}
.quiz-wrap{max-width:760px}
.quiz-card{background:var(--card);border:1px solid var(--line);border-radius:22px;padding:30px 28px;box-shadow:0 18px 48px -28px rgba(16,61,34,.5)}
.q-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.q-meta .kind{font-weight:700;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-ink)}
.q-meta .count{font-weight:600;font-size:13px;color:var(--muted)}
.bar{height:6px;background:rgba(27,42,32,.1);border-radius:99px;overflow:hidden;margin-bottom:24px}
.bar i{display:block;height:100%;background:var(--green);border-radius:99px;width:0;transition:width .3s}
.q-prompt{font-family:var(--display);font-weight:700;font-size:25px;line-height:1.18;margin:0 0 22px}
.opts{display:grid;gap:12px}
.opt{text-align:left;width:100%;background:#fff;border:1.5px solid rgba(27,42,32,.14);border-radius:14px;padding:16px 18px;font-weight:600;font-size:16px;line-height:1.3;color:var(--ink);cursor:pointer;transition:all .15s;font-family:var(--body)}
.opt:hover{border-color:var(--green);background:#EEF5EC;transform:translateY(-1px)}
.opt.correct{border-color:var(--green);background:#E7F2E5}
.opt.wrong{border-color:var(--red);background:#FBEDEA}
.field{display:block;margin-bottom:16px}
.field label{font-weight:600;font-size:14px;color:var(--ink);display:block;margin-bottom:7px}
.field input,.field select{width:100%;font-family:var(--body);font-size:16px;padding:13px 14px;border:1.5px solid rgba(27,42,32,.16);border-radius:12px;background:#fff;color:var(--ink)}
.seg{display:flex;gap:10px;flex-wrap:wrap}
.seg button{flex:1;min-width:90px;font-family:var(--body);font-weight:700;font-size:16px;padding:14px;border:1.5px solid rgba(27,42,32,.16);border-radius:12px;background:#fff;cursor:pointer}
.seg button.on{border-color:var(--green);background:#E7F2E5;color:var(--green)}
.result-title{font-family:var(--display);font-weight:800;font-size:30px;line-height:1.05;margin:0 0 10px;text-align:center}
.result-msg{font-size:16.5px;line-height:1.55;color:var(--muted);max-width:42ch;margin:0 auto 24px;text-align:center}
.rline{display:flex;justify-content:space-between;align-items:center;gap:14px;background:#fff;border:1px solid rgba(27,42,32,.1);border-radius:12px;padding:14px 18px}
.rline span{font-size:14px;color:var(--muted)}
.rline b{font-weight:700;font-size:15px;color:var(--green);text-align:right}
.saved{text-align:center;font-size:13px;margin-top:14px;color:var(--muted)}
.note{text-align:center;font-size:13px;color:#8A9389;margin:16px auto 0;max-width:46ch}

/* Cierre */
.sec-deep{background:var(--green-deep);color:var(--paper);text-align:center}
.sec-deep .escudo{height:80px;width:auto;margin:0 auto 26px;filter:drop-shadow(0 6px 16px rgba(0,0,0,.35))}
.sec-deep h2{font-weight:800;font-size:clamp(38px,6vw,76px);line-height:1;letter-spacing:-.02em}
.sec-deep .lead2{font-size:20px;line-height:1.5;color:#D8D0BB;max-width:50ch;margin:20px auto 0}
.sec-deep .hl{color:var(--gold)}
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;max-width:760px;margin:46px auto 0}
.kpi{border:1px solid rgba(247,243,233,.2);border-radius:16px;padding:22px 16px}
.kpi .num{font-family:var(--display);font-weight:700;font-size:32px;color:var(--gold);line-height:1}
.kpi .cap{font-size:13px;color:#BDB6A2;margin-top:6px}
.closing{font-size:18px;font-weight:600;margin:42px 0 0;color:#F3EFE2}
.fine{font-size:12.5px;line-height:1.6;color:#8A9388;max-width:70ch;margin:34px auto 0}

@media(max-width:780px){
  .board,.vgrid{grid-template-columns:1fr}
  .myth .head,.myth .row{grid-template-columns:1fr}
  .myth .row .r{border-left:none;border-top:1px solid rgba(27,42,32,.1)}
  .myth .head .r{border-left:none}
}
