/* NHS Overtime Calculator — scoped to #nhsc-ot — 2026/27 */
#nhsc-ot *,#nhsc-ot *::before,#nhsc-ot *::after{box-sizing:border-box;margin:0;padding:0}

#nhsc-ot{max-width:1200px;margin:0 auto;padding:24px 16px;background:#0d1117;color:#e6edf3;font-family:'Inter',system-ui,sans-serif;font-size:14px;line-height:1.5}

/* HERO */
#nhsc-ot .hero{background:linear-gradient(135deg,#0d2137,#1a3a5c,#0d2137);border:1px solid rgba(31,111,235,.3);border-radius:16px;padding:36px 44px;margin-bottom:18px;position:relative;overflow:hidden}
#nhsc-ot .hero::after{content:'';position:absolute;bottom:-80px;right:-60px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(56,139,253,.1),transparent 70%)}
#nhsc-ot .hi{position:relative;z-index:1}
#nhsc-ot .htag{display:inline-flex;align-items:center;gap:6px;background:rgba(31,111,235,.15);border:1px solid rgba(31,111,235,.35);border-radius:20px;padding:4px 13px;font-size:11px;font-weight:600;color:#388bfd;letter-spacing:.05em;text-transform:uppercase;margin-bottom:13px}
#nhsc-ot .hdot{width:6px;height:6px;background:#3fb950;border-radius:50%;box-shadow:0 0 6px #3fb950}
#nhsc-ot .hero h1{font-size:clamp(20px,3vw,34px);font-weight:700;color:#fff;line-height:1.15;margin-bottom:8px}
#nhsc-ot .hero p{font-size:13px;color:#8b949e;max-width:560px;line-height:1.65;margin-bottom:16px}
#nhsc-ot .pills{display:flex;flex-wrap:wrap;gap:5px}
#nhsc-ot .pill{display:flex;align-items:center;gap:4px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:3px 10px;font-size:11px;color:#8b949e}
#nhsc-ot .pok{color:#3fb950;font-size:10px}

/* LAYOUT */
#nhsc-ot .layout{display:grid;grid-template-columns:1fr 420px;gap:16px;align-items:start}
@media(max-width:960px){#nhsc-ot .layout{grid-template-columns:1fr}}

/* CARD */
#nhsc-ot .card{background:#161b22;border:1px solid rgba(255,255,255,.08);border-radius:10px;margin-bottom:12px;overflow:hidden}
#nhsc-ot .ch{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.06);background:#1c2230}
#nhsc-ot .ci{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
#nhsc-ot .ci-b{background:rgba(31,111,235,.15)}
#nhsc-ot .ci-g{background:rgba(35,134,54,.15)}
#nhsc-ot .ci-a{background:rgba(187,128,9,.15)}
#nhsc-ot .ci-r{background:rgba(218,54,51,.15)}
#nhsc-ot .ci-p{background:rgba(137,87,229,.15)}
#nhsc-ot .ct{font-size:12px;font-weight:600;color:#e6edf3;letter-spacing:.03em}
#nhsc-ot .cb{padding:14px 16px}

/* FORM */
#nhsc-ot .lbl{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#484f58;margin-bottom:6px;margin-top:10px}
#nhsc-ot .lbl:first-child{margin-top:0}
#nhsc-ot .inp{width:100%;background:#0d1117;border:1px solid rgba(255,255,255,.12);border-radius:6px;padding:8px 12px;color:#e6edf3;font:400 13px/1 'Inter',system-ui,sans-serif;outline:none;transition:.15s}
#nhsc-ot .inp:focus{border-color:#388bfd;box-shadow:0 0 0 3px rgba(31,111,235,.15)}
#nhsc-ot .iw{position:relative}
#nhsc-ot .ipx{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#484f58;font-size:13px;pointer-events:none}
#nhsc-ot .isfx{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:#484f58;font-size:11px;pointer-events:none}
#nhsc-ot .hint{font-size:10px;color:#484f58;margin-top:4px;line-height:1.4}
#nhsc-ot .fld{margin-bottom:10px}

/* OT HOURS GRID */
#nhsc-ot .ot-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
#nhsc-ot .ot-item{}
#nhsc-ot .ot-label{font-size:11px;font-weight:600;color:#e6edf3;margin-bottom:3px;display:flex;align-items:center;gap:6px}
#nhsc-ot .ot-rate{font-size:10px;padding:1px 6px;border-radius:3px;font-weight:700}
#nhsc-ot .rt-std{background:rgba(35,134,54,.15);color:#3fb950}
#nhsc-ot .rt-dbl{background:rgba(187,128,9,.2);color:#e3b341}
#nhsc-ot .rt-pln{background:rgba(72,79,88,.2);color:#8b949e}

/* BAND GRID */
#nhsc-ot .bgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(68px,1fr));gap:5px;margin-bottom:10px}
#nhsc-ot .bb{background:#1c2230;border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:7px 4px;text-align:center;cursor:pointer;font:600 11px 'Inter',system-ui,sans-serif;color:#8b949e;line-height:1.2;transition:.15s;display:flex;flex-direction:column;align-items:center;gap:2px}
#nhsc-ot .bb small{font-size:10px;font-weight:400;color:#484f58;display:block}
#nhsc-ot .bb:hover{border-color:#388bfd;color:#388bfd}
#nhsc-ot .bb.on{background:rgba(31,111,235,.15);border-color:#1f6feb;color:#e6edf3}
#nhsc-ot .bb.noOT{border-color:rgba(218,54,51,.3);color:#f85149}
#nhsc-ot .bb.noOT.on{background:rgba(218,54,51,.1);border-color:#da3633;color:#f85149}

/* REGION GRID */
#nhsc-ot .rgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:5px;margin-bottom:8px}
#nhsc-ot .rb{background:#1c2230;border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:9px 10px;cursor:pointer;font:500 12px 'Inter',system-ui,sans-serif;color:#8b949e;display:flex;align-items:center;gap:6px;transition:.15s}
#nhsc-ot .rb:hover{border-color:#388bfd;color:#388bfd}
#nhsc-ot .rb.on{background:rgba(31,111,235,.15);border-color:#1f6feb;color:#e6edf3}
#nhsc-ot .rflag{font-size:14px}

/* FREQ GRID */
#nhsc-ot .fqgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:5px}

/* HCAS */
#nhsc-ot .hgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:5px}

/* LOAN GRID */
#nhsc-ot .lgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}
#nhsc-ot .lb{background:#1c2230;border:1px solid rgba(255,255,255,.08);border-radius:5px;padding:7px 4px;text-align:center;cursor:pointer;font:500 10px 'Inter',system-ui,sans-serif;color:#8b949e;transition:.15s;display:flex;flex-direction:column;align-items:center;gap:1px}
#nhsc-ot .lb small{font-size:9px;color:#484f58}
#nhsc-ot .lb:hover{border-color:#388bfd;color:#388bfd}
#nhsc-ot .lb.on{background:rgba(31,111,235,.15);border-color:#1f6feb;color:#e6edf3}

/* MONTH GRID */
#nhsc-ot .mgrid{display:grid;grid-template-columns:repeat(6,1fr);gap:4px}
#nhsc-ot .mb{background:#1c2230;border:1px solid rgba(255,255,255,.06);border-radius:5px;padding:5px 2px;text-align:center;cursor:pointer;font:500 10px 'Inter',system-ui,sans-serif;color:#8b949e;transition:.15s}
#nhsc-ot .mb:hover{border-color:#388bfd;color:#388bfd}
#nhsc-ot .mb.on{background:rgba(31,111,235,.15);border-color:#1f6feb;color:#e6edf3}

/* TOGGLE */
#nhsc-ot .trow{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.05)}
#nhsc-ot .trow:last-child{border-bottom:none}
#nhsc-ot .tinfo strong{display:block;font-size:12px;font-weight:600;color:#e6edf3;margin-bottom:2px}
#nhsc-ot .tinfo span{font-size:10px;color:#484f58}
#nhsc-ot .tog{position:relative;display:inline-block;width:40px;height:22px;flex-shrink:0}
#nhsc-ot .tog input{opacity:0;width:0;height:0}
#nhsc-ot .tsl{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:#21262d;border-radius:22px;transition:.2s;border:1px solid rgba(255,255,255,.08)}
#nhsc-ot .tsl::before{content:'';position:absolute;width:16px;height:16px;left:2px;bottom:2px;background:#484f58;border-radius:50%;transition:.2s}
#nhsc-ot .tog input:checked + .tsl{background:#238636;border-color:#238636}
#nhsc-ot .tog input:checked + .tsl::before{transform:translateX(18px);background:#fff}

/* RESULTS */
#nhsc-ot .rbox{background:#0d1117;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:14px;margin-bottom:10px}
#nhsc-ot .rrow{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:12px}
#nhsc-ot .rrow:last-child{border-bottom:none}
#nhsc-ot .rlbl{color:#8b949e}
#nhsc-ot .rval{font-weight:600;font-feature-settings:"tnum";color:#e6edf3}
#nhsc-ot .rval.red{color:#f85149}
#nhsc-ot .rval.grn{color:#3fb950}
#nhsc-ot .rval.amb{color:#e3b341}
#nhsc-ot .rsep{border-top:1px solid rgba(255,255,255,.1);margin:8px 0;padding-top:8px}
#nhsc-ot .rbig{font-size:22px;font-weight:700;color:#3fb950}
#nhsc-ot .rbig-r{font-size:20px;font-weight:700;color:#f85149}

/* OT BREAKDOWN */
#nhsc-ot .ot-bk{background:rgba(35,134,54,.06);border:1px solid rgba(35,134,54,.15);border-radius:8px;padding:12px 14px;margin-bottom:10px}
#nhsc-ot .ot-bk-row{display:flex;justify-content:space-between;font-size:11px;padding:3px 0}
#nhsc-ot .ot-bk-total{font-size:14px;font-weight:700;color:#3fb950;padding-top:8px;margin-top:6px;border-top:1px solid rgba(35,134,54,.2);display:flex;justify-content:space-between}

/* RATE CARDS */
#nhsc-ot .rate-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:12px}
#nhsc-ot .rate-card{background:#1c2230;border:1px solid rgba(255,255,255,.07);border-radius:8px;padding:10px 12px;text-align:center}
#nhsc-ot .rate-card strong{display:block;font-size:17px;font-weight:700;font-feature-settings:"tnum";margin-bottom:2px}
#nhsc-ot .rate-card small{font-size:10px;color:#8b949e}
#nhsc-ot .rc-ot strong{color:#3fb950}
#nhsc-ot .rc-bh strong{color:#e3b341}
#nhsc-ot .rc-base strong{color:#388bfd}
#nhsc-ot .rc-toil strong{color:#b083f0}

/* COMPARISON */
#nhsc-ot .cmp-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}
#nhsc-ot .cmp-card{background:#1c2230;border:1px solid rgba(255,255,255,.07);border-radius:8px;padding:12px;text-align:center}
#nhsc-ot .cmp-card strong{display:block;font-size:19px;font-weight:700;margin-bottom:4px;font-feature-settings:"tnum"}
#nhsc-ot .cmp-card small{font-size:10px;color:#8b949e}
#nhsc-ot .cmp-base strong{color:#388bfd}
#nhsc-ot .cmp-ot strong{color:#3fb950}

/* WARN / INFO */
#nhsc-ot .warn{background:rgba(218,54,51,.08);border:1px solid rgba(218,54,51,.2);border-radius:7px;padding:9px 12px;font-size:11px;color:#f85149;margin:6px 0;display:flex;gap:8px;align-items:flex-start;line-height:1.5}
#nhsc-ot .info{background:rgba(31,111,235,.08);border:1px solid rgba(31,111,235,.15);border-radius:7px;padding:9px 12px;font-size:11px;color:#388bfd;margin:6px 0;line-height:1.5}
#nhsc-ot .ok{background:rgba(35,134,54,.08);border:1px solid rgba(35,134,54,.15);border-radius:7px;padding:9px 12px;font-size:11px;color:#3fb950;margin:6px 0;line-height:1.5}
#nhsc-ot .ambi{background:rgba(187,128,9,.08);border:1px solid rgba(187,128,9,.15);border-radius:7px;padding:9px 12px;font-size:11px;color:#e3b341;margin:6px 0;line-height:1.5}

/* DISC */
#nhsc-ot .disc{font-size:10px;color:#484f58;margin-top:20px;padding:12px 14px;border:1px solid rgba(255,255,255,.05);border-radius:7px;line-height:1.6}
