﻿:root{
  --azul:#1b3e8f; --azul-osc:#142e6b; --azul-cl:#e8edf8;
  --verde:#5c8a3c; --verde-osc:#456a2c; --verde-cl:#eef4e6;
  --gris:#f4f6f8; --txt:#212b3b; --borde:#d7dde8; --rojo:#c0392b; --amar:#b8860b;
}
*{box-sizing:border-box}
body{margin:0;font-family:Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--txt);background:var(--gris);line-height:1.5}
a{color:var(--azul)}
.cont{max-width:980px;margin:0 auto;padding:0 16px}

/* Barra blanca superior con el logo */
.brandbar{background:#fff;border-bottom:3px solid var(--verde)}
.brandbar .cont{display:flex;align-items:center;padding:10px 16px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand .logo{height:46px;width:auto;display:block;border-radius:4px}
.brand-txt{color:var(--azul);font-size:1.15rem;font-weight:600;letter-spacing:.2px}
.brand-txt b{color:var(--verde-osc)}

/* Nav azul UPEL */
nav.menu{background:var(--azul)}
nav.menu .cont{display:flex;flex-wrap:wrap;gap:2px;padding:0 16px}
nav.menu a{color:#fff;text-decoration:none;padding:12px 14px;font-size:.93rem;border-bottom:3px solid transparent}
nav.menu a:hover{background:var(--azul-osc)}
nav.menu a.act{border-bottom-color:var(--verde);background:var(--azul-osc)}
nav.menu a.salir{margin-left:auto;opacity:.92;font-size:.86rem}
nav.menu a.coord{color:#dfeccd}

.hero{background:linear-gradient(120deg,var(--azul),var(--verde));color:#fff;padding:34px 0}
.hero h2{color:#fff;font-size:1.6rem;margin:0 0 6px}
.hero p{max-width:660px;opacity:.96;margin:0}

main{padding:22px 0 60px}
h2{color:var(--azul);font-size:1.3rem;margin:0 0 4px}
.sub{color:#5c6675;margin:0 0 18px}

.card{background:#fff;border:1px solid var(--borde);border-radius:10px;padding:18px;margin-bottom:18px;box-shadow:0 1px 3px rgba(0,0,0,.05)}
.grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}

.turno{border:1px solid var(--borde);border-radius:10px;padding:14px;background:#fff}
.turno h3{margin:0 0 4px;font-size:1.02rem}
.turno .fecha{color:var(--azul);font-weight:600}
.cupo{display:inline-block;margin-top:8px;padding:3px 10px;border-radius:20px;font-size:.82rem;font-weight:600}
.cupo.ok{background:var(--verde-cl);color:var(--verde-osc)}
.cupo.lleno{background:#fdecea;color:var(--rojo)}
.cupo.poco{background:#fbf2dc;color:var(--amar)}

label{display:block;font-size:.88rem;font-weight:600;margin:10px 0 4px}
input,select{width:100%;padding:10px;border:1px solid var(--borde);border-radius:7px;font-size:1rem;font-family:inherit}
input:focus,select:focus{outline:2px solid var(--verde);border-color:var(--verde)}
.chk{display:flex;gap:8px;align-items:flex-start;margin:14px 0;font-weight:400;font-size:.9rem}
.chk input{width:auto;margin-top:3px}

.btn{display:inline-block;background:var(--verde);color:#fff;border:0;border-radius:7px;padding:11px 20px;font-size:1rem;font-weight:600;cursor:pointer;text-decoration:none}
.btn:hover{background:var(--verde-osc)}
.btn.sec{background:#fff;color:var(--azul);border:1px solid var(--azul)}
.btn.sec:hover{background:var(--azul-cl)}
.btn.peli{background:var(--rojo)}
.btn:disabled{opacity:.5;cursor:not-allowed}

table{width:100%;border-collapse:collapse;background:#fff}
th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--borde);font-size:.93rem}
th{background:var(--azul);color:#fff;font-weight:600}
tr:nth-child(even) td{background:#fafbfd}

.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:end;margin-bottom:14px}
.toolbar .campo{flex:0 0 auto}

.msg{padding:11px 14px;border-radius:8px;margin:12px 0;font-size:.92rem;display:none}
.msg.ok{background:var(--verde-cl);color:var(--verde-osc);display:block}
.msg.err{background:#fdecea;color:var(--rojo);display:block}
.msg.info{background:var(--azul-cl);color:var(--azul-osc);display:block}
.vacio{color:#7a8493;padding:18px;text-align:center}

.embed{width:100%;min-height:760px;border:1px solid var(--borde);border-radius:10px;background:#fff}
.tabs{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.tabs button{background:#fff;border:1px solid var(--borde);border-radius:7px;padding:9px 16px;cursor:pointer;font-size:.93rem;font-weight:600;color:var(--azul)}
.tabs button.act{background:var(--azul);color:#fff;border-color:var(--azul)}
.pane{display:none}.pane.act{display:block}

/* Login */
.login-wrap{max-width:400px;margin:50px auto}
.login-wrap .logo{height:60px;display:block;margin:0 auto 16px}

.infobox div{margin:2px 0}
.aporte-list{margin:6px 0 0;padding-left:20px}
.aporte-list li{margin:4px 0}
.aporte-list .cat{color:#7a8493;font-size:.85rem}
.acc input,.acc button{vertical-align:middle}
/* Spinner global de espera (interaccion con el Sheet) */
.spinner-overlay{position:fixed;inset:0;background:rgba(20,30,45,.45);z-index:9999;
  display:none;align-items:center;justify-content:center}
.spinner-overlay.show{display:flex}
.spinner-box{background:#fff;border-radius:12px;padding:22px 28px;text-align:center;
  box-shadow:0 6px 24px rgba(0,0,0,.25);min-width:200px}
.spinner{width:42px;height:42px;margin:0 auto 12px;border:5px solid var(--azul-cl);
  border-top-color:var(--azul);border-radius:50%;animation:cssspin .8s linear infinite}
.spinner-txt{color:var(--azul-osc);font-size:.92rem;font-weight:600}
@keyframes cssspin{to{transform:rotate(360deg)}}

.fila-cancelada td{opacity:.55}
.badge-canc{color:var(--rojo);font-size:.78rem;font-weight:600}
.btn.breact,.breact{background:var(--azul)}
.btn.breact:hover,.breact:hover{background:var(--azul-osc)}

footer{border-top:1px solid var(--borde);padding:18px 0;color:#6b7484;font-size:.85rem;text-align:center}
footer a{color:var(--verde-osc)}
@media(max-width:560px){.brand-txt{font-size:1rem}nav.menu a.salir{margin-left:0}}
