/* ===== GEM·TUR — tema de marca ===== */
:root{
  --verde:#0F5132; --verde2:#1B7A5A; --piedra:#7C5E3C; --oro:#D4A017;
  --fondo:#F4F1E9; --texto:#1B2A24; --linea:#e3ddcd; --blanco:#fff;
  --verde-suave:#e7efe9; --rojo:#c0392b; --ambar:#e08e0b; --muted:#6b7a72;
  --sombra:0 6px 22px rgba(15,81,50,.10); --r:14px;
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;color:var(--texto);background:var(--fondo);line-height:1.55}
a{color:var(--verde);text-decoration:none}
h1,h2,h3{font-family:Georgia,"Times New Roman",serif;line-height:1.2}
img{max-width:100%}
.wrap{max-width:1100px;margin:0 auto;padding:34px 20px}
.btn{display:inline-block;background:var(--verde);color:#fff;padding:12px 22px;border-radius:999px;font-weight:600;border:none;cursor:pointer;transition:.15s}
.btn:hover{background:#0c3f28}
.btn.ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.7)}
.btn.ghost:hover{background:rgba(255,255,255,.15)}
.muted{color:var(--muted)}
.lead{color:var(--muted);max-width:720px;margin:.2em 0 1.6em}

/* ---- Portal publico ---- */
.pubhead{display:flex;align-items:center;justify-content:space-between;padding:12px 22px;background:#fff;border-bottom:1px solid var(--linea);position:sticky;top:0;z-index:20}
.pubhead .brand{display:flex;align-items:center;gap:10px;font-family:Georgia,serif;font-weight:700;font-size:20px;color:var(--verde)}
.pubhead nav a{margin-left:18px;color:var(--texto);font-weight:600}
.pubhead nav a:hover{color:var(--verde)}
.hero{background:radial-gradient(1200px 500px at 50% -10%,#1B7A5A22,transparent),linear-gradient(160deg,#0F5132,#093019);color:#fff;text-align:center}
.heroinner{max-width:820px;margin:0 auto;padding:64px 20px 72px}
.herologo{filter:drop-shadow(0 8px 18px rgba(0,0,0,.35));background:#F4F1E9;border-radius:50%;padding:4px}
.hero h1{font-size:clamp(38px,7vw,64px);margin:.3em 0 .1em;letter-spacing:1px}
.hero .tag{font-size:clamp(18px,3vw,24px);color:var(--oro);font-style:italic;margin:.2em 0 1em}
.hero .sub{color:#dfe8e2;max-width:560px;margin:0 auto 1.8em}
.herobtns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

.zgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:22px;margin-top:14px}
.zcard{background:#fff;border-radius:var(--r);overflow:hidden;box-shadow:var(--sombra);color:var(--texto);display:flex;flex-direction:column;transition:.18s;border:1px solid var(--linea)}
.zcard:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(15,81,50,.18)}
.zimg{height:150px;display:flex;align-items:center;justify-content:center;position:relative}
.zimg img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.zicon{font-size:56px}
.zbody{padding:16px 18px 18px}
.ztag{display:inline-block;background:var(--verde-suave);color:var(--verde);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:3px 10px;border-radius:999px}
.ztag.light{background:rgba(255,255,255,.25);color:#fff}
.zbody h3{margin:.5em 0 .3em;font-size:21px}
.zbody p{margin:.2em 0 .8em;color:var(--muted);font-size:14.5px}
.zprov{font-size:13px;color:var(--piedra);font-weight:600}

/* ---- Landing de zona ---- */
.zhero{color:#fff;text-align:center;padding:56px 20px}
.zheroinner{max-width:820px;margin:0 auto}
.zicon.big{font-size:64px;display:block}
.zhero h1{font-size:clamp(30px,6vw,50px);margin:.2em 0}
.zdetalle{display:grid;grid-template-columns:1fr 320px;gap:34px}
.zmain p{margin:.6em 0}
.destacado{font-size:19px;font-weight:600;color:var(--verde);border-left:4px solid var(--oro);padding-left:14px}
.atracs{padding-left:18px}.atracs li{margin:.4em 0}
.zside .zficha{background:#fff;border:1px solid var(--linea);border-radius:var(--r);padding:8px 16px;box-shadow:var(--sombra);margin-bottom:14px}
.zficha div{padding:12px 0;border-bottom:1px solid var(--linea)}
.zficha div:last-child{border-bottom:none}
.zficha span{display:block;font-size:12.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.zficha b{font-weight:600;font-size:14.5px}
.zside .btn{width:100%;text-align:center;margin-top:10px}

/* ---- Encuesta publica ---- */
.encuesta{max-width:640px}
.card{background:#fff;border:1px solid var(--linea);border-radius:var(--r);box-shadow:var(--sombra);padding:24px}
.form label{display:block;margin:14px 0;font-weight:600}
.form select,.form textarea,.form input[type=text],.form input[type=number],.form input[type=date]{width:100%;margin-top:6px;padding:11px;border:1px solid var(--linea);border-radius:10px;font:inherit;font-weight:400;background:#fdfdfb}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 18px}
.radios{display:flex;gap:18px;font-weight:400;margin-top:6px}
.stars{display:inline-flex;gap:4px;margin-left:6px;vertical-align:middle}
.stars button{background:none;border:none;font-size:26px;color:#d9d2c0;cursor:pointer;padding:0;line-height:1}
.stars button.on{color:var(--oro)}
.msg{margin-top:10px;font-weight:600}.msg.ok{color:var(--verde)}.msg.err{color:var(--rojo)}
.cta{background:var(--piedra);color:#fff;text-align:center;padding:44px 20px}
.cta h3{margin:0 0 .2em;font-size:26px}.cta p{margin:.2em 0 1.2em;color:#f0e8da}
.cta .btn{background:var(--oro);color:#3a2c07}.cta .btn:hover{background:#c39412}
.pubfoot{background:#0c3f28;color:#cfe0d6;text-align:center;padding:34px 20px}
.pubfoot p{margin:.3em 0}

@media(max-width:820px){.zdetalle{grid-template-columns:1fr}.grid2{grid-template-columns:1fr}}

/* ===== Panel de gestion ===== */
.panel{display:none}
body.app{background:#eef1ec}
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.login-card{background:#fff;border-radius:18px;box-shadow:var(--sombra);padding:34px;max-width:380px;width:100%;text-align:center}
.login-card img{height:96px;margin-bottom:6px}
.login-card h2{margin:.2em 0}
.login-card input{width:100%;padding:12px;margin:8px 0;border:1px solid var(--linea);border-radius:10px;font:inherit}
.login-card .btn{width:100%;margin-top:8px}
.apphead{display:flex;align-items:center;gap:12px;background:var(--verde);color:#fff;padding:10px 18px;position:sticky;top:0;z-index:30}
.apphead img{height:36px;background:#F4F1E9;border-radius:50%}
.apphead b{font-family:Georgia,serif;font-size:19px}
.apphead .sp{flex:1}
.apphead a,.apphead button{color:#fff;background:transparent;border:none;cursor:pointer;font:inherit}
.tabs{display:flex;gap:4px;flex-wrap:wrap;background:#fff;padding:8px 14px;border-bottom:1px solid var(--linea);position:sticky;top:56px;z-index:20}
.tabs button{background:transparent;border:none;padding:9px 15px;border-radius:999px;cursor:pointer;font:inherit;font-weight:600;color:var(--muted)}
.tabs button.on{background:var(--verde-suave);color:var(--verde)}
.view{max-width:1160px;margin:0 auto;padding:22px 18px}
.filtros{display:flex;gap:10px;flex-wrap:wrap;align-items:end;margin-bottom:18px;background:#fff;padding:12px 14px;border-radius:12px;border:1px solid var(--linea)}
.filtros label{font-size:12.5px;font-weight:600;color:var(--muted);display:flex;flex-direction:column;gap:4px}
.filtros input,.filtros select{padding:8px;border:1px solid var(--linea);border-radius:8px;font:inherit}

.kgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(215px,1fr));gap:14px}
.kcard{background:#fff;border-radius:12px;padding:15px 16px;border:1px solid var(--linea);border-left:6px solid #ccc;box-shadow:var(--sombra)}
.kcard.verde{border-left-color:var(--verde2)}.kcard.ambar{border-left-color:var(--ambar)}
.kcard.rojo{border-left-color:var(--rojo)}.kcard.na{border-left-color:#bbb}
.kcard .kn{font-size:13px;color:var(--muted);font-weight:600;display:flex;justify-content:space-between;gap:6px}
.kcard .kv{font-size:30px;font-weight:800;font-family:Georgia,serif;margin:.1em 0}
.kcard .km{font-size:12px;color:var(--muted)}
.chip{font-size:10.5px;font-weight:700;text-transform:uppercase;padding:2px 8px;border-radius:999px;background:#eee;color:#555;white-space:nowrap}
.chip.KPI{background:#e7efe9;color:var(--verde)}.chip.KRI{background:#fdeceb;color:var(--rojo)}.chip.KCI{background:#fbf1da;color:#9a6b06}
.dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:5px}
.dot.verde{background:var(--verde2)}.dot.ambar{background:var(--ambar)}.dot.rojo{background:var(--rojo)}.dot.na{background:#bbb}

.resumen{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin:0 0 20px}
.ritem{background:#fff;border:1px solid var(--linea);border-radius:12px;padding:12px 14px}
.ritem span{font-size:12px;color:var(--muted);font-weight:600}.ritem b{display:block;font-size:22px;font-family:Georgia,serif}

table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;box-shadow:var(--sombra);font-size:14px}
th,td{padding:9px 11px;text-align:left;border-bottom:1px solid var(--linea)}
th{background:#f7f5ee;font-size:12px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted)}
tr:hover td{background:#faf9f4}
.tbl-actions button{border:none;background:none;cursor:pointer;font-size:15px;padding:2px 5px}
.section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:wrap;gap:10px}
.bar{height:12px;border-radius:6px;background:# e9e4d6;background:#e9e4d6;overflow:hidden;min-width:80px}
.bar>i{display:block;height:100%;background:var(--verde2)}
.bench-row{display:grid;grid-template-columns:180px 1fr 90px 70px;gap:10px;align-items:center;padding:8px 0;border-bottom:1px solid var(--linea)}
.tramo{font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px}
.tramo.lider{background:#e7efe9;color:var(--verde)}.tramo.medio{background:#fbf1da;color:#9a6b06}.tramo.rezagado{background:#fdeceb;color:var(--rojo)}

.modal-bg{position:fixed;inset:0;background:rgba(20,30,25,.5);display:flex;align-items:center;justify-content:center;padding:16px;z-index:50}
.modal{background:#fff;border-radius:16px;max-width:560px;width:100%;max-height:90vh;overflow:auto;padding:22px}
.modal h3{margin:0 0 12px}
.modal label{display:block;font-size:13px;font-weight:600;margin:9px 0 0;color:var(--texto)}
.modal input,.modal select,.modal textarea{width:100%;padding:9px;margin-top:4px;border:1px solid var(--linea);border-radius:9px;font:inherit}
.modal .row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}
.btn.sec{background:#eee;color:#333}.btn.sec:hover{background:#e0e0e0}
.btn.sm{padding:8px 14px;font-size:13px}
.qrbox{text-align:center}.qrbox svg{width:180px;height:180px}
.linkrow{display:flex;gap:8px;align-items:center;margin:8px 0}
.linkrow input{flex:1;padding:8px;border:1px solid var(--linea);border-radius:8px;font-size:13px;background:#f7f5ee}
.gcat{background:#fff;border:1px solid var(--linea);border-radius:12px;padding:16px 18px;margin-bottom:14px}
.gcat h4{margin:.2em 0}
.foda{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.foda>div{border-radius:10px;padding:12px 14px}
.foda .F{background:#e7efe9}.foda .O{background:#eaf2fb}.foda .D{background:#fbf1da}.foda .A{background:#fdeceb}
.pill{display:inline-block;background:var(--verde-suave);color:var(--verde);border-radius:999px;padding:2px 10px;font-size:12px;font-weight:700;margin:2px}
@media(max-width:700px){.bench-row{grid-template-columns:120px 1fr 60px;}.bench-row .tramo{display:none}.modal .row{grid-template-columns:1fr}.foda{grid-template-columns:1fr}}

/* ===== Responsive móvil ===== */
.tbl-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:12px}
@media(max-width:640px){
  .view{padding:14px 10px}
  .apphead{padding:8px 10px;gap:8px}
  .apphead b{font-size:16px}.apphead img{height:30px}
  #whoami{display:none}
  .apphead a,.apphead button{font-size:13px}
  .tabs{top:50px;padding:6px 8px;gap:3px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .tabs button{white-space:nowrap;padding:8px 12px;font-size:14px}
  table{font-size:13px}
  th,td{padding:7px 8px;white-space:nowrap}
  .kv{font-size:26px}
  .kgrid{grid-template-columns:1fr 1fr}
  .filtros{gap:8px;padding:10px}
  .filtros label{flex:1 1 42%}
  .filtros input,.filtros select{width:100%}
  .modal{padding:18px}
  .section-head{gap:8px}
  iframe{height:46vh !important}
}
@media(max-width:400px){.kgrid{grid-template-columns:1fr}}
@media(max-width:560px){
  .pubhead{flex-wrap:wrap;gap:4px 10px;padding:10px 14px}
  .pubhead nav{width:100%}
  .pubhead nav a{margin-left:0;margin-right:14px;font-size:14px}
  .wrap{padding:24px 16px}
  .heroinner{padding:48px 16px 54px}
  .zdetalle{gap:22px}
}
