@import"https://fonts.googleapis.com/css2?family=Archivo:wght@500;600;700;800&family=Hanken+Grotesk:wght@400;500;600;700&display=swap";:root{--navy-900: #0a1424;--navy-850: #0d1a2e;--navy-800: #102139;--navy-700: #16294a;--navy-600: #1f3a63;--line: rgba(201, 162, 39, .16);--line-soft: rgba(255, 255, 255, .07);--gold: #c9a227;--gold-bright: #e3c14e;--gold-dim: rgba(201, 162, 39, .12);--text: #e8edf5;--text-dim: #9fb0c6;--text-faint: #6b7e98;--green: #46b97a;--amber: #e0a52e;--red: #e06b5e;--blue: #5b9bd5;--radius: 10px;--shadow: 0 8px 28px rgba(0, 0, 0, .35);--font-display: "Rajdhani", system-ui, sans-serif;--font-body: "IBM Plex Sans", system-ui, sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, monospace}:root[data-theme=light]{--font-display: "Archivo", system-ui, sans-serif;--font-body: "Hanken Grotesk", system-ui, sans-serif;--gold: #a6772b;--gold-bright: #b9852f;--gold-dim: rgba(200, 150, 62, .14);--text: #0d1f33;--text-dim: #3a4d63;--text-faint: #6b7e92;--line: rgba(13, 31, 51, .12);--line-soft: rgba(13, 31, 51, .07);--shadow: 0 2px 6px rgba(5, 30, 61, .08), 0 18px 48px rgba(5, 30, 61, .14);--green: #0a7040;--amber: #9e5e00;--red: #d03a2c;--blue: #1f6fc4}:root[data-theme=light] body{background:radial-gradient(120% 60% at 50% -10%,rgba(200,150,62,.07),transparent 60%),radial-gradient(90% 50% at 100% 0%,rgba(10,42,82,.05),transparent 55%),#eef2f7}:root[data-theme=light] .sidebar{background:#fff;border-right:1px solid var(--line)}:root[data-theme=light] .card{background:#fff;border:1px solid var(--line);box-shadow:0 1px 2px #051e3d0a,0 6px 18px #051e3d0f}:root[data-theme=light] .card.glow{border-color:var(--gold-dim)}:root[data-theme=light] .input,:root[data-theme=light] .select{background:#f0f4f9;border-color:var(--line);color:var(--text)}:root[data-theme=light] .topbar{border-bottom:1px solid var(--line)}:root[data-theme=light] .table tr:hover td{background:#0d1f3306}:root[data-theme=light] .auth-panel{background:#eef2f7}:root[data-theme=light] .nav-item.active{background:var(--gold-dim);color:var(--gold)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-body);background:radial-gradient(1200px 600px at 80% -10%,#13284a 0%,var(--navy-900) 55%);color:var(--text);-webkit-font-smoothing:antialiased;font-size:14px}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}.app{display:grid;grid-template-columns:232px 1fr;min-height:100vh}.sidebar{background:linear-gradient(180deg,var(--navy-850),var(--navy-900));border-right:1px solid var(--line);padding:20px 14px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:4px}.brand{display:flex;align-items:center;gap:10px;padding:4px 8px 18px}.brand-mark{width:34px;height:34px;border-radius:8px;flex-shrink:0;background:linear-gradient(135deg,var(--gold),#8a6f15);display:grid;place-items:center;color:#1a1304;font-weight:700;font-family:var(--font-display);font-size:18px}.brand-name{font-family:var(--font-display);font-weight:700;font-size:18px;letter-spacing:.5px;line-height:1}.brand-sub{font-size:10px;color:var(--text-faint);letter-spacing:2px;text-transform:uppercase}.nav-section{font-size:10px;color:var(--text-faint);letter-spacing:1.5px;text-transform:uppercase;padding:14px 10px 6px}.nav-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:8px;color:var(--text-dim);font-weight:500;font-size:13.5px;transition:all .12s}.nav-item:hover{background:var(--line-soft);color:var(--text)}.nav-item.active{background:var(--gold-dim);color:var(--gold-bright)}.nav-item .ico{width:18px;text-align:center;opacity:.9}.nav-spacer{flex:1}.nav-foot{font-size:11px;color:var(--text-faint);padding:8px 10px;border-top:1px solid var(--line-soft)}.main{min-width:0;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;padding:18px 28px;border-bottom:1px solid var(--line-soft)}.page-title{font-family:var(--font-display);font-size:24px;font-weight:700;letter-spacing:.4px}.page-sub{color:var(--text-faint);font-size:12.5px;margin-top:2px}.content{padding:24px 28px 60px}.grid{display:grid;gap:16px}.cols-4{grid-template-columns:repeat(4,1fr)}.cols-3{grid-template-columns:repeat(3,1fr)}.cols-2{grid-template-columns:repeat(2,1fr)}.card{background:linear-gradient(180deg,#16294a8c,#0d1a2e8c);border:1px solid var(--line-soft);border-radius:var(--radius);padding:18px}.card.glow{border-color:var(--line)}.stat .label{font-size:11px;letter-spacing:1.4px;text-transform:uppercase;color:var(--text-faint)}.stat .value{font-family:var(--font-display);font-size:34px;font-weight:700;margin-top:6px;line-height:1}.stat .meta{font-size:12px;color:var(--text-dim);margin-top:7px}.value.gold{color:var(--gold-bright)}.table{width:100%;border-collapse:collapse;font-size:13px}.table th{text-align:left;font-size:10.5px;letter-spacing:1px;text-transform:uppercase;color:var(--text-faint);font-weight:600;padding:10px 14px;border-bottom:1px solid var(--line)}.table td{padding:11px 14px;border-bottom:1px solid var(--line-soft);color:var(--text)}.table tr:hover td{background:#ffffff06}.table .clickable{cursor:pointer}.mono{font-family:var(--font-mono);font-size:12.5px;color:var(--text-dim)}.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;letter-spacing:.3px;background:var(--line-soft);color:var(--text-dim)}.badge.freq{background:var(--gold-dim);color:var(--gold-bright)}.badge.area{background:#5b9bd524;color:#8fc0f0}.badge.open{background:#e0a52e26;color:var(--amber)}.badge.completed{background:#46b97a26;color:var(--green)}.badge.in_progress{background:#5b9bd526;color:var(--blue)}.badge.overdue{background:#e06b5e26;color:var(--red)}.badge.ppe{background:#5b9bd526;color:#8fc0f0}.badge.hazard{background:#e06b5e26;color:var(--red)}.badge.loto{background:#e0a52e26;color:var(--amber)}.badge.food_safety{background:#46b97a26;color:var(--green)}.row{display:flex;align-items:center;gap:10px}.between{justify-content:space-between}.wrap{flex-wrap:wrap}.toolbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}.input,.select{background:var(--navy-850);border:1px solid var(--line-soft);color:var(--text);padding:9px 12px;border-radius:8px;font-size:13px;font-family:inherit;outline:none}.input:focus,.select:focus{border-color:var(--gold)}.input{min-width:240px}.btn{background:var(--gold);color:#1a1304;font-weight:600;border:none;padding:9px 16px;border-radius:8px;font-size:13px}.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--gold-bright)}.section-title{font-family:var(--font-display);font-size:16px;font-weight:600;margin:26px 0 12px;letter-spacing:.3px}.muted{color:var(--text-faint)}.back{color:var(--text-dim);font-size:13px;margin-bottom:14px;display:inline-block}.back:hover{color:var(--gold-bright)}.pill-row{display:flex;gap:8px;flex-wrap:wrap}.step{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--line-soft)}.step-no{width:24px;height:24px;border-radius:6px;background:var(--gold-dim);color:var(--gold-bright);display:grid;place-items:center;font-size:12px;font-weight:700;flex-shrink:0;font-family:var(--font-mono)}.step-text{font-size:13.5px;line-height:1.5;color:var(--text);white-space:pre-line}.legend{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.legend-item{display:flex;gap:9px;align-items:baseline;font-size:13px}.legend-code{font-family:var(--font-mono);color:var(--gold-bright);font-weight:600;width:16px}.empty{text-align:center;color:var(--text-faint);padding:60px 20px}.loading{color:var(--text-faint);padding:30px;font-size:13px}.bar{height:7px;border-radius:6px;background:var(--line-soft);overflow:hidden;margin-top:8px}.bar>span{display:block;height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-bright))}.menu-btn{display:none;background:transparent;border:1px solid var(--line);color:var(--gold-bright);padding:7px 11px;border-radius:8px}@media(max-width:860px){.app{grid-template-columns:1fr}.sidebar{position:fixed;left:0;top:0;z-index:50;width:230px;transform:translate(-100%);transition:transform .2s;box-shadow:var(--shadow)}.sidebar.open{transform:translate(0)}.menu-btn{display:inline-flex}.topbar{padding:14px 16px}.content{padding:16px 16px 80px}.cols-2{grid-template-columns:1fr}.cols-3,.cols-4{grid-template-columns:repeat(2,1fr);gap:10px}.stat{padding:13px 14px}.stat .value{font-size:24px}.page-title{font-size:20px}.input{min-width:0;width:100%}.toolbar{flex-direction:column}.legend{grid-template-columns:1fr}.scroll-x{overflow-x:visible}.table thead{display:none}.table,.table tbody,.table tr,.table td{display:block;width:100%}.table tr{border:1px solid var(--line-soft);border-radius:var(--radius);margin:0 0 10px;background:#ffffff04}.table tr:hover td{background:transparent}.table td{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:9px 14px;text-align:right;min-height:40px}.table tr td:last-child{border-bottom:none}.table td:before{content:attr(data-label);flex:0 0 auto;text-align:left;font-size:10.5px;letter-spacing:1px;text-transform:uppercase;color:var(--text-faint);font-weight:600}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:40}}.auth-splash{display:grid;place-items:center;min-height:100vh;color:var(--text-faint)}.signout{display:block;margin-top:10px;background:transparent;border:1px solid var(--line);color:var(--text-dim);font-size:11px;padding:5px 10px;border-radius:7px;width:100%}.signout:hover{color:var(--gold-bright);border-color:var(--line);background:var(--line-soft)}.auth-wrap{display:grid;grid-template-columns:1.05fr 1fr;min-height:100vh}.auth-brand{position:relative;overflow:hidden;background:radial-gradient(900px 500px at 15% -10%,#16294a 0%,transparent 60%),linear-gradient(160deg,var(--navy-850),var(--navy-900));border-right:1px solid var(--line);display:flex;align-items:center;padding:56px}.auth-brand:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;opacity:.5;background-image:radial-gradient(rgba(201,162,39,.1) 1px,transparent 1.4px);background-size:22px 22px;-webkit-mask-image:radial-gradient(80% 80% at 30% 20%,#000,transparent 75%);mask-image:radial-gradient(80% 80% at 30% 20%,#000,transparent 75%)}.auth-brand-inner{position:relative;max-width:440px}.auth-logo{display:flex;align-items:center;gap:11px;margin-bottom:40px}.auth-headline{font-family:var(--font-display);font-weight:700;font-size:40px;line-height:1.05;letter-spacing:.2px;margin-bottom:26px}.auth-headline .gold{color:var(--gold-bright)}.auth-points{list-style:none;display:flex;flex-direction:column;gap:13px}.auth-points li{position:relative;padding-left:24px;color:var(--text-dim);font-size:14.5px}.auth-points li:before{content:"▹";position:absolute;left:0;color:var(--gold);font-weight:700}.auth-foot{margin-top:40px;color:var(--text-faint);font-size:12.5px}.auth-panel{display:grid;place-items:center;padding:40px 28px}.auth-card{width:100%;max-width:380px}.auth-card-head{margin-bottom:24px}.auth-card-head h2{font-family:var(--font-display);font-size:26px;font-weight:700;letter-spacing:.3px}.auth-card-head p{color:var(--text-faint);font-size:13.5px;margin-top:5px}.auth-form{display:flex;flex-direction:column;gap:15px}.auth-row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.auth-label{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--text-dim);letter-spacing:.3px}.auth-input{width:100%;min-width:0}.auth-submit{width:100%;padding:11px;font-size:14px;margin-top:4px}.auth-meta{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:12.5px;color:var(--text-faint);margin-top:4px}.auth-link{color:var(--gold-bright)}.auth-link:hover{text-decoration:underline}.auth-err{background:#e06b5e1f;border:1px solid rgba(224,107,94,.4);color:#f0a89f;padding:9px 12px;border-radius:8px;font-size:12.5px}.auth-note{color:var(--text-dim);font-size:13.5px;line-height:1.6;margin-bottom:18px}@media(max-width:860px){.auth-wrap{grid-template-columns:1fr}.auth-brand{display:none}.auth-panel{padding:32px 20px}}.onb{max-width:1000px;margin:0 auto;padding:56px 24px 80px}.onb-head{text-align:center;margin-bottom:36px}.onb-head h1{font-family:var(--font-display);font-size:30px;font-weight:700;letter-spacing:.3px}.onb-head .muted{margin-top:8px}.onb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:start}.plan-card{position:relative;background:linear-gradient(180deg,#16294a8c,#0d1a2e8c);border:1px solid var(--line-soft);border-radius:14px;padding:24px 22px;display:flex;flex-direction:column;gap:14px}.plan-card.featured{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold-dim),var(--shadow)}.plan-tag{position:absolute;top:-11px;left:22px;background:var(--gold);color:#1a1304;font-size:10.5px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;padding:3px 10px;border-radius:20px}.plan-name{font-family:var(--font-display);font-size:17px;font-weight:600;color:var(--text-dim);letter-spacing:.4px}.plan-price{font-family:var(--font-display);font-size:40px;font-weight:700;line-height:1}.plan-price span{font-size:15px;color:var(--text-faint);font-weight:500}.plan-feats{list-style:none;display:flex;flex-direction:column;gap:9px;margin:4px 0 8px}.plan-feats li{position:relative;padding-left:22px;font-size:13px;color:var(--text-dim)}.plan-feats li:before{content:"✓";position:absolute;left:0;color:var(--green);font-weight:700}.spinner{width:26px;height:26px;margin:18px auto 0;border-radius:50%;border:3px solid var(--line-soft);border-top-color:var(--gold);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:860px){.onb-grid{grid-template-columns:1fr}}.months{display:flex;align-items:flex-end;gap:10px;height:200px;padding-top:8px}.month-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}.month-bar{flex:1;width:100%;display:flex;align-items:flex-end}.month-bar>span{display:block;width:100%;border-radius:5px 5px 0 0;background:linear-gradient(180deg,var(--gold-bright),var(--gold));min-height:2px}.month-lbl{font-size:10.5px;color:var(--text-faint);margin-top:6px;text-transform:uppercase;letter-spacing:.5px}.month-val{font-family:var(--font-mono);font-size:9.5px;color:var(--text-dim);margin-top:2px}@media(max-width:860px){.month-val{display:none}.months{gap:4px}}.modal-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:100;display:grid;place-items:center;padding:20px}.modal{width:100%;max-width:560px;max-height:90vh;overflow:auto;background:var(--navy-850);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow)}:root[data-theme=light] .modal{background:#fff}.modal.wide{max-width:760px}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line-soft)}.modal-head h3{font-family:var(--font-display);font-size:18px;font-weight:600}.modal-x{background:transparent;border:none;color:var(--text-faint);font-size:16px}.modal-x:hover{color:var(--text)}.modal-body{padding:22px}.modal-foot{padding:16px 22px;border-top:1px solid var(--line-soft);display:flex}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-grid .input,.form-grid .select{width:100%;min-width:0}.btn.small{padding:5px 11px;font-size:12px}.btn.ghost.danger{color:var(--red);border-color:#e06b5e66}.btn.ghost.danger:hover{background:#e06b5e1a}@media(max-width:640px){.form-grid{grid-template-columns:1fr}}.specs{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px 24px;margin-top:16px;padding-top:14px;border-top:1px solid var(--line-soft)}.specs>div{display:flex;flex-direction:column;gap:2px}.spec-k{font-size:10.5px;letter-spacing:1px;text-transform:uppercase;color:var(--text-faint)}.spec-v{font-size:13.5px}.sched-overdue{border-left:3px solid var(--red)}.sched-soon{border-left:3px solid var(--amber)}.sched-up{border-left:3px solid var(--green)}.due-tag{display:inline-block;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.3px}.due-tag.overdue{background:#e06b5e29;color:var(--red)}.due-tag.due-soon{background:#e0a52e29;color:var(--amber)}.due-tag.upcoming{background:#46b97a29;color:var(--green)}.badge.freq-weekly{background:#5b9bd529;color:#8fc0f0}.badge.freq-monthly{background:#00b0f029;color:#4cb8e8}.badge.freq-quarterly{background:#e0a52e29;color:var(--amber)}.badge.freq-semi_annual{background:#46b97a29;color:var(--green)}.badge.freq-annual{background:#966ec82e;color:#b88fe0}.card.chart-alert{border-color:#e06b5e80}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.cal-head{font-size:10.5px;letter-spacing:1px;text-transform:uppercase;color:var(--text-faint);text-align:center;padding:6px 0}.cal-cell{min-height:96px;background:var(--card-bg, rgba(22,41,74,.4));border:1px solid var(--line-soft);border-radius:8px;padding:5px;overflow:hidden}:root:not([data-theme]) .cal-cell,:root[data-theme=dark] .cal-cell{background:#16294a66}:root[data-theme=light] .cal-cell{background:#fff}.cal-cell.empty-cell{background:transparent;border-color:transparent}.cal-cell.today{border-color:var(--gold)}.cal-day{font-size:11px;color:var(--text-dim);margin-bottom:4px;font-family:var(--font-mono)}.cal-pill{font-size:9.5px;padding:2px 5px;border-radius:4px;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-pill.freq-weekly{background:#5b9bd533;color:#8fc0f0}.cal-pill.freq-monthly{background:#00b0f033;color:#4cb8e8}.cal-pill.freq-quarterly{background:#e0a52e33;color:var(--amber)}.cal-pill.freq-semi_annual{background:#46b97a33;color:var(--green)}.cal-pill.freq-annual{background:#966ec838;color:#b88fe0}.cal-pill.wo{background:var(--line-soft);color:var(--text-dim)}.cal-pill.wo.completed{background:#46b97a26;color:var(--green)}@media(max-width:860px){.cal-cell{min-height:64px}.cal-pill{font-size:8.5px}}
