:root{
  --olive:#5c6444; --olive-dark:#3f4630; --olive-light:#eef0e6;
  --bg:#f7f7f2; --card:#ffffff; --ink:#26271f; --muted:#6b6f5d;
  --line:#e3e4d8; --accent:#b08948; --ok:#3f7d4e; --warn:#b5852a; --bad:#a8412f;
  --radius:14px; --shadow:0 1px 3px rgba(0,0,0,.06),0 6px 20px rgba(0,0,0,.04);
}
*{box-sizing:border-box} html,body{margin:0}
body{font-family:'Segoe UI',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--ink);font-size:15px;line-height:1.5}
a{color:var(--olive-dark)}
.topbar{display:flex;align-items:center;gap:14px;padding:10px 22px;background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.topbar img{height:38px}
.brand{font-weight:700;letter-spacing:.5px;color:var(--olive-dark);font-size:18px}
.spacer{flex:1}
.chip{padding:3px 11px;border-radius:999px;font-size:12px;font-weight:600;background:var(--olive-light);color:var(--olive-dark);border:1px solid var(--line)}
.chip.role-AC{background:#efe7d6;color:#7a5b1e;border-color:#e6d8be}
.chip.role-OECA{background:#e3ece1;color:#3f6a47}
.chip.role-ADMIN{background:#e7eef5;color:#345a7e}
.chip.role-WORKER{background:#f5ece1;color:#9a6a2e}
.chip.role-PLATFORM_ADMIN{background:#ececf2;color:#4a4a63}
.user{font-size:13px;color:var(--muted)} .user b{color:var(--ink)}
.btn{display:inline-block;padding:8px 14px;border-radius:10px;border:1px solid var(--line);background:var(--card);color:var(--ink);text-decoration:none;font-size:13px;cursor:pointer}
.btn.primary{background:var(--olive);color:#fff;border-color:var(--olive)}
.wrap{max-width:1080px;margin:28px auto;padding:0 22px}
h1{font-size:22px;margin:0 0 4px} .sub{color:var(--muted);margin:0 0 22px}
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:24px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}
.kpi .v{font-size:30px;font-weight:700;color:var(--olive-dark)} .kpi .l{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 20px;margin-bottom:20px}
.card h2{font-size:15px;margin:0 0 12px;color:var(--olive-dark)}
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--line)}
th{font-size:12px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted)}
.lvl{font-size:11px;padding:2px 8px;border-radius:6px;background:var(--olive-light);color:var(--olive-dark)}
.lvl.CENTER{background:#e7eef5;color:#345a7e}.lvl.REGION{background:#efe7d6;color:#7a5b1e}.lvl.WORLD{background:#ececf2;color:#4a4a63}
.path{font-family:ui-monospace,Menlo,monospace;font-size:12px;color:var(--muted)}
.note{font-size:13px;color:var(--muted)}
/* login */
.login{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#eef0e6,#f7f7f2)}
.login .box{background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:34px;width:360px;text-align:center}
.login img{height:210px;max-width:100%;margin-bottom:2px}
.login input{width:100%;padding:11px 12px;margin:7px 0;border:1px solid var(--line);border-radius:10px;font-size:14px}
.login .btn{width:100%;margin-top:8px} .err{color:var(--bad);font-size:13px;margin-top:8px}
/* worker PWA */
.cocina{max-width:480px;margin:0 auto}
.bigbtn{display:block;width:100%;padding:22px;margin:14px 0;border-radius:18px;border:none;font-size:20px;font-weight:700;color:#fff;background:var(--olive);box-shadow:var(--shadow);cursor:pointer}
.bigbtn.alt{background:var(--accent)} .bigbtn.ghost{background:#fff;color:var(--olive-dark);border:2px solid var(--olive)}
.plato{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px;margin:12px 0;display:flex;align-items:center;justify-content:space-between}
.plato .ok{width:34px;height:34px;border-radius:50%;border:2px solid var(--olive)}
/* platform */
.eng{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--line)}
.dot{width:10px;height:10px;border-radius:50%}.dot.g{background:var(--ok)}.dot.a{background:var(--warn)}.dot.r{background:var(--bad)}
.mono{font-family:ui-monospace,Menlo,monospace;font-size:12px;color:var(--muted)}
/* roscos (donut charts) del cuadro de mando AC */
.roscos{display:flex;flex-wrap:wrap;gap:24px;justify-content:space-around}
.rosco{text-align:center;min-width:200px}
.rtit{font-size:13px;font-weight:600;color:var(--olive-dark);margin-bottom:6px}
.legs{margin-top:10px;display:inline-block;text-align:left}
.leg{display:block;font-size:13px;color:var(--ink);margin:3px 0;text-decoration:none;padding:2px 4px;border-radius:6px}
a.leg:hover{background:var(--olive-light)}
svg a{cursor:pointer}
.dotc{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:6px;vertical-align:middle}
th.num,td.num{text-align:right}
/* ayuda contextual */
.help-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;border:1px solid var(--line);background:var(--olive-light);color:var(--olive-dark);font-weight:700;cursor:pointer;user-select:none}
.help-btn:hover{background:var(--olive);color:#fff}
.help-panel{display:none;background:#fff;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
#help-toggle:checked ~ .help-panel{display:block}
.help-inner{max-width:1080px;margin:0 auto;padding:16px 22px}
.help-inner h4{margin:0 0 8px;color:var(--olive-dark)}
.help-inner p,.help-inner li{font-size:14px;line-height:1.6;color:var(--ink)}
.help-inner ul{margin:6px 0;padding-left:20px}
footer{text-align:center;color:var(--muted);font-size:12px;padding:24px}
