/* =========================================================
   VARIABLES GENERALES DEL TEMA
   Colores, sombras y valores reutilizables en toda la app.
   ========================================================= */
:root{
  --guinda:#FF0077; --guinda-2:#111111; --oro:#6b7280; --verde:#4b5563;
  --bg:#f5f1ea; --panel:#fff; --ink:#1f2937; --muted:#64748b; --line:#ddd6c8;
  --borde:#ddd6c8; --gris:#64748b;
  --blue:#1d4ed8; --red:#9f1239; --amber:#92400e; --green:#166534;
  --shadow:0 18px 45px rgba(15,23,42,.10);
}

/* Reset básico para que padding y bordes no alteren medidas. */
*{box-sizing:border-box}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:linear-gradient(135deg,#f4efe5,#fbfaf7 45%,#eef4f1);color:var(--ink)}
button,input,select,textarea{font:inherit}button{cursor:pointer}.hidden{display:none!important}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.small{font-size:.83rem}.muted{color:var(--muted)}

/* =========================================================
   PANTALLA DE ACCESO
   Estilos del login, tarjeta inicial y claves de acceso.
   ========================================================= */
.login{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:min(720px,100%);background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);overflow:hidden}.strip{height:12px;background:linear-gradient(90deg,var(--guinda),var(--oro),var(--verde))}.login-head{display:flex;gap:18px;align-items:center;padding:30px}.seal{width:78px;height:78px;border-radius:50%;background:var(--guinda);border:4px solid #eee2cb;color:#fff;display:grid;place-items:center;font-size:34px;font-weight:900;flex:none}.eyebrow{margin:0 0 6px;color:var(--oro);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.11em}h1,h2,h3,h4{margin:0;line-height:1.15}h1{color:var(--guinda);font-size:clamp(26px,4vw,40px)}h2{color:#fff;font-size:24px}h3{color:var(--guinda);font-size:28px}.login-form{display:grid;gap:14px;padding:0 30px 28px}.access{background:#f8fafc;border-top:1px solid var(--line);padding:20px 30px;color:#475569;line-height:1.8}.code{display:inline-block;background:#eef2f7;border:1px solid #dbe2ea;border-radius:6px;padding:2px 7px;color:var(--guinda);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}

/* =========================================================
   BARRA SUPERIOR Y ENCABEZADO
   Contiene identidad visual, usuario activo y acciones globales.
   ========================================================= */
.topbar{min-height:84px;background:linear-gradient(90deg,var(--guinda),var(--guinda-2));border-bottom:7px solid var(--oro);color:white;display:flex;align-items:center;justify-content:space-between;padding:16px 28px;gap:16px;flex-wrap:wrap}.top-left,.top-actions{display:flex;align-items:center;gap:14px}.seal-small{width:52px;height:52px;border-radius:50%;background:var(--guinda);border:3px solid #eee2cb;display:grid;place-items:center;font-size:22px;font-weight:900}.badge{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.28);border-radius:999px;padding:8px 12px;font-size:13px}


/* Marca visual interna */
/* =========================================================
   SELLO / MARCA DE LA APP
   Dibuja el emblema sin imágenes externas.
   ========================================================= */
.brand-mark{position:relative;display:grid;place-items:center;background:linear-gradient(145deg,var(--guinda),var(--guinda-2));border:3px solid #eee2cb;box-shadow:inset 0 0 0 1px rgba(255,255,255,.18),0 8px 18px rgba(15,23,42,.18);overflow:hidden;flex:none}
.brand-mark::before{content:"";position:absolute;inset:20%;border:2px solid rgba(238,226,203,.9);border-radius:12px;transform:rotate(45deg)}
.brand-mark::after{content:"";position:absolute;width:46%;height:3px;background:var(--oro);border-radius:999px;transform:rotate(-35deg);box-shadow:0 11px 0 rgba(238,226,203,.88),0 -11px 0 rgba(238,226,203,.88)}
.brand-mark span{position:absolute;width:8px;height:8px;border-radius:50%;background:#fff;opacity:.92}
.brand-mark span:nth-child(1){top:22%;left:48%}.brand-mark span:nth-child(2){bottom:25%;left:28%}.brand-mark span:nth-child(3){bottom:25%;right:28%}
.brand-mark-lg{width:82px;height:82px;border-radius:22px}.brand-mark-sm{width:56px;height:56px;border-radius:16px}.brand-mark-sm::before{border-radius:8px}.brand-mark-sm span{width:6px;height:6px}

/* =========================================================
   ESTRUCTURA GENERAL
   Sidebar, panel principal y navegación por módulos.
   ========================================================= */
.layout{display:grid;grid-template-columns:290px 1fr;gap:22px;padding:22px}.sidebar,.panel{background:#fff;border:1px solid var(--line);border-radius:22px;box-shadow:0 12px 28px rgba(15,23,42,.06)}.sidebar{padding:14px;height:max-content}.panel{padding:24px}.nav{width:100%;text-align:left;background:transparent;border:0;border-radius:14px;padding:14px 15px;font-weight:900;color:#334155;display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.nav span{display:flex;align-items:center;gap:10px}.nav.active,.nav:hover{background:#d9e4df;color:var(--verde)}.nav.locked{color:#94a3b8}.role-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;padding:13px;margin-bottom:12px}.role-box b{color:var(--guinda)}

/* =========================================================
   AVISOS DEL SISTEMA
   Mensajes de error, advertencia, éxito e información.
   ========================================================= */
.notice{border-radius:14px;border:1px solid #bfdbfe;background:#eff6ff;color:#1e3a8a;padding:14px 16px;line-height:1.45;margin-bottom:16px}.notice.warn{border-color:#fed7aa;background:#fff7ed;color:#7c2d12}.notice.error{border-color:#fecdd3;background:#fff1f2;color:var(--red)}.notice.ok{border-color:#bbf7d0;background:#f0fdf4;color:var(--green)}

/* =========================================================
   GRIDS, CABECERAS Y BOTONES
   Utilidades de acomodo y acciones reutilizables.
   ========================================================= */
.grid{display:grid;gap:14px}.grid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.grid3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.grid4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.section-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:18px;flex-wrap:wrap}.actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.btn{border:0;border-radius:999px;padding:10px 16px;font-weight:900;display:inline-flex;align-items:center;gap:8px}.btn.primary{background:var(--guinda);color:white;box-shadow:0 8px 18px rgba(97,18,50,.22)}.btn.secondary{background:#ede8de;color:var(--guinda);border:1px solid var(--line)}.btn.ghost{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.35);color:white}.btn.danger{background:#fff1f2;border:1px solid #fecdd3;color:var(--red)}.btn.good{background:#f0fdf4;border:1px solid #bbf7d0;color:var(--green)}.btn:disabled{opacity:.5;cursor:not-allowed}

/* =========================================================
   FORMULARIOS
   Campos, validaciones visuales, notas y ayudas.
   ========================================================= */
label{display:grid;gap:7px;font-weight:800;color:#334155;font-size:14px}input,select,textarea{width:100%;border:2px solid #b9b19f;border-radius:12px;padding:11px 12px;background:#fff; color:var(--ink);outline:none;box-shadow:inset 0 1px 2px rgba(15,23,42,.04), 0 1px 0 rgba(255,255,255,.9)}input[readonly]{background:#f4f6f8;border-color:#cbd5e1;color:#475569;cursor:not-allowed}input::placeholder,textarea::placeholder{color:#64748b;opacity:1}input:hover,select:hover,textarea:hover{border-color:#9f967f;background:#fffdfa}input[readonly]:hover{background:#f4f6f8;border-color:#cbd5e1}input:focus,select:focus,textarea:focus{border-color:var(--oro);background:#fff;box-shadow:0 0 0 4px rgba(165,127,44,.18), inset 0 1px 2px rgba(15,23,42,.04)}input[readonly]:focus{background:#f4f6f8;border-color:#cbd5e1;box-shadow:inset 0 1px 2px rgba(15,23,42,.04)}.field-error{border-color:#fb7185!important;background:#fff7f8!important;box-shadow:0 0 0 3px rgba(251,113,133,.12)!important}.field-valid{border-color:#22c55e!important;background:#f0fdf4!important;box-shadow:0 0 0 3px rgba(34,197,94,.12)!important}.field-note{font-weight:700;color:var(--red);font-size:12px;min-height:14px}.field-note.ok{color:var(--green)}.hint{font-weight:500;color:var(--muted);font-size:12px;line-height:1.35}fieldset{border:1px solid #cfc6b4;border-radius:18px;padding:18px;margin:0 0 18px;background:#fffdfa;box-shadow:inset 0 1px 0 rgba(255,255,255,.8)}legend{color:var(--verde);font-weight:900;padding:0 8px}.check{display:flex;gap:10px;align-items:flex-start;font-weight:700}.check input{width:18px;height:18px;margin-top:1px}.filter-panel{background:#fafafa;border:1px solid var(--line);border-radius:20px;padding:18px;margin-bottom:18px}.filter-title{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:14px}.chip-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.chip{border:1px solid #dbe2ea;border-radius:999px;background:#f8fafc;color:#475569;padding:6px 10px;font-size:12px;font-weight:800}.summary-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;margin-bottom:18px}.summary{border:1px solid var(--line);border-radius:18px;background:#fff;padding:16px}.summary span{display:block;color:var(--muted);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}.summary strong{display:block;color:var(--guinda);font-size:30px;margin-top:4px}.summary.green strong{color:var(--green)}.summary.amber strong{color:var(--amber)}.summary.red strong{color:var(--red)}.summary.blue strong{color:var(--blue)}

/* =========================================================
   TABLAS Y DETALLES
   Listados, etiquetas de estado y filas expandibles.
   ========================================================= */
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:18px}table{width:100%;border-collapse:collapse;min-width:980px;background:#fff}th,td{padding:13px 14px;border-bottom:1px solid #e5e7eb;text-align:left;vertical-align:top}th{background:#f3f1eb;color:var(--guinda);font-size:12px;text-transform:uppercase;letter-spacing:.04em}.pager{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin:12px 0;padding:12px 14px;border:1px solid var(--line);border-radius:12px;background:#fff}.pager-info{display:grid;gap:2px;color:#334155}.pager-info span{font-size:12px;color:var(--muted)}.pager-size{display:flex;align-items:center;gap:8px;font-size:12px;color:#475569}.pager-size select{width:auto;min-width:78px;padding:7px 9px;border-radius:9px}.pager-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.pager-current{font-size:12px;font-weight:900;color:#475569;padding:0 4px}.tag{display:inline-flex;align-items:center;border-radius:999px;padding:5px 9px;font-size:11px;font-weight:900;border:1px solid #dbe2ea}.tag.ok{background:#f0fdf4;color:var(--green);border-color:#bbf7d0}.tag.warn{background:#fffbeb;color:var(--amber);border-color:#fde68a}.tag.red{background:#fff1f2;color:var(--red);border-color:#fecdd3}.tag.blue{background:#eff6ff;color:#1e3a8a;border-color:#bfdbfe}.detail-row td{background:#fffdf7}.detail-box{border:1px solid var(--line);border-radius:20px;background:#fff;padding:18px}.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.detail-section{border:1px solid #e2e8f0;border-radius:16px;background:#f8fafc;padding:14px}.detail-section h4{font-size:16px;color:var(--verde);margin-bottom:10px}.kv{display:grid;gap:8px;font-size:14px}.kv div b{display:block;color:#64748b;font-size:12px;margin-bottom:2px}
/* =========================================================
   MODALES
   Confirmaciones, edición, exportación y mensajes posteriores.
   ========================================================= */
.modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:60;display:grid;place-items:center;padding:20px}.modal{width:min(640px,100%);background:white;border-radius:22px;border:1px solid var(--line);box-shadow:var(--shadow);overflow:hidden}.modal-header{padding:18px 22px;background:linear-gradient(90deg,var(--guinda),var(--guinda-2));color:white}.modal-body{padding:22px;line-height:1.6}.modal-actions{padding:0 22px 22px;display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}.doc{line-height:1.75;background:#fffdf9;border:1px solid var(--line);border-radius:18px;padding:20px}.empty{padding:24px;text-align:center;color:var(--muted)}

/* =========================================================
   DISEÑO RESPONSIVO GENERAL
   Ajustes para tablet y celular.
   ========================================================= */
@media(max-width:980px){.layout{grid-template-columns:1fr}.sidebar{display:block}.grid4,.grid3,.grid2,.summary-row,.detail-grid{grid-template-columns:1fr 1fr}.topbar,.section-head{align-items:flex-start}}@media(max-width:650px){.grid4,.grid3,.grid2,.summary-row,.detail-grid{grid-template-columns:1fr}.login-head{flex-direction:column;align-items:flex-start}.panel,.layout{padding:14px}.topbar{padding:14px}}


/* =========================================================
   REPORTES Y ESTADÍSTICAS
   Resúmenes, gráficas de barras y reportes imprimibles.
   ========================================================= */
/* Paso 16 · Estadísticas y reportes */
.report-summary{grid-template-columns:repeat(7,minmax(0,1fr))}
.chart-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:14px}
.bar-list{display:grid;gap:12px}.bar-item{display:grid;gap:6px}.bar-meta{display:flex;justify-content:space-between;gap:10px;font-size:13px;color:#334155}.bar-meta span{font-weight:800}.bar-meta b{color:var(--guinda)}.bar-track{height:12px;background:#e5e7eb;border-radius:999px;overflow:hidden;border:1px solid #d9dde5}.bar-fill{height:100%;background:linear-gradient(90deg,var(--guinda),var(--oro));border-radius:999px;min-width:4px}
@media(max-width:1100px){.report-summary{grid-template-columns:repeat(3,minmax(0,1fr))}.chart-grid{grid-template-columns:1fr}}
@media(max-width:650px){.report-summary{grid-template-columns:1fr}}



/* =========================================================
   BITÁCORA DE CONTROL DIARIO
   Formato visual del control territorial diario y fotografías.
   ========================================================= */
/* Bitácora de control diario */
.daily-form{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#fff;margin-top:12px}
.daily-title{background:var(--guinda);color:#fff;text-align:center;font-weight:900;text-transform:uppercase;letter-spacing:.03em;padding:10px 12px;font-size:16px}
.daily-grid{display:grid;grid-template-columns:1.15fr 1.25fr 1.15fr 1.25fr;border-top:1px solid var(--line)}
.daily-label{background:#f0f0ef;border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:14px 12px;font-weight:900;text-transform:uppercase;color:#111;display:flex;align-items:center}
.daily-field{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:10px;background:#fff;display:grid;align-items:center}
.daily-label.tall,.daily-field.tall{min-height:120px}
.daily-field input,.daily-field select,.daily-field textarea{border:2px solid #b9b19f;border-radius:10px;background:#fff;color:var(--guinda);font-weight:900;text-transform:uppercase;text-align:center;box-shadow:inset 0 1px 2px rgba(15,23,42,.04);padding:10px 12px}
.daily-field textarea{text-align:left;resize:vertical;line-height:1.5}
.daily-field input::placeholder,.daily-field textarea::placeholder{color:#64748b;opacity:1}
.daily-field input:hover,.daily-field select:hover,.daily-field textarea:hover{border-color:#9f967f;background:#fffdfa}
.daily-field input:focus,.daily-field select:focus,.daily-field textarea:focus{box-shadow:0 0 0 4px rgba(97,18,50,.12), inset 0 1px 2px rgba(15,23,42,.04);border-color:var(--oro);background:#fff}
.daily-photos{padding:18px;border-top:1px solid var(--line);background:#fffdf9}.daily-photos h4{margin:0 0 6px;color:var(--verde)}
.photo-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-top:12px}.photo-slot{border:1px dashed var(--line);border-radius:16px;background:#fff;padding:10px;display:grid;gap:8px;justify-items:center}.photo-preview{width:100%;height:150px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;display:grid;place-items:center;overflow:hidden;color:var(--muted);font-weight:800}.photo-preview img{width:100%;height:100%;object-fit:cover}.photo-btn{justify-content:center;width:100%;font-size:12px}.photo-remove{justify-content:center;width:100%;font-size:12px}
@media(max-width:900px){.daily-grid{grid-template-columns:1fr 1fr}.photo-grid{grid-template-columns:1fr 1fr}}
@media(max-width:620px){.daily-grid,.photo-grid{grid-template-columns:1fr}.daily-label{border-right:0}.daily-field{border-right:0}.daily-label.tall,.daily-field.tall{min-height:auto}}
.grid5{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}
.tag.green{background:#f0fdf4;color:var(--green);border-color:#bbf7d0}.tag.amber{background:#fffbeb;color:var(--amber);border-color:#fde68a}
.bar-fill.green{background:linear-gradient(90deg,#16a34a,#86efac)}.bar-fill.amber{background:linear-gradient(90deg,#d97706,#facc15)}.bar-fill.red{background:linear-gradient(90deg,#be123c,#fb7185)}
@media(max-width:1000px){.grid5{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:650px){.grid5{grid-template-columns:1fr}}


/* =========================================================
   DASHBOARD DE INTELIGENCIA TERRITORIAL
   Tarjetas, semáforos, barras de avance y alertas.
   ========================================================= */
/* PASO 21 · Dashboard de Inteligencia Territorial */
.dashboard-summary .summary strong{font-size:30px}
.dashboard-hero{display:grid;grid-template-columns:1.2fr 2fr;gap:18px;align-items:center;background:linear-gradient(135deg,#fff,#f7f4ef)}
.dashboard-hero h4{font-size:34px;margin:0;color:var(--guinda)}
.dashboard-global-bar{display:grid;grid-template-columns:1fr 80px;gap:14px;align-items:center}
.dashboard-global-bar strong{font-size:28px;color:var(--guinda);text-align:right}
.dash-bar{margin:0 0 13px;border-bottom:1px solid var(--borde);padding-bottom:12px}
.dash-bar:last-child{border-bottom:0;margin-bottom:0;padding-bottom:0}
.dash-bar-head{display:flex;justify-content:space-between;gap:12px;margin-bottom:7px;font-size:13px}
.dash-bar-head span{color:var(--gris);font-weight:800}
.alert-row{display:flex;justify-content:space-between;gap:12px;align-items:center;border:1px solid var(--borde);border-radius:14px;padding:11px 13px;margin-bottom:9px;font-size:13px}
.alert-row.green{background:#ecfdf5;border-color:#bbf7d0;color:#166534}
.alert-row.amber{background:#fffbeb;border-color:#fde68a;color:#92400e}
.alert-row.red{background:#fff1f2;border-color:#fecdd3;color:#9f1239}
.dashboard-semaforo-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.semaforo-card{border-radius:18px;padding:20px;text-align:center;border:1px solid var(--borde)}
.semaforo-card strong{display:block;font-size:38px;line-height:1;font-weight:900}
.semaforo-card span{display:block;margin-top:7px;font-size:13px;font-weight:900;text-transform:uppercase;letter-spacing:.05em}
.semaforo-card.green{background:#ecfdf5;color:#166534;border-color:#bbf7d0}
.semaforo-card.amber{background:#fffbeb;color:#92400e;border-color:#fde68a}
.semaforo-card.red{background:#fff1f2;color:#9f1239;border-color:#fecdd3}
@media(max-width:850px){.dashboard-hero{grid-template-columns:1fr}.dashboard-semaforo-grid{grid-template-columns:1fr}.dashboard-global-bar{grid-template-columns:1fr}.dashboard-global-bar strong{text-align:left}}


/* =========================================================
   REPORTE DE CÉLULAS CIUDADANAS
   Tabla de cliente, resumen y estilos de impresión/exportación.
   ========================================================= */
/* Reporte de células ciudadanas · formato cliente */
.reporte-celulas-panel .table-wrap{border-color:#111;border-radius:10px}
.reporte-celulas-wrap table,.preview-celulas{min-width:1220px;border-collapse:collapse}
.preview-celulas th{background:#e8e2d8;color:#111;border:1px solid #111;text-align:center;font-size:10px;padding:7px 6px}
.preview-celulas td{border:1px solid #111;text-align:center;font-size:11px;padding:6px 7px}
.preview-celulas .group-row td{background:var(--guinda);color:#fff;text-align:left;font-weight:900}
.preview-celulas .green-cell{background:#4b5563;color:#fff;font-weight:900}
.preview-celulas .yellow-cell{background:#f6c343;color:#111;font-weight:900}
.preview-celulas .red-cell{background:#b91c1c;color:#fff;font-weight:900}
.report-celulas-summary{grid-template-columns:repeat(6,minmax(0,1fr))}
@media(max-width:1100px){.report-celulas-summary{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:650px){.report-celulas-summary{grid-template-columns:1fr}}

select{appearance:auto;min-height:50px} input,select,textarea{min-height:50px} textarea{min-height:110px}

/* =========================================================
   PULIDO INSTITUCIONAL
   Ajustes de presentación para una interfaz más sobria y operativa.
   ========================================================= */
body{background:#f4f6f8}
.login-card,.sidebar,.panel,.modal{border-radius:12px}
.login-card{max-width:680px}
.strip{height:8px}
.topbar{min-height:76px;border-bottom:4px solid var(--oro);box-shadow:0 10px 24px rgba(15,23,42,.12)}
.top-left h2{font-size:21px;letter-spacing:0}
.top-actions{margin-left:auto}
.session-chip{display:grid;gap:2px;min-width:150px;padding:8px 12px;border:1px solid rgba(255,255,255,.24);border-radius:10px;background:rgba(255,255,255,.12);line-height:1.15}
.session-chip b{font-size:13px;color:#fff}
.session-chip span{font-size:11px;color:#f4e9d4;text-transform:uppercase;font-weight:800;letter-spacing:.04em}
.brand-mark-lg{border-radius:14px}.brand-mark-sm{border-radius:10px}
.layout{gap:18px;padding:18px}.sidebar{padding:10px}.panel{padding:22px}
.nav{border-radius:8px;padding:12px 13px;font-weight:800;color:#334155}
.nav.active,.nav:hover{background:#edf4f1;color:var(--verde)}
.nav-icon{width:18px;height:18px;flex:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;fill:none}
.btn{border-radius:8px;padding:10px 14px;font-weight:800;line-height:1.1}
.btn .nav-icon{width:16px;height:16px}
.notice{border-radius:10px}.notice.info{border-color:#cbd5e1;background:#f8fafc;color:#334155}
input,select,textarea{border-radius:8px;border-color:#c7c0b2}
fieldset,.filter-panel,.summary,.table-wrap,.detail-box,.detail-section,.doc,.daily-form,.photo-slot,.photo-preview{border-radius:10px}
th,td{padding:11px 12px}
th{background:#f1f3f5;color:#3b3b3f}
.summary strong{font-size:28px}
.dashboard-hero{background:#fff;border:1px solid var(--line)}
.semaforo-card{border-radius:10px}
@media(max-width:650px){.session-chip{min-width:0}.top-actions{width:100%;justify-content:space-between}.top-left h2{font-size:18px}}
@media(max-width:760px){.org-level{grid-template-columns:1fr}.org-level-title{border-right:0;border-bottom:3px solid #e2e8f0;padding:0 0 10px}.org-level-nodes{grid-template-columns:1fr}}

/* Reclutamiento Padre-Hijo */
.recruit-tree,.recruit-tree ul{list-style:none;margin:0;padding-left:18px}
.recruit-tree{padding-left:0;display:grid;gap:10px}
.recruit-tree li{position:relative;margin:0 0 10px}
.recruit-tree ul{margin-top:10px;border-left:2px solid #e2e8f0}
.recruit-tree ul li{padding-left:14px}
.recruit-card{display:grid;gap:4px;border:1px solid #dbe2ea;border-radius:10px;background:#fff;padding:11px 12px;box-shadow:0 4px 12px rgba(15,23,42,.04)}
.recruit-card b{color:var(--guinda);font-size:14px}
.recruit-card span{color:#475569;font-size:12px}
.recruit-card em{color:var(--verde);font-size:12px;font-style:normal;font-weight:800}
.hierarchy-guide{margin-bottom:16px}
.guide-flow{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}
.guide-flow span{position:relative;background:#fff;border:1px solid #dbe2ea;border-radius:8px;padding:8px 10px;color:var(--guinda);font-size:12px;font-weight:900}
.guide-flow span:not(:last-child)::after{content:"→";margin-left:8px;color:var(--muted)}

/* =========================================================
   PULIDO VISUAL FINAL
   Capa de refinamiento para que la app se perciba más formal.
   ========================================================= */
:root{
  --bg:#f3f5f7;
  --panel:#ffffff;
  --ink:#172033;
  --muted:#667085;
  --line:#d7dde5;
  --soft:#f7f8fa;
  --soft-2:#eef2f5;
  --focus:rgba(165,127,44,.24);
  --shadow:0 18px 42px rgba(15,23,42,.09);
}

html{background:var(--bg)}
body{
  min-height:100vh;
  background:
    linear-gradient(180deg,#f8fafc 0,#f3f5f7 42%,#eef2f5 100%);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

h1{font-size:36px}
h2{font-size:22px}
h3{font-size:26px;color:#4b1029}
h4{letter-spacing:0}
.muted{color:#667085}
.small{line-height:1.45}

.login{padding:32px;background:linear-gradient(135deg,#f6f7f9,#eef3f1)}
.login-card{
  width:min(760px,100%);
  border-radius:14px;
  border-color:#d8dee7;
  box-shadow:0 22px 54px rgba(31,41,55,.14);
}
.login-head{padding:32px 34px 24px}
.login-form{padding:0 34px 30px}
.access{padding:18px 34px;background:#f8fafc;color:#526071}
.seal,.brand-mark-lg{width:76px;height:76px}

.topbar{
  position:sticky;
  top:0;
  z-index:30;
  min-height:72px;
  padding:12px 22px;
  border-bottom:4px solid var(--oro);
  background:linear-gradient(90deg,#111111 0,#FF0077 56%,#3b3b3f 100%);
}
.top-left{min-width:0}
.top-left h2{font-size:20px;white-space:normal}
.session-chip{
  border-radius:8px;
  background:rgba(255,255,255,.10);
  border-color:rgba(255,255,255,.26);
}

.layout{
  grid-template-columns:272px minmax(0,1fr);
  align-items:start;
  gap:18px;
  padding:18px;
  max-width:1680px;
  margin:0 auto;
}
.sidebar{
  position:sticky;
  top:92px;
  max-height:calc(100vh - 112px);
  overflow:auto;
  border-radius:10px;
  padding:8px;
  box-shadow:0 12px 26px rgba(15,23,42,.06);
}
.panel{
  min-width:0;
  border-radius:10px;
  padding:24px;
  box-shadow:0 12px 30px rgba(15,23,42,.07);
}

.nav{
  min-height:44px;
  margin:0 0 3px;
  padding:11px 12px;
  border-radius:7px;
  color:#3d4758;
  transition:background .16s ease,color .16s ease,transform .16s ease;
}
.nav:hover{transform:translateX(2px)}
.nav.active{
  background:#edf4f1;
  color:var(--verde);
  box-shadow:inset 3px 0 0 var(--verde);
}
.nav.locked{opacity:.62}
.nav span{min-width:0}
.nav-icon{width:17px;height:17px}

.section-head{
  padding-bottom:14px;
  border-bottom:1px solid #e4e8ee;
  margin-bottom:18px;
}
.eyebrow{
  color:#8a6a22;
  letter-spacing:.08em;
  font-size:11px;
}

.notice{
  border-radius:8px;
  padding:13px 15px;
  box-shadow:0 1px 0 rgba(255,255,255,.7) inset;
}
.notice b{font-weight:900}

.summary-row{gap:10px}
.summary{
  position:relative;
  overflow:hidden;
  min-height:96px;
  border-radius:8px;
  padding:15px;
  background:linear-gradient(180deg,#fff,#fbfcfd);
  box-shadow:0 7px 18px rgba(15,23,42,.045);
}
.summary::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:4px;
  background:var(--guinda);
}
.summary.blue::before{background:var(--blue)}
.summary.green::before{background:var(--green)}
.summary.amber::before{background:#b7791f}
.summary.red::before{background:var(--red)}
.summary span{
  font-size:11px;
  letter-spacing:.045em;
  color:#667085;
}
.summary strong{
  font-size:30px;
  line-height:1.05;
  margin-top:8px;
}

fieldset,.filter-panel,.detail-section,.detail-box,.doc,.daily-form{
  border-radius:8px;
  background:#fff;
  border-color:#dfe4ea;
  box-shadow:0 1px 0 rgba(255,255,255,.8) inset;
}
fieldset{
  padding:16px;
  margin-bottom:16px;
}
legend{
  color:#4b5563;
  font-size:13px;
  letter-spacing:.02em;
}
.filter-panel{
  padding:16px;
  background:#fbfcfd;
}
.filter-title{margin-bottom:12px}

label{gap:6px;color:#344054;font-size:13px}
input,select,textarea{
  min-height:46px;
  border-radius:7px;
  border:1.5px solid #c9d0da;
  background:#fff;
  padding:10px 11px;
  box-shadow:none;
}
textarea{min-height:104px}
input:hover,select:hover,textarea:hover{border-color:#aeb7c4;background:#fff}
input:focus,select:focus,textarea:focus{
  border-color:var(--oro);
  box-shadow:0 0 0 4px var(--focus);
}
input::placeholder,textarea::placeholder{
  color:#8a94a6;
  opacity:.62;
  font-weight:500;
}
.hint{font-size:11px;color:#7a8494}
.field-note{font-size:11px}

.btn{
  min-height:40px;
  border-radius:7px;
  padding:10px 13px;
  box-shadow:none;
  transition:transform .14s ease,box-shadow .14s ease,background .14s ease,border-color .14s ease;
}
.btn:hover:not(:disabled){transform:translateY(-1px)}
.btn.primary{
  background:#FF0077;
  box-shadow:0 8px 18px rgba(97,18,50,.20);
}
.btn.primary:hover:not(:disabled){background:#4f0f29}
.btn.secondary{
  background:#f3f5f7;
  border-color:#cfd6df;
  color:#4b1029;
}
.btn.secondary:hover:not(:disabled){background:#e9edf2}
.btn.danger{background:#fff5f6}
.btn.ghost:hover:not(:disabled){background:rgba(255,255,255,.20)}
.btn.small{
  min-height:34px;
  padding:8px 10px;
  font-size:12px;
}
.row-actions{
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:nowrap;
}
.btn.icon-btn{
  width:34px;
  height:34px;
  min-height:34px;
  padding:0;
  justify-content:center;
  border-radius:8px;
}
.btn.icon-btn .nav-icon{
  width:16px;
  height:16px;
}
.filter-title b{
  display:inline-flex;
  align-items:center;
  gap:7px;
}
.filter-title b .nav-icon{
  width:16px;
  height:16px;
  color:#FF0077;
}

.table-wrap{
  border-radius:8px;
  background:#fff;
  box-shadow:0 8px 20px rgba(15,23,42,.045);
}
table{min-width:920px}
th{
  position:sticky;
  top:0;
  z-index:1;
  background:#eef1f4;
  color:#3b3b3f;
  font-size:11px;
}
td{
  color:#344054;
  border-bottom-color:#edf0f3;
}
tbody tr:hover td{background:#fafbfc}
.detail-row td{background:#fffdf8}
.tag{border-radius:7px}

.detail-section h4{
  font-size:15px;
  color:#4b5563;
}
.detail-grid{gap:12px}
.kv{font-size:13px}
.kv div b{
  color:#667085;
  text-transform:uppercase;
  letter-spacing:.035em;
}

.modal-backdrop{
  background:rgba(16,24,40,.55);
  backdrop-filter:blur(2px);
}
.modal{
  border-radius:10px;
  width:min(720px,100%);
}
.modal.location-modal{
  width:min(980px,100%);
}
.modal-header{
  padding:17px 20px;
  background:#FF0077;
}
.modal-body{padding:20px}
.modal-actions{padding:0 20px 20px}
.modal .table-wrap table{min-width:560px}

body.modal-open{
  overflow:hidden;
}
.modal-backdrop{
  align-items:center;
  justify-items:center;
  z-index:5000;
  overflow:hidden;
  overscroll-behavior:contain;
}
.modal{
  display:flex;
  flex-direction:column;
  max-height:calc(100vh - 40px);
  overflow:hidden;
}
.modal-header,
.modal-actions{
  flex:0 0 auto;
}
.modal-body{
  flex:1 1 auto;
  min-height:0;
  overflow-y:auto;
  overscroll-behavior:contain;
  scrollbar-gutter:stable;
}
.modal-body .table-wrap{
  max-height:42vh;
  overflow:auto;
}

.daily-title{letter-spacing:.02em}
.daily-label{background:#eef1f4;color:#263241}
.daily-field input,.daily-field select,.daily-field textarea{
  border-width:1.5px;
  color:#3b3b3f;
}
.photo-slot{border-radius:8px}
.photo-preview{border-radius:7px}

.dashboard-hero,.semaforo-card,.recruit-card,.guide-flow span{
  border-radius:8px;
}
.recruit-card{box-shadow:0 7px 18px rgba(15,23,42,.045)}

/* Organigrama automático */
.org-scroll{
  overflow:auto;
  max-height:72vh;
  padding:22px 18px 18px;
  background:#fbfcfd;
  border:2px solid #cbd5e1;
  border-radius:8px;
  scrollbar-gutter:stable both-edges;
  -webkit-overflow-scrolling:touch;
}
.org-scroll::-webkit-scrollbar{
  width:14px;
  height:14px;
}
.org-scroll::-webkit-scrollbar-track{
  background:#eef2f5;
  border-radius:999px;
}
.org-scroll::-webkit-scrollbar-thumb{
  background:#8b95a5;
  border:3px solid #eef2f5;
  border-radius:999px;
}
.org-scroll::-webkit-scrollbar-thumb:hover{
  background:#667085;
}
.org-level-chart{
  display:grid;
  gap:18px;
  min-width:1180px;
  padding:4px 4px 18px;
  position:relative;
}
.org-level{
  --org-line:#667085;
  display:grid;
  grid-template-columns:210px minmax(0,1fr);
  gap:18px;
  align-items:stretch;
  padding:14px;
  border:2px solid #d6dde7;
  border-radius:8px;
  background:#fff;
  position:relative;
  box-shadow:0 8px 20px rgba(15,23,42,.045);
}
.org-level:not(:last-child)::after{
  content:"";
  position:absolute;
  left:105px;
  bottom:-20px;
  width:0;
  height:20px;
  border-left:4px solid var(--org-line);
}
.org-level-title{
  display:grid;
  align-content:center;
  gap:4px;
  border-right:4px solid var(--org-line);
  padding-right:16px;
  position:relative;
}
.org-level-title::after{
  content:"";
  position:absolute;
  top:50%;
  right:-19px;
  width:18px;
  border-top:4px solid var(--org-line);
}
.org-level-title span{
  color:var(--guinda);
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
}
.org-level-title b{
  color:#2f3340;
  font-size:15px;
}
.org-level-title small{
  color:#667085;
  font-weight:800;
}
.org-level-nodes{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:14px;
  align-items:stretch;
  position:relative;
  padding-left:12px;
}
.org-level-nodes::before{
  content:"";
  position:absolute;
  left:0;
  top:50%;
  right:0;
  border-top:3px solid #94a3b8;
  z-index:0;
}
.org-chart{
  display:flex;
  align-items:flex-start;
  justify-content:center;
  gap:24px;
  min-width:max-content;
}
.org-node-wrap{
  display:grid;
  justify-items:center;
  gap:22px;
  position:relative;
}
.org-node{
  width:100%;
  max-width:260px;
  min-height:146px;
  display:grid;
  gap:5px;
  padding:13px 14px;
  border:2px solid #cbd5e1;
  border-top:5px solid var(--guinda);
  border-radius:8px;
  background:#fff;
  box-shadow:0 10px 22px rgba(15,23,42,.06);
  text-align:center;
  position:relative;
  z-index:1;
}
.org-level-nodes .org-node::before{
  content:"";
  position:absolute;
  top:50%;
  left:-14px;
  width:14px;
  border-top:3px solid #94a3b8;
}
.org-level-nodes .org-node{max-width:none}
.org-node b{color:#3b3b3f;font-size:14px}
.org-node span{font-size:12px;font-weight:900;color:#4b5563;text-transform:uppercase}
.org-node small{font-size:11px;color:#667085;line-height:1.35}
.org-node em{font-style:normal;font-size:11px;font-weight:900;color:#475569}
.org-node.admin{border-top-color:#FF0077}
.org-node.supervisor{border-top-color:#4b5563}
.org-node.zone{border-top-color:#1d4ed8}
.org-node.capture{border-top-color:#6b7280}
.org-node.neutral{border-top-color:#64748b}
.org-children{
  display:flex;
  align-items:flex-start;
  justify-content:center;
  gap:18px;
  position:relative;
  padding-top:18px;
}
.org-children::before{
  content:"";
  position:absolute;
  top:0;
  left:50%;
  height:18px;
  border-left:4px solid #667085;
}
.org-children>.org-node-wrap::before{
  content:"";
  position:absolute;
  top:-18px;
  left:50%;
  height:18px;
  border-left:4px solid #667085;
}
.org-children>.org-node-wrap:not(:only-child)::after{
  content:"";
  position:absolute;
  top:-18px;
  left:0;
  right:0;
  border-top:4px solid #667085;
}
.asistencia-panel .table-wrap{border-radius:8px}
.attendance-table{min-width:1120px}
.attendance-table th:nth-child(1),.attendance-table td:nth-child(1){width:46px;text-align:center}
.attendance-table th:nth-child(7),.attendance-table th:nth-child(8),.attendance-table td:nth-child(7),.attendance-table td:nth-child(8){text-align:center;width:82px}
.attendance-cell{background:linear-gradient(#fff,#fff) padding-box;border-bottom-color:#d6d3ca;min-height:34px}
.attendance-sign{min-width:150px}
.attendance-notes{min-width:190px}
.attendance-table .tag{white-space:nowrap}
.attendance-table .row-actions{justify-content:flex-start}

/* =========================================================
   OPTIMIZACIÓN PARA TABLETAS
   Menú táctil, formularios cómodos y tablas manejables.
   ========================================================= */
@media (pointer:coarse){
  .btn{min-height:44px}
  .btn.icon-btn{width:44px;height:44px;min-height:44px}
  .nav{min-height:46px}
  input,select,textarea{min-height:48px;font-size:16px}
}
@media (min-width:651px) and (max-width:1180px){
  body{background:#f4f6f8}
  .topbar{
    position:sticky;
    top:0;
    z-index:30;
    min-height:72px;
    padding:12px 16px;
  }
  .top-left h2{font-size:20px}
  .brand-mark-sm{width:46px;height:46px}
  .layout{
    display:block;
    padding:14px;
    max-width:none;
  }
  .sidebar{
    position:sticky;
    top:76px;
    z-index:25;
    display:flex;
    gap:8px;
    overflow-x:auto;
    overflow-y:hidden;
    padding:10px;
    margin-bottom:14px;
    max-height:none;
    border-radius:10px;
    scrollbar-width:thin;
    -webkit-overflow-scrolling:touch;
  }
  .sidebar::-webkit-scrollbar{height:8px}
  .sidebar::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px}
  .nav{
    width:auto;
    min-width:max-content;
    flex:0 0 auto;
    margin:0;
    padding:12px 14px;
    white-space:nowrap;
  }
  .nav:hover{transform:none}
  .btn{min-height:44px}
  .btn.icon-btn{width:44px;height:44px;min-height:44px}
  input,select,textarea{min-height:48px;font-size:16px}
  .panel{
    padding:18px;
    border-radius:10px;
  }
  .grid4,.grid3{grid-template-columns:repeat(2,minmax(0,1fr))}
  .grid2,.detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .summary-row{grid-template-columns:repeat(3,minmax(0,1fr))}
  .section-head{gap:12px}
  .section-head .actions{width:100%;justify-content:flex-start}
  .filter-panel{padding:16px}
  .table-wrap{
    border-radius:10px;
    overflow:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:thin;
  }
  .table-wrap::-webkit-scrollbar{height:9px}
  .table-wrap::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px}
  th,td{padding:12px 11px}
  .pager{align-items:flex-start}
  .pager-actions{width:100%}
  .daily-grid{grid-template-columns:1fr 1fr}
  .photo-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .org-scroll{overflow:auto;-webkit-overflow-scrolling:touch}
}
@media (max-width:650px){
  .sidebar{
    display:flex;
    gap:8px;
    overflow-x:auto;
    overflow-y:hidden;
    padding:10px;
    margin-bottom:12px;
    -webkit-overflow-scrolling:touch;
  }
  .nav{
    width:auto;
    min-width:max-content;
    flex:0 0 auto;
    margin:0;
    white-space:nowrap;
  }
  .btn.icon-btn{width:42px;height:42px;min-height:42px}
  .row-actions{gap:8px}
  .pager-actions .btn{flex:1 1 calc(50% - 8px)}
}

button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:3px solid rgba(165,127,44,.35);
  outline-offset:2px;
}

.map-picker-layout{
  display:grid;
  grid-template-columns:minmax(0,2fr) minmax(240px,1fr);
  gap:14px;
  align-items:stretch;
}
.map-picker,.territorial-map{
  min-height:360px;
  height:52vh;
  border:1px solid var(--line);
  border-radius:10px;
  overflow:hidden;
  background:#eef2f1;
}
.map-picker{
  min-height:300px;
  height:360px;
}
.map-picker-side{
  display:flex;
  flex-direction:column;
  gap:12px;
  justify-content:center;
  border:1px solid var(--line);
  border-radius:10px;
  padding:14px;
  background:#f8fafc;
}
.map-coords{
  display:grid;
  gap:4px;
  padding:12px;
  border-radius:8px;
  background:#fff;
  border:1px solid #e2e8f0;
}
.map-coords span{
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  color:#334155;
}
.map-panel{
  position:relative;
}
.map-status{
  position:absolute;
  left:14px;
  bottom:14px;
  z-index:500;
  background:rgba(255,255,255,.92);
  border:1px solid var(--line);
  border-radius:999px;
  padding:8px 12px;
  color:#334155;
  font-size:12px;
  font-weight:800;
  box-shadow:0 8px 20px rgba(15,23,42,.08);
}
.map-fallback{
  height:100%;
  display:grid;
  place-items:center;
  text-align:center;
  padding:20px;
  color:#64748b;
  font-weight:800;
}
.leaflet-container{
  font-family:inherit;
}
.svg-map{
  width:100%;
  height:100%;
  display:block;
  background:#eef2f1;
  cursor:default;
}
.svg-picker-map{
  cursor:crosshair;
}
.svg-sections path{
  fill:#6b7280;
  fill-opacity:.08;
  stroke:#FF0077;
  stroke-width:1;
  vector-effect:non-scaling-stroke;
}
.svg-points circle{
  fill:#dc2626;
  stroke:#fff;
  stroke-width:2;
  vector-effect:non-scaling-stroke;
  filter:drop-shadow(0 2px 2px rgba(15,23,42,.28));
}
.svg-points .hidden{
  display:none;
}

@media(max-width:980px){
  .topbar{position:static}
  .layout{grid-template-columns:1fr;padding:14px}
  .sidebar{position:static;max-height:none}
  .panel{padding:18px}
  .map-picker-layout{grid-template-columns:1fr}
}
@media(max-width:650px){
  h1{font-size:30px}
  h2{font-size:19px}
  h3{font-size:23px}
  .login{padding:18px}
  .login-head,.login-form,.access{padding-left:20px;padding-right:20px}
  .brand-mark-lg,.seal{width:66px;height:66px}
  .topbar{gap:12px}
  .top-actions{align-items:stretch}
  .session-chip{flex:1}
  .section-head{gap:12px}
  .actions{width:100%}
  .actions .btn{justify-content:center}
  table{min-width:760px}
  .map-picker,.territorial-map{height:440px;min-height:360px}
}

/* Prioridad final para tabletas reales, incluida orientación horizontal. */
@media (min-width:651px) and (max-width:1180px){
  .topbar{position:sticky;top:0}
  .layout{display:block;grid-template-columns:none;padding:14px}
  .sidebar{
    position:sticky;
    top:76px;
    display:flex;
    gap:8px;
    overflow-x:auto;
    overflow-y:hidden;
    max-height:none;
  }
  .nav{width:auto;flex:0 0 auto;margin:0;white-space:nowrap}
}

/* Tema SiCaCCS */
:root{
  --guinda:#FF0077;
  --guinda-2:#111111;
  --oro:#6b7280;
  --verde:#4b5563;
  --bg:#f5f5f6;
  --line:#d1d5db;
  --borde:#d1d5db;
  --muted:#6b7280;
  --ink:#111827;
  --shadow:0 18px 42px rgba(17,24,39,.10);
}
body{background:linear-gradient(180deg,#fff 0,#f5f5f6 48%,#eceef1 100%)}
.campaign-banner{
  width:100%;
  overflow:hidden;
  background:#f8f2ed;
  border-bottom:2px solid #991e2b;
  box-shadow:0 6px 18px rgba(17,24,39,.12);
}
.campaign-banner img{
  display:block;
  width:100%;
  height:auto;
  aspect-ratio:20 / 3;
  object-fit:cover;
  object-position:center center;
}
.campaign-banner + .login{
  min-height:calc(100vh - clamp(96px,15vw,300px));
}
.strip{background:linear-gradient(90deg,#FF0077,#111,#6b7280)}
.topbar{
  background:linear-gradient(90deg,#111 0,#FF0077 58%,#3b3b3f 100%);
  border-bottom-color:#6b7280;
}
.brand-mark,.seal,.seal-small{
  background:linear-gradient(145deg,#FF0077,#111);
  border-color:#fff;
}
.brand-mark::after{
  background:#fff;
  box-shadow:0 11px 0 rgba(255,255,255,.78),0 -11px 0 rgba(255,255,255,.78);
}
.eyebrow{color:#FF0077}
.nav.active,.nav:hover{background:#fff0f7;color:#FF0077}

@media(max-width:900px){
  .campaign-banner img{
    aspect-ratio:5 / 1;
  }
}
@media(max-width:600px){
  .campaign-banner img{
    aspect-ratio:3.6 / 1;
    object-position:50% center;
  }
}
.nav.active{box-shadow:inset 3px 0 0 #FF0077}
.btn.primary{background:#FF0077;color:#fff;box-shadow:0 8px 18px rgba(255,0,119,.22)}
.btn.secondary{background:#f3f4f6;color:#111827;border-color:#d1d5db}
h1,h3,.role-box b,.summary strong{color:#FF0077}
input,select,textarea{border-color:#cbd5e1}
input:focus,select:focus,textarea:focus{border-color:#FF0077;box-shadow:0 0 0 4px rgba(255,0,119,.14), inset 0 1px 2px rgba(15,23,42,.04)}
fieldset{border-color:#d1d5db;background:#fff}
legend{color:#111827}
