
:root{--navy:#0B1F3A;--cream:#F4EFE7;--gold:#CBB26A;--text:#0B1F3A;--card:#ffffff;--muted:#6B7A90;--shadow:0 8px 18px rgba(0,0,0,.12)}
:root.dark{--cream:#0D1624;--text:#E7EEF9;--card:#0F1B2C;--muted:#9fb0ca}
*{box-sizing:border-box}
html,body{margin:0;background:var(--cream);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial}
.app{max-width:430px;margin:0 auto;padding:16px}
.card{background:var(--card);border-radius:16px;box-shadow:var(--shadow);padding:12px}
header.hd{display:flex;align-items:center;justify-content:space-between}
.hd .brand{display:flex;gap:8px;align-items:center}
.hd img.logo{width:22px;height:22px;border-radius:6px;object-fit:cover}
.tabs{display:flex;gap:8px;margin:12px 0}
.tab{flex:1;text-align:center;padding:10px;border-radius:12px;background:var(--card);box-shadow:var(--shadow);font-weight:900;text-decoration:none;color:inherit}
.tab.active,.tab[aria-current=page]{background:var(--gold);color:#111}
.btn{border:0;border-radius:12px;padding:10px 14px;font-weight:900;cursor:pointer;box-shadow:var(--shadow);background:var(--navy);color:#fff}
.btn.gold{background:var(--gold);color:#111}
.btn.ghost{background:transparent;border:1px solid #2b3a55;color:var(--text)}
.input input,.input select{width:100%;padding:12px;border-radius:12px;border:1px solid #2b3a55;background:var(--card);color:var(--text)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.full{grid-column:1/-1}
.kpi .h{font-size:12px;color:var(--muted)}
.kpi .v{font-size:22px;font-weight:900}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(min-width:900px){.grid{grid-template-columns:1fr 1fr} /* force 2x? on desktop as requested */ }
.tile{position:relative;background:var(--card);border-radius:18px;box-shadow:var(--shadow);padding:12px;display:flex;flex-direction:column;gap:6px;align-items:center;min-height:152px}
.tile .name{font-weight:900;text-align:center;overflow-wrap:anywhere}
.tile .mid{font-size:12px;color:var(--muted)}
.tile .row{display:flex;gap:8px;align-items:center}
.tile .menu{border:1px solid #2b3a55;background:transparent;color:var(--text);border-radius:10px;padding:4px 8px;cursor:pointer}
.tile .donut svg{width:84px;height:84px}
.tile-pop{position:fixed;z-index:120;background:var(--card);border-radius:12px;box-shadow:var(--shadow);padding:6px;display:none;min-width:160px}
.tile-pop .it{padding:8px 10px;border-radius:10px;cursor:pointer}
.tile-pop .it:hover{background:rgba(0,0,0,.06)}
.hamb{border:1px solid #2b3a55;background:transparent;color:var(--text);border-radius:10px;padding:8px 10px;cursor:pointer;box-shadow:var(--shadow)}
.menu-sheet{position:fixed;right:10px;top:10px;background:var(--card);border-radius:14px;box-shadow:var(--shadow);padding:8px;min-width:260px;display:none;z-index:90}
.menu-sheet.open{display:block}
.menu-sheet .hdr{display:flex;align-items:center;justify-content:space-between;font-weight:900;padding:6px 8px 4px}
.menu-sheet .closex{border:0;background:transparent;font-size:18px;cursor:pointer;color:var(--text)}
.menu-sheet .it{padding:8px;border-radius:10px;cursor:pointer}
.menu-sheet .it:hover{background:rgba(0,0,0,.08)}
.modal{position:fixed;inset:0;background:rgba(0,0,0,.45);display:none;align-items:center;justify-content:center;z-index:100}
.modal.open{display:flex}
.modal .dialog{background:var(--card);border-radius:16px;box-shadow:var(--shadow);padding:12px;width:92vw;max-width:430px}
.keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:8px}
.key{padding:16px 0;text-align:center;border:1px solid #2b3a55;border-radius:12px;font-size:18px;font-weight:900;background:transparent;color:var(--text);cursor:pointer}
.key.ok{background:#2d7f5e;color:#fff}
.key.cancel{background:#3a4a66;color:#fff}
.preview{font-size:28px;font-weight:900;text-align:center;margin-top:8px}
/* Tour */
.spot{position:fixed;inset:0;z-index:95;pointer-events:none}
.spot .mask{position:absolute;inset:0;background:radial-gradient(140px 140px at 50% 50%, transparent 0 98%, rgba(0,0,0,.60) 98.5%) no-repeat;transition:background-position 80ms linear, background-size 80ms linear}
.tour{position:fixed;z-index:96;background:var(--card);box-shadow:var(--shadow);border-radius:14px;padding:10px;max-width:300px}
.tour .cta{display:flex;gap:8px;margin-top:8px;justify-content:flex-end}
.tour button{border:0;border-radius:10px;padding:6px 10px;cursor:pointer}
.tour .next{background:var(--gold);color:#111}
.tour .skip{background:#eee;color:#222}
.tour-hl{outline:3px solid var(--gold)!important; box-shadow:0 0 0 6px rgba(203,178,106,0.25), 0 6px 18px rgba(0,0,0,.18)!important; border-radius:14px!important}
/* Login center */
body.login header.hd,body.login .tabs{display:none!important}
body.login .app{min-height:100vh;display:flex;align-items:center;justify-content:center}
body.login .card{width:100%;max-width:430px}
.toast{position:fixed;left:50%;top:18px;transform:translateX(-50%);background:#111;color:#fff;padding:8px 12px;border-radius:10px;box-shadow:var(--shadow);opacity:0;transition:.25s;z-index:200}
.toast.open{opacity:1}
