/* eRRC — design system. Self-contained, no external fonts/CDN. */
:root{
  --bg:#0b0809; --bg-2:#120d0f; --panel:#191215; --panel-2:#22181b;
  --line:#33252a; --line-2:#45323a;
  --txt:#f0ecef; --muted:#b0a3a8; --faint:#7a6b71;
  --brand:#ff4757; --brand-2:#c81e3a; --accent:#22d3a6;
  --warn:#f5a524; --danger:#f0445e; --ok:#22d3a6;
  --gold:#ffd166; --silver:#cfd6e6; --bronze:#e0915a;
  --radius:16px; --radius-sm:10px;
  --shadow:0 10px 40px -12px rgba(0,0,0,.6);
  --grad:linear-gradient(135deg,var(--brand),var(--brand-2));
  --nav-bg:rgba(12,9,10,.72);
  --bg-img:radial-gradient(1200px 600px at 80% -10%,rgba(255,71,87,.16),transparent 60%),
           radial-gradient(900px 500px at -10% 10%,rgba(200,30,58,.14),transparent 55%);
  --row-hover:#ffffff06;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji",sans-serif;
}
/* ---- light theme ---- */
:root[data-theme="light"]{
  --bg:#f4f6fb; --bg-2:#eef1f8; --panel:#ffffff; --panel-2:#f1f4fb;
  --line:#e3e8f1; --line-2:#d2dae8;
  --txt:#101524; --muted:#56627d; --faint:#8a96ad;
  --gold:#d4a017; --silver:#9aa6bd; --bronze:#c07d49;
  --shadow:0 10px 30px -16px rgba(25,40,80,.25);
  --nav-bg:rgba(255,255,255,.8);
  --bg-img:radial-gradient(1200px 600px at 85% -10%,rgba(255,71,87,.08),transparent 60%),
           radial-gradient(900px 500px at -10% 5%,rgba(200,30,58,.08),transparent 55%);
  --row-hover:#1015240a;
}
:root[data-theme="light"] .b-draft{background:#eef1f7;color:#8b96ad;border-color:#e2e7f0}
:root[data-theme="light"] .b-entered{background:#fdf3df;color:#9a6a08;border-color:#f0dca8}
:root[data-theme="light"] .b-validated{background:#e3f6ee;color:#0d7a55;border-color:#bfe9d6}
:root[data-theme="light"] .flash.ok{background:#e3f6ee;border-color:#bfe9d6;color:#0d6e4d}
:root[data-theme="light"] .flash.err{background:#fde7ec;border-color:#f3c2cd;color:#b42342}
:root[data-theme="light"] .flash.warn{background:#fdf3df;border-color:#f0dca8;color:#8a5e06}
:root[data-theme="light"] .rank-1{border-color:#e8cf7a;background:linear-gradient(100deg,#fdf7e6,var(--panel))}
:root[data-theme="light"] .rank-2{border-color:#cfd6e6;background:var(--panel)}
:root[data-theme="light"] .rank-3{border-color:#ecd0b3;background:var(--panel)}
:root[data-theme="light"] .sched-block.malica{background:#fdf3df;border-color:#f0dca8;color:#8a5e06}
:root[data-theme="light"] .gantt-bar.malica{background:#f6e4b8;border-color:#e0a93a;color:#5a3f06}
:root[data-theme="light"] .btn-danger{background:#fdeef1;color:#c0334e;border-color:#f3c2cd}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font); color:var(--txt); background:var(--bg);
  background-image:var(--bg-img);
  background-attachment:fixed; min-height:100vh; line-height:1.5;
  -webkit-font-smoothing:antialiased; font-size:15px;
}
a{color:var(--brand); text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{margin:0 0 .4em; font-weight:700; letter-spacing:-.02em}
h1{font-size:1.7rem} h2{font-size:1.25rem} h3{font-size:1rem}
.muted{color:var(--muted)} .faint{color:var(--faint)} .small{font-size:.82rem}
.mono{font-variant-numeric:tabular-nums; font-feature-settings:"tnum"}

/* ---- top bar ---- */
.nav{position:sticky; top:0; z-index:50; backdrop-filter:blur(14px);
  background:var(--nav-bg); border-bottom:1px solid var(--line);}
.nav-in{max-width:1280px; margin:0 auto; padding:.7rem 1.2rem; display:flex; align-items:center; gap:1.1rem}
.brand{display:flex; align-items:center; gap:.6rem; font-weight:800; letter-spacing:-.03em; font-size:1.15rem; color:var(--txt)}
.brand:hover{text-decoration:none}
.brand img{height:34px; width:34px; object-fit:contain; border-radius:8px; background:#fff1; padding:2px}
.brand .e{background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent}
.nav-links{display:flex; gap:.25rem; flex-wrap:wrap; margin-left:.5rem}
.nav-links a{color:var(--muted); padding:.45rem .8rem; border-radius:10px; font-weight:600; font-size:.9rem}
.nav-links a:hover{color:var(--txt); background:var(--panel); text-decoration:none}
.nav-links a.active{color:var(--txt); background:var(--panel-2)}
.nav-right{margin-left:auto; display:flex; align-items:center; gap:.7rem}
.chip{font-size:.78rem; padding:.25rem .6rem; border-radius:999px; background:var(--panel-2); color:var(--muted); border:1px solid var(--line)}

/* ---- layout ---- */
.wrap{max-width:1280px; margin:0 auto; padding:1.6rem 1.2rem 4rem}
.page-head{display:flex; align-items:flex-end; gap:1rem; flex-wrap:wrap; margin-bottom:1.2rem}
.page-head .sub{color:var(--muted)}
.grid{display:grid; gap:1rem}
.cols-2{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}
.cols-3{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}

/* ---- cards ---- */
.card{background:linear-gradient(180deg,var(--panel),var(--bg-2)); border:1px solid var(--line);
  border-radius:var(--radius); padding:1.2rem; box-shadow:var(--shadow)}
.card h2{display:flex; align-items:center; gap:.5rem}
.card-pad{padding:1.4rem}
.stat{display:flex; flex-direction:column; gap:.2rem}
.stat .v{font-size:1.9rem; font-weight:800; letter-spacing:-.03em}
.stat .k{color:var(--muted); font-size:.82rem; text-transform:uppercase; letter-spacing:.06em}

/* ---- buttons ---- */
.btn{display:inline-flex; align-items:center; gap:.5rem; cursor:pointer; font:inherit; font-weight:650;
  border:1px solid var(--line-2); background:var(--panel-2); color:var(--txt);
  padding:.6rem 1rem; border-radius:11px; transition:.15s; text-decoration:none}
.btn:hover{border-color:var(--brand); text-decoration:none; transform:translateY(-1px)}
.btn:active{transform:none}
.btn-primary{background:var(--grad); border:none; color:#fff; box-shadow:0 6px 20px -6px rgba(255,71,87,.5)}
.btn-primary:hover{filter:brightness(1.08)}
.btn-ghost{background:transparent}
.btn-danger{border-color:#5b2533; color:#ff8da0; background:#23131a}
.btn-danger:hover{border-color:var(--danger)}
.btn-sm{padding:.35rem .65rem; font-size:.85rem; border-radius:9px}
.btn[disabled]{opacity:.45; cursor:not-allowed; transform:none}
.btn-row{display:flex; gap:.6rem; flex-wrap:wrap; align-items:center}

/* ---- forms ---- */
label{display:block; font-weight:600; font-size:.85rem; color:var(--muted); margin-bottom:.35rem}
input,select,textarea{width:100%; font:inherit; color:var(--txt); background:var(--bg-2);
  border:1px solid var(--line-2); border-radius:10px; padding:.6rem .7rem; transition:.15s}
input:focus,select:focus,textarea:focus{outline:none; border-color:var(--brand); box-shadow:0 0 0 3px rgba(255,71,87,.18)}
.field{margin-bottom:1rem}
.inline{display:flex; gap:.8rem; flex-wrap:wrap}
.inline .field{flex:1; min-width:120px}
input[type=checkbox]{width:auto}

/* score buttons 1..5 */
.score-row{display:flex; gap:.4rem; flex-wrap:wrap}
.score-row input{display:none}
.score-row label{display:flex; align-items:center; justify-content:center; width:42px; height:42px;
  margin:0; border:1px solid var(--line-2); border-radius:10px; background:var(--bg-2); color:var(--muted);
  font-weight:700; cursor:pointer; transition:.12s}
.score-row label:hover{border-color:var(--brand); color:var(--txt)}
.score-row input:checked + label{background:var(--grad); color:#fff; border-color:transparent; transform:translateY(-1px)}

/* ---- tables ---- */
.tbl-wrap{overflow-x:auto; border-radius:var(--radius); border:1px solid var(--line)}
table{width:100%; border-collapse:collapse; font-size:.92rem}
th,td{padding:.7rem .8rem; text-align:left; border-bottom:1px solid var(--line)}
thead th{background:var(--bg-2); color:var(--muted); font-size:.78rem; text-transform:uppercase; letter-spacing:.05em; position:sticky; top:0}
tbody tr:hover{background:var(--row-hover)}
td.num,th.num{text-align:right; font-variant-numeric:tabular-nums}
tbody tr:last-child td{border-bottom:none}

/* ---- badges / status ---- */
.badge{display:inline-flex; align-items:center; gap:.35rem; font-size:.74rem; font-weight:700;
  padding:.2rem .55rem; border-radius:999px; border:1px solid transparent; white-space:nowrap}
.b-draft{background:#1c2030; color:var(--faint); border-color:var(--line)}
.b-entered{background:#2a2410; color:var(--warn); border-color:#4a3d12}
.b-validated{background:#0f2a22; color:var(--ok); border-color:#15402f}
.dot{width:8px; height:8px; border-radius:50%; display:inline-block}
.dot.ok{background:var(--ok)} .dot.warn{background:var(--warn)} .dot.none{background:var(--faint)}

/* ---- ranking ---- */
.rank-card{display:flex; align-items:center; gap:1rem; padding:1rem 1.2rem; border:1px solid var(--line);
  border-radius:14px; background:var(--panel); margin-bottom:.7rem; transition:.25s}
.rank-card .pos{font-size:1.5rem; font-weight:800; width:2.4rem; text-align:center; color:var(--faint)}
.rank-1{border-color:#5a4a18; background:linear-gradient(100deg,#1d1808,var(--panel))}
.rank-1 .pos{color:var(--gold)}
.rank-2{border-color:#3a4254} .rank-2 .pos{color:var(--silver)}
.rank-3{border-color:#4a3320} .rank-3 .pos{color:var(--bronze)}
.rank-card .grow{flex:1; min-width:0}
.rank-card .tname{font-weight:700; font-size:1.05rem}
.rank-card .tscore{font-size:1.6rem; font-weight:800; letter-spacing:-.03em}
.bar{height:7px; border-radius:4px; background:var(--line); overflow:hidden; margin-top:.45rem}
.bar > span{display:block; height:100%; background:var(--grad); border-radius:4px; transition:width .6s cubic-bezier(.2,.8,.2,1)}

/* ---- SaaS leaderboard table (dashboard) ---- */
.lead-wrap{overflow-x:auto; border:1px solid var(--line); border-radius:var(--radius)}
.lead{width:100%; border-collapse:separate; border-spacing:0; font-size:.92rem}
.lead th,.lead td{padding:.7rem .8rem; border-bottom:1px solid var(--line); text-align:center; white-space:nowrap}
.lead thead th{background:var(--bg-2); color:var(--muted); font-size:.72rem; font-weight:700; text-transform:uppercase;
  letter-spacing:.05em; position:sticky; top:0; z-index:3}
.lead tbody tr{transition:.15s}
.lead tbody tr:hover{background:var(--row-hover)}
.lead tbody tr:last-child td{border-bottom:none}
.lead .col-rank{width:56px; text-align:center; font-weight:800; font-size:1.05rem; color:var(--faint)}
.lead .col-team{text-align:left; position:sticky; left:0; background:var(--panel); z-index:2}
.lead thead .col-team{background:var(--bg-2); z-index:4}
.lead tbody tr:hover .col-team{background:var(--panel-2)}
.lead .col-pt{font-weight:600; color:var(--muted)}
.lead .col-total{text-align:right}
.lead .tname{font-weight:700; font-size:.98rem}
.lead .tflag{margin-right:.4rem}
.lead .tcountry{color:var(--faint); font-size:.78rem; font-weight:500}
.lead tr.is-1 .col-rank{color:var(--gold)} .lead tr.is-2 .col-rank{color:var(--silver)} .lead tr.is-3 .col-rank{color:var(--bronze)}
.lead tr.is-1{background:linear-gradient(100deg,rgba(255,209,102,.08),transparent 40%)}
.lead .tot{display:inline-flex; flex-direction:column; align-items:flex-end; gap:.25rem; min-width:74px}
.lead .tot .v{font-size:1.25rem; font-weight:800; letter-spacing:-.02em; font-variant-numeric:tabular-nums}
.lead .tot .bar{width:74px; margin-top:0}

/* per-location score pill */
.pill{display:inline-flex; align-items:center; gap:.35rem; min-width:3.1rem; justify-content:center;
  padding:.28rem .5rem; border-radius:9px; font-weight:700; font-size:.86rem; font-variant-numeric:tabular-nums;
  border:1px solid transparent}
.pill.validated{background:rgba(34,211,166,.13); color:var(--ok); border-color:rgba(34,211,166,.28)}
.pill.entered{background:rgba(245,165,36,.13); color:var(--warn); border-color:rgba(245,165,36,.28)}
.pill.empty{background:transparent; color:var(--faint); border:1px dashed var(--line-2); font-weight:600}
.pill .pdot{width:6px; height:6px; border-radius:50%; flex:none}
.pill.validated .pdot{background:var(--ok)} .pill.entered .pdot{background:var(--warn)}
.lead .pnmp-sub{display:block; font-size:.66rem; color:var(--faint); font-weight:600; margin-top:.15rem}
.legend{display:flex; gap:1.1rem; flex-wrap:wrap; align-items:center; color:var(--muted); font-size:.82rem; margin-top:.9rem}
.legend .pill{min-width:0; padding:.15rem .45rem; font-size:.78rem}

/* ---- flash ---- */
.flash{padding:.8rem 1rem; border-radius:12px; margin-bottom:1rem; border:1px solid var(--line); font-weight:600}
.flash.ok{background:#0f2a22; border-color:#15402f; color:#7ef0cd}
.flash.err{background:#2a1119; border-color:#5b2533; color:#ff9db0}
.flash.warn{background:#2a2410; border-color:#4a3d12; color:#ffd58a}

/* ---- login ---- */
.login-wrap{min-height:100vh; display:grid; place-items:center; padding:1.5rem}
.login-card{width:100%; max-width:400px}
.login-logo{display:flex; flex-direction:column; align-items:center; gap:.8rem; margin-bottom:1.6rem}
.login-logo img{height:72px; width:72px; object-fit:contain}
.login-logo .t{font-size:2rem; font-weight:800; letter-spacing:-.03em}
.login-logo .t .e{background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent}

/* ---- schedule grid ---- */
.sched{display:grid; gap:.5rem}
.sched-row{display:grid; grid-template-columns:180px 1fr; gap:.6rem; align-items:start}
.sched-team{font-weight:700; padding-top:.4rem}
.sched-track{position:relative; height:auto; display:flex; flex-direction:column; gap:.35rem}
.sched-block{border-radius:10px; padding:.45rem .65rem; font-size:.82rem; border:1px solid var(--line-2);
  background:var(--panel-2); display:flex; justify-content:space-between; gap:.5rem; align-items:center}
.sched-block.malica{background:#2a2110; border-color:#4a3d12; color:var(--warn)}
.sched-block .t{color:var(--muted); font-variant-numeric:tabular-nums; white-space:nowrap}
.locked-i{color:var(--warn)}

/* gantt-style print/visual timeline */
.gantt{position:relative; overflow-x:auto; border:1px solid var(--line); border-radius:var(--radius); padding:.5rem}
.gantt-row{position:relative; height:38px; border-bottom:1px solid var(--line)}
.gantt-row:last-child{border-bottom:none}
.gantt-lbl{position:absolute; left:0; top:0; width:150px; padding:.5rem; font-weight:700; font-size:.85rem; background:var(--bg-2); z-index:2; height:100%}
.gantt-area{position:relative; margin-left:150px; height:100%}
.gantt-bar{position:absolute; top:5px; height:28px; border-radius:7px; font-size:.72rem; color:#fff;
  display:flex; align-items:center; padding:0 .5rem; overflow:hidden; white-space:nowrap; background:var(--grad)}
.gantt-bar.malica{background:#f5a52455; border:1px dashed #f5a524; color:#ffd58a}

.tabs{display:flex; gap:.25rem; background:var(--panel-2); padding:.3rem; border-radius:12px; width:fit-content; border:1px solid var(--line)}
.tabs button,.tabs a{border:none; background:transparent; color:var(--muted); padding:.45rem .95rem; border-radius:9px; font:inherit; font-weight:650; font-size:.9rem; cursor:pointer; text-decoration:none; transition:.15s}
.tabs button:hover,.tabs a:hover{color:var(--txt); text-decoration:none}
.tabs button.active,.tabs a.active{background:var(--grad); color:#fff; box-shadow:0 4px 14px -6px rgba(255,71,87,.6)}

/* ---- FAANG-style underline sub-navigation (admin) ---- */
.subnav{display:flex; gap:.1rem; border-bottom:1px solid var(--line); margin-bottom:1.6rem; overflow-x:auto; scrollbar-width:none}
.subnav::-webkit-scrollbar{display:none}
.subnav a{position:relative; display:inline-flex; align-items:center; gap:.45rem; padding:.7rem .95rem; color:var(--muted);
  font-weight:600; font-size:.92rem; white-space:nowrap; border-bottom:2px solid transparent; margin-bottom:-1px;
  border-radius:8px 8px 0 0; transition:.15s; text-decoration:none}
.subnav a:hover{color:var(--txt); background:var(--row-hover); text-decoration:none}
.subnav a.active{color:var(--txt); border-bottom-color:var(--brand)}
.subnav a .ico{font-size:1.02em; opacity:.9}

.hidden{display:none!important}
hr{border:none; border-top:1px solid var(--line); margin:1.2rem 0}
.spacer{flex:1}

@media print{
  .nav,.btn,.tabs,.no-print{display:none!important}
  body{background:#fff; color:#000}
  .card,.gantt{box-shadow:none; border-color:#ccc}
  .gantt-bar{background:#dde3f5!important; color:#000; border:1px solid #99a}
}
@media (max-width:640px){
  .sched-row{grid-template-columns:1fr}
  .nav-links{display:none}
}
