:root{color-scheme:dark;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(180deg,#08101d,#0b1424);color:#e2e8f0;--page-max-width: 1680px;--surface-card: #101a2b;--surface-subtle: #162338;--surface-input: #0e1727;--text-primary: #e2e8f0;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--card-border: #253754;--line-border: #2a3b59;--line-strong: #3f567c;--card-shadow: 0 16px 34px rgba(2, 6, 23, .45);--accent: #3b82f6;--accent-contrast: #eff6ff;--badge-open-bg: #1d4ed8;--badge-open-text: #dbeafe;--badge-closed-bg: #78350f;--badge-closed-text: #fde68a;--badge-approved-bg: #166534;--badge-approved-text: #dcfce7;--badge-archived-bg: #334155;--badge-archived-text: #cbd5e1;--alert-border: #be123c;--alert-bg: rgba(190, 18, 60, .22);--alert-text: #fecdd3}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:inherit;color:var(--text-primary)}#root{min-height:100vh}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-main{flex:1}.app-main.app-main-centered{display:grid}.smoke-notice-page{min-height:100vh;font-family:Verdana,Segoe UI,Arial,sans-serif;background:#0f172a;padding:20px 12px;display:flex;justify-content:center}.smoke-notice-page__content{width:min(100%,980px);display:grid;gap:16px;grid-template-columns:repeat(2,minmax(0,1fr));align-items:start;padding-bottom:16px}.smoke-notice-page__brand{grid-column:1 / -1;display:flex;align-items:center;gap:14px;background:linear-gradient(180deg,#fff,#f8fafc);border:2px solid #cbd5e1;border-radius:10px;padding:14px 18px}.smoke-notice-page__brand-logo{width:128px;height:auto;display:block;flex:0 0 auto;object-fit:contain}.smoke-notice-page__brand-text{min-width:0;display:grid;gap:2px}.smoke-notice-page__brand-name{margin:0;color:#0b1b34;font-size:clamp(20px,2.8vw,28px);line-height:1.2;font-weight:800}.smoke-notice-page__brand-tagline{margin:0;color:#334155;font-size:clamp(14px,1.8vw,17px);line-height:1.3;font-weight:600}.smoke-notice-page__panel{width:100%;display:grid;gap:12px;background:#fff;color:#0f172a;border:2px solid #cbd5e1;border-radius:10px;padding:18px}.smoke-notice-page__banner{margin:0;font-size:clamp(32px,4.4vw,44px);line-height:1;font-weight:800;letter-spacing:.05em;color:#0b1b34;text-align:center}.smoke-notice-page__title{margin:0;font-size:clamp(28px,3.6vw,36px);line-height:1.1;font-weight:800;color:#0b1b34;text-align:center}.smoke-notice-page__text{margin:0;font-size:clamp(16px,2.1vw,20px);line-height:1.45;color:#1e293b}.smoke-notice-page__label,.smoke-notice-page__important{margin:0;font-size:clamp(18px,2.4vw,22px);line-height:1.3;font-weight:700;color:#0b1b34}.smoke-notice-page__date-line{margin:0;color:#334155;font-size:clamp(16px,2.2vw,19px);letter-spacing:.06em;text-align:center}.smoke-notice-page__list,.smoke-notice-page__steps{margin:0;padding-left:22px;display:grid;gap:4px;color:#1e293b;font-size:clamp(16px,2.1vw,20px);line-height:1.4}.smoke-notice-page__serious{color:#9f1239;font-weight:700}.smoke-notice-page__danger{color:#b91c1c;font-weight:800}.smoke-notice-page__alert-box{border:2px solid #fca5a5;border-left-width:8px;border-radius:10px;background:#fff1f2;padding:12px 14px}.smoke-notice-page__alert-text{color:#7f1d1d;font-weight:600}.smoke-notice-page__important-box{border:2px solid #fecaca;border-left-width:8px;border-radius:10px;background:#fff7ed;padding:12px 14px;display:grid;gap:8px}.smoke-notice-page__important-box .smoke-notice-page__important{color:#9a3412;letter-spacing:.02em}.smoke-notice-page__important-text{color:#7c2d12;font-weight:600}.smoke-notice-page__danger-step{color:#991b1b;font-weight:700}button,input,select,textarea{font:inherit}.container{max-width:var(--page-max-width);margin:0 auto;padding:24px clamp(14px,2vw,28px)}.site-footer-wrap{display:flex;justify-content:center;padding-top:10px;padding-bottom:18px}.site-footer{width:min(100%,760px);margin:0 auto;border:0;border-radius:0;background:transparent;box-shadow:none;padding:8px 0;display:grid;gap:8px;text-align:center;justify-items:center}.site-footer__meta{display:grid;gap:4px;justify-items:center;text-align:center;width:100%;color:var(--text-secondary);font-size:13px;line-height:1.5}.site-footer__copyright{display:inline-flex;align-items:center;justify-content:center;gap:6px}.site-footer__copyright-mark{font-weight:700}.brand-logo{display:block;width:170px;max-width:100%;height:auto;object-fit:contain}.login-brand{display:grid;place-items:center;margin-bottom:2px}.login-brand .brand-logo{width:min(200px,100%)}.dashboard-brand{display:flex;align-items:center;gap:14px;min-width:0}.dashboard-brand .brand-logo{width:138px;flex:0 0 auto}.dashboard-brand__text{min-width:0}.dashboard-brand__text .muted{margin-top:4px}.card{background:var(--surface-card);border-radius:14px;border:1px solid var(--card-border);padding:18px;box-shadow:var(--card-shadow)}.grid{display:grid;gap:12px}.grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid.cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch}.grid.cols-2>.card{height:100%}.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.admin-split{grid-template-columns:minmax(320px,460px) minmax(0,1fr);align-items:stretch}.grid.admin-split>*{min-width:0}.grid.admin-split>.card{height:100%}.row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.tab-row{display:flex;gap:10px;flex-wrap:wrap}.tab{border:1px solid var(--line-strong);background:var(--surface-card);color:var(--text-primary);border-radius:8px;padding:8px 12px;cursor:pointer;font-weight:600}.tab.active{border-color:var(--accent);background:var(--accent);color:var(--accent-contrast)}.primary{border:1px solid var(--accent);background:var(--accent);color:var(--accent-contrast);border-radius:8px;padding:8px 12px;cursor:pointer;font-weight:600}.secondary{border:1px solid var(--accent);background:#3b82f614;color:#bfdbfe;border-radius:8px;padding:8px 12px;cursor:pointer;font-weight:600}.primary:disabled,.secondary:disabled{opacity:.55;cursor:not-allowed}.table-wrap{width:100%;overflow-x:auto}.table-wrap.table-scroll-y{max-height:min(68vh,760px);overflow-y:auto;border:1px solid var(--line-border);border-radius:10px}.table{width:100%;table-layout:fixed;border-collapse:collapse}.table.sticky-head{min-width:1080px;table-layout:auto}.table th,.table td{text-align:left;padding:9px 8px;border-bottom:1px solid var(--line-border);font-size:12.5px;vertical-align:top;white-space:normal;overflow-wrap:anywhere;word-break:break-word}.table th{color:var(--text-secondary);font-weight:700;line-height:1.2}.table.sticky-head thead th{position:sticky;top:0;z-index:2;background:var(--surface-subtle);box-shadow:inset 0 -1px 0 var(--line-strong)}.table.compact th,.table.compact td{padding:4px 5px;font-size:11px;line-height:1.15}.table.compact .badge{font-size:10px;padding:1px 8px}.table.compact input,.table.compact select,.table.compact textarea{font-size:11px;padding:5px 6px;line-height:1.2}.table.compact textarea{min-height:44px}.table.compact .secondary,.table.compact .primary{font-size:11px;padding:5px 8px}.table.compact .action-stack{display:flex;flex-wrap:wrap;align-items:center;gap:4px}.table.compact .action-stack button{white-space:nowrap}.table.compact .col-user{min-width:120px}.table.compact .col-job{min-width:130px}.table.compact .col-date{min-width:138px}.table.compact .col-description{min-width:190px}.table.compact .col-money{min-width:88px}.table.compact .col-qty,.table.compact .col-receipts{min-width:62px}.table.compact .col-status{min-width:94px}.table.compact .col-entry-state{min-width:96px}.table.compact .col-auto{min-width:84px}.table.compact .col-correction{min-width:300px}.table.compact .col-reason{min-width:210px}.table.compact .col-action{min-width:150px}.table.compact .col-error{min-width:220px}.table.compact .col-payload{min-width:230px}.table.compact .col-collection{min-width:112px}.table.compact .col-id{min-width:172px}.col-user{min-width:140px}.col-job{min-width:150px}.col-name{min-width:140px}.col-email{min-width:220px}.col-workorder{min-width:120px}.col-role{min-width:90px}.col-date{min-width:156px;white-space:nowrap}.col-description{min-width:220px}.col-money{min-width:104px;white-space:nowrap}.col-qty,.col-receipts{min-width:78px;white-space:nowrap}.col-status{min-width:110px;white-space:nowrap}.col-entry-state{min-width:112px;white-space:nowrap}.col-auto{min-width:96px;white-space:nowrap}.col-correction{min-width:320px}.col-reason{min-width:240px}.col-action{min-width:170px}.col-password-reset{min-width:260px}.table.table-users{table-layout:fixed}.table.table-users .col-name,.table.table-users .col-email,.table.table-users .col-role,.table.table-users .col-money,.table.table-users .col-status,.table.table-users .col-password-reset,.table.table-users .col-action{min-width:0}.table.table-users .col-name{width:14%}.table.table-users .col-email{width:22%}.table.table-users .col-role{width:8%}.table.table-users .col-money{width:11%}.table.table-users .col-status{width:9%}.table.table-users .col-password-reset{width:23%}.table.table-users .col-action{width:13%}.table.table-users .col-password-reset .action-stack{grid-template-columns:1fr;gap:4px}.table.table-users .col-password-reset input,.table.table-users .col-password-reset .secondary,.table.table-users .col-action .secondary{width:100%;min-width:0}.table.table-users .col-action .secondary{white-space:normal;padding-left:8px;padding-right:8px}.table.table-assignments{table-layout:fixed}.table.table-assignments .col-user,.table.table-assignments .col-job,.table.table-assignments .col-date,.table.table-assignments .col-qty,.table.table-assignments .col-status,.table.table-assignments .col-entry-state,.table.table-assignments .col-description,.table.table-assignments .col-action{min-width:0}.table.table-assignments .col-user,.table.table-assignments .col-job{width:15%}.table.table-assignments .col-date{width:14%}.table.table-assignments .col-qty{width:8%}.table.table-assignments .col-status{width:9%}.table.table-assignments .col-entry-state{width:11%}.table.table-assignments .col-description{width:16%}.table.table-assignments .col-action{width:12%}.col-error{min-width:260px}.col-payload{min-width:280px}.col-collection{min-width:130px}.col-id{min-width:200px}.field{display:grid;gap:6px}.field label{font-size:12px;color:var(--text-secondary);font-weight:600}.field input,.field select,.field textarea{border:1px solid var(--line-strong);border-radius:8px;padding:8px;background:var(--surface-input);color:var(--text-primary);width:100%}.cell-correction{width:320px;min-width:320px}.correction-grid{display:grid;gap:6px}.correction-grid input{width:100%;min-width:0}.correction-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr))}.cell-reason{width:240px;min-width:240px}.cell-prewrap{white-space:pre-wrap}.action-stack{display:grid;gap:6px}.table-tools{display:flex;flex-wrap:wrap;gap:10px 16px;align-items:center;justify-content:space-between}.toggle-group{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.check-inline{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary)}.check-inline input{margin:0}.badge{display:inline-flex;border-radius:999px;padding:2px 10px;font-size:12px;font-weight:700}.badge.open{background:var(--badge-open-bg);color:var(--badge-open-text)}.badge.closed{background:var(--badge-closed-bg);color:var(--badge-closed-text)}.badge.approved{background:var(--badge-approved-bg);color:var(--badge-approved-text)}.badge.archived{background:var(--badge-archived-bg);color:var(--badge-archived-text)}.badge.pending{background:#312e81;color:#c7d2fe}.badge.rejected{background:#7f1d1d;color:#fecaca}.tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:999px;background:#fbbf24;color:#1c1917;font-size:10px;font-weight:800;padding:0 5px;margin-left:6px;line-height:1}.alert{border:1px solid var(--alert-border);background:var(--alert-bg);color:var(--alert-text);border-radius:8px;padding:10px;margin-top:10px}.muted{color:var(--text-muted);font-size:13px}h1,h2,h3,h4,h5{margin:0}@media(max-width:1180px){.grid.cols-5,.grid.cols-4,.grid.cols-3{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.cols-2,.admin-split{grid-template-columns:1fr}.dashboard-brand{gap:10px}.dashboard-brand .brand-logo{width:118px}.table-wrap.table-scroll-y{max-height:none;border:0;border-radius:0}.table.sticky-head{min-width:920px}}@media(max-width:820px),(orientation:landscape)and (max-height:430px){.grid.cols-4,.grid.cols-3,.grid.cols-2,.admin-split{grid-template-columns:1fr}.container{padding:14px 12px}.site-footer-wrap{padding-top:8px;padding-bottom:12px}.card{padding:14px}.table,.table.sticky-head{min-width:680px}.table th,.table td{font-size:11.5px;padding:6px}.tab{padding:6px 10px;font-size:12px}.smoke-notice-page{padding:12px 10px}.smoke-notice-page__content{grid-template-columns:1fr;gap:12px}.smoke-notice-page__brand{padding:12px;gap:10px;border-radius:8px}.smoke-notice-page__brand-logo{width:96px}.smoke-notice-page__panel{padding:12px;border-radius:8px}.smoke-notice-page__alert-box,.smoke-notice-page__important-box{border-radius:8px;padding:10px 12px}.smoke-notice-page__alert-box,.smoke-notice-page__important-box,.smoke-notice-page__list,.smoke-notice-page__steps{gap:6px}}body.mobile-site{-webkit-text-size-adjust:100%;text-size-adjust:100%;touch-action:manipulation}body.mobile-site .grid.cols-4,body.mobile-site .grid.cols-3,body.mobile-site .grid.cols-2,body.mobile-site .admin-split{grid-template-columns:1fr}body.mobile-site .container{padding:14px 12px}body.mobile-site .card{padding:14px}body.mobile-site .login-brand .brand-logo{width:min(180px,100%)}body.mobile-site .dashboard-brand{align-items:flex-start}body.mobile-site .dashboard-brand .brand-logo{width:108px}body.mobile-site .tab-row{flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;padding-bottom:2px}body.mobile-site .tab{flex:0 0 auto;white-space:nowrap}body.mobile-site .table-wrap{-webkit-overflow-scrolling:touch}body.mobile-site .table-wrap.table-scroll-y{max-height:none;border:0;border-radius:0}body.mobile-site .table{min-width:760px;table-layout:auto}body.mobile-site .table.table-overview-shifts{min-width:860px}body.mobile-site .table.table-overview-materials,body.mobile-site .table.table-jobs{min-width:960px}body.mobile-site .table.table-assignments{min-width:1280px}body.mobile-site .table.table-users{min-width:1260px}body.mobile-site .table.table-shifts{min-width:1620px}body.mobile-site .table.table-materials,body.mobile-site .table.table-conflicts{min-width:1520px}body.mobile-site .table.table-audit{min-width:960px}body.mobile-site .table.compact.table-shifts{min-width:1320px}body.mobile-site .table.compact.table-materials,body.mobile-site .table.compact.table-conflicts{min-width:1240px}body.mobile-site .table.compact.table-audit{min-width:820px}body[data-device=mobile][data-orientation=portrait] .table th,body[data-device=mobile][data-orientation=portrait] .table td{font-size:11.5px;padding:6px}body[data-device=mobile][data-orientation=landscape] .table th,body[data-device=mobile][data-orientation=landscape] .table td{font-size:12px;padding:7px}body[data-device=mobile][data-orientation=landscape] .table.table-shifts{min-width:1500px}body[data-device=mobile][data-orientation=landscape] .table.table-materials,body[data-device=mobile][data-orientation=landscape] .table.table-conflicts{min-width:1420px}body[data-device=mobile][data-orientation=landscape] .table.compact.table-shifts{min-width:1260px}body[data-device=mobile][data-orientation=landscape] .table.compact.table-materials,body[data-device=mobile][data-orientation=landscape] .table.compact.table-conflicts{min-width:1180px}body[data-device=mobile][data-orientation=landscape] .container{padding-left:10px;padding-right:10px}body[data-device=mobile] .table.compact th,body[data-device=mobile] .table.compact td,body[data-device=mobile] .table.compact input,body[data-device=mobile] .table.compact select,body[data-device=mobile] .table.compact textarea{font-size:10.5px;padding:4px 5px}
