:root{--asset-rev: 2;--navy: #0f2a5e;--navy-dark: #0a1e47;--navy-light: #1a3d7a;--orange: #f57c00;--orange-light: #ff9800;--orange-dark: #e65100;--white: #ffffff;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-500: #6b7280;--gray-700: #374151;--gray-900: #111827;--green: #16a34a;--green-light: #dcfce7;--red: #dc2626;--red-light: #fee2e2;--yellow: #ca8a04;--yellow-light: #fef9c3;--radius: 12px;--radius-sm: 8px;--shadow: 0 1px 3px rgba(0,0,0,.12), 0 1px 2px rgba(0,0,0,.08);--shadow-md: 0 4px 6px rgba(0,0,0,.1), 0 2px 4px rgba(0,0,0,.06);--shadow-lg: 0 10px 25px rgba(0,0,0,.15);--bottom-nav-height: 64px;--top-bar-height: 56px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;color:var(--gray-900);background:var(--gray-50);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%;max-width:480px;margin:0 auto;background:var(--white);position:relative;overflow:hidden;display:flex;flex-direction:column}.page-content{flex:1;overflow-y:auto;padding:16px;padding-bottom:calc(var(--bottom-nav-height) + 16px)}.page-content-notab{flex:1;overflow-y:auto;padding:16px}h1{font-size:1.5rem;font-weight:700;line-height:1.3}h2{font-size:1.25rem;font-weight:600}h3{font-size:1.1rem;font-weight:600}p{line-height:1.6}.card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;margin-bottom:12px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:var(--radius-sm);font-family:inherit;font-size:.95rem;font-weight:600;cursor:pointer;border:none;transition:opacity .15s,transform .1s;text-decoration:none}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--navy);color:var(--white)}.btn-secondary{background:var(--orange);color:var(--white)}.btn-outline{background:transparent;color:var(--navy);border:2px solid var(--navy)}.btn-danger{background:var(--red);color:var(--white)}.btn-ghost{background:var(--gray-100);color:var(--gray-700)}.btn-full{width:100%}.btn-sm{padding:8px 14px;font-size:.85rem}.input-group{margin-bottom:16px}.input-label{display:block;font-size:.875rem;font-weight:500;color:var(--gray-700);margin-bottom:6px}.input{width:100%;padding:12px 14px;border:1.5px solid var(--gray-300);border-radius:var(--radius-sm);font-family:inherit;font-size:1rem;color:var(--gray-900);background:var(--white);transition:border-color .15s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.input:focus{outline:none;border-color:var(--navy)}.input::placeholder{color:var(--gray-300)}.input-error{border-color:var(--red)!important}.error-text{font-size:.8rem;color:var(--red);margin-top:4px}select.input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%236b7280'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:20px;padding-right:40px}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:100px;font-size:.75rem;font-weight:600}.badge-blue{background:#dbeafe;color:#1d4ed8}.badge-green{background:var(--green-light);color:var(--green)}.badge-red{background:var(--red-light);color:var(--red)}.badge-yellow{background:var(--yellow-light);color:var(--yellow)}.badge-orange{background:#fff7ed;color:var(--orange-dark)}.badge-gray{background:var(--gray-100);color:var(--gray-500)}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:24px;height:24px;border:3px solid var(--gray-200);border-top-color:var(--navy);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.spinner-center{display:flex;justify-content:center;align-items:center;padding:48px}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0}.toggle{position:relative;display:inline-block;width:44px;height:26px}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;right:0;bottom:0;left:0;background:var(--gray-300);border-radius:26px;transition:.2s}.toggle-slider:before{content:"";position:absolute;width:20px;height:20px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s}.toggle input:checked+.toggle-slider{background:var(--navy)}.toggle input:checked+.toggle-slider:before{transform:translate(18px)}.divider{height:1px;background:var(--gray-200);margin:16px 0}.section-title{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);margin-bottom:8px}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px}.status-dot.active{background:var(--green)}.status-dot.trial{background:var(--orange)}.status-dot.past_due{background:var(--red)}.status-dot.cancelled{background:var(--gray-300)}.toast-container{position:fixed;top:16px;left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:8px;width:calc(100% - 32px);max-width:448px}.toast{padding:12px 16px;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;box-shadow:var(--shadow-md);animation:slideDown .25s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.toast-success{background:var(--green);color:#fff}.toast-error{background:var(--red);color:#fff}.toast-info{background:var(--navy);color:#fff}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;display:flex;align-items:flex-end}.modal-sheet{background:var(--white);border-radius:20px 20px 0 0;padding:24px 20px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .25s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-handle{width:40px;height:4px;background:var(--gray-300);border-radius:2px;margin:0 auto 20px}.empty-state{text-align:center;padding:48px 24px;color:var(--gray-500)}.empty-state-icon{font-size:3rem;margin-bottom:12px}.empty-state h3{color:var(--gray-700);margin-bottom:8px}.att-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.att-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;border:1.5px solid transparent;transition:transform .1s;-webkit-user-select:none;user-select:none}.att-cell:active{transform:scale(.9)}.att-cell.P{background:var(--green-light);color:var(--green);border-color:var(--green)}.att-cell.A{background:var(--red-light);color:var(--red);border-color:var(--red)}.att-cell.H{background:#dbeafe;color:#1d4ed8;border-color:#93c5fd}.att-cell.L{background:var(--yellow-light);color:var(--yellow);border-color:#fde047}.att-cell.empty{background:var(--gray-100);cursor:default}.att-cell.today{box-shadow:0 0 0 2px var(--orange)}.plan-gate{background:var(--white);border:2px dashed var(--orange);border-radius:var(--radius);padding:24px;text-align:center;margin:12px 0}.plan-gate h3{color:var(--navy);margin-bottom:8px}.plan-gate p{color:var(--gray-500);font-size:.875rem;margin-bottom:16px}.pricing-grid{display:grid;gap:12px}.pricing-card{border:2px solid var(--gray-200);border-radius:var(--radius);padding:20px;cursor:pointer;transition:border-color .15s,box-shadow .15s}.pricing-card.selected{border-color:var(--orange);box-shadow:0 0 0 3px #f57c0026}.pricing-card .price{font-size:1.75rem;font-weight:700;color:var(--navy)}.pricing-card .price span{font-size:1rem;color:var(--gray-500);font-weight:400}.table-scroll{overflow-x:auto;margin:0 -16px;padding:0 16px}table{width:100%;border-collapse:collapse;font-size:.875rem}th{text-align:left;padding:10px 12px;background:var(--navy);color:#fff;font-weight:600;white-space:nowrap}td{padding:10px 12px;border-bottom:1px solid var(--gray-200)}tr:last-child td{border-bottom:none}tr:nth-child(2n) td{background:var(--gray-50)}tfoot td{font-weight:700;background:#f0f4ff;border-top:2px solid var(--navy)}.auth-page{min-height:100%;display:flex;flex-direction:column;background:var(--navy)}.auth-header{padding:48px 24px 32px;text-align:center;color:#fff}.auth-logo{font-size:2rem;font-weight:700}.auth-logo span{color:var(--orange-light)}.auth-subtitle{color:#ffffffb3;margin-top:4px;font-size:.9rem}.auth-body{flex:1;background:var(--gray-50);border-radius:24px 24px 0 0;padding:28px 24px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--gray-500)}.text-navy{color:var(--navy)}.text-orange{color:var(--orange)}.text-green{color:var(--green)}.text-red{color:var(--red)}.font-bold{font-weight:700}.font-semibold{font-weight:600}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.w-full{width:100%}.rounded{border-radius:var(--radius-sm)}.dash-page{display:flex;flex-direction:column;height:100%}.dash-sidebar{display:none}.dash-topbar-m,.dash-bottomnav-m{display:contents}.dash-main{flex:1;min-height:0;overflow-y:auto;padding:16px 16px calc(var(--bottom-nav-height) + 16px)}.dash-head{margin-bottom:16px}.dash-head h1{font-size:1.4rem;color:var(--navy)}.dash-head .sub{color:var(--gray-500);font-size:.85rem;margin-top:2px}.kpi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}.kpi-tile{position:relative;background:var(--white);border:1px solid var(--gray-200, #e5e7eb);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 16px 16px 18px;overflow:hidden;transition:box-shadow .15s,transform .15s}.kpi-tile:hover{box-shadow:0 6px 18px #0f2a5e1f;transform:translateY(-2px)}.kpi-tile:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--kpi-accent, var(--navy))}.kpi-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:8px}.kpi-icon{flex-shrink:0;width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:1.05rem;box-shadow:inset 0 2px 6px #0000001f}.kpi-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--gray-500);line-height:1.3}.kpi-value{font-size:1.6rem;font-weight:700;color:var(--navy);letter-spacing:-.02em;line-height:1.1}.kpi-sub{font-size:.75rem;margin-top:4px;font-weight:600}.kpi-delta{display:flex;align-items:center;gap:5px;font-size:.74rem;font-weight:600;margin-top:5px}.kpi-delta .kpi-arrow{font-size:.66rem}.kpi-delta.good{color:#16a34a}.kpi-delta.bad{color:#dc2626}.tappable{cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.tappable:focus-visible{outline:2px solid var(--orange);outline-offset:2px}.tappable:active{transform:translateY(0) scale(.985)}.kpi-tile .card-open{position:absolute;right:12px;bottom:10px;font-size:1.3rem;line-height:1;color:var(--gray-300, #cbd5e1);transition:color .15s,transform .15s}.kpi-tile.tappable:hover .card-open{color:var(--orange);transform:translate(3px)}.chart-card .chart-title{display:flex;align-items:center;justify-content:space-between}.chart-open{font-size:.66rem;font-weight:700;letter-spacing:.02em;color:var(--orange);text-transform:none;opacity:.75;transition:opacity .15s,transform .15s}.chart-card.tappable:hover .chart-open{opacity:1;transform:translate(2px)}.chart-grid{display:grid;grid-template-columns:1fr;gap:12px}.chart-card{background:var(--white);border:1px solid var(--gray-200, #e5e7eb);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;display:flex;flex-direction:column}.chart-card .chart-title{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--gray-500);margin-bottom:12px;padding-left:10px;border-left:3px solid var(--orange)}@media(min-width:900px){.dash-page{position:fixed;top:0;right:0;bottom:0;left:0;max-width:none;height:100vh;display:grid;grid-template-columns:232px 1fr;background:var(--gray-100);z-index:50}.dash-topbar-m,.dash-bottomnav-m{display:none}.dash-sidebar{display:flex;flex-direction:column;background:var(--navy);color:#fff;padding:22px 16px}.dash-brand{font-size:1.15rem;font-weight:700;margin-bottom:28px;padding:0 8px}.dash-brand span{color:var(--orange-light)}.dash-navlink{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:8px;color:#ffffffa6;text-decoration:none;font-size:.9rem;font-weight:500;margin-bottom:2px;transition:background .15s,color .15s}.dash-navlink:hover{background:#ffffff12;color:#fff}.dash-navlink.active{background:var(--orange);color:#fff;font-weight:600}.dash-sidebar-foot{margin-top:auto;padding-top:16px;border-top:1px solid rgba(255,255,255,.12)}.dash-sidebar-foot .who{font-size:.8rem;opacity:.8;padding:0 8px 10px}.dash-main{padding:28px 32px 32px}.dash-head h1{font-size:1.7rem}.kpi-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}.kpi-value{font-size:1.9rem}.chart-grid{grid-template-columns:repeat(2,1fr);gap:16px}.chart-span-2{grid-column:span 2}}@media(min-width:1300px){.chart-grid{grid-template-columns:repeat(3,1fr)}.chart-span-2{grid-column:span 2}}.att-table-wrap{overflow-x:auto;margin:0 -16px;padding:0 16px 8px}.att-spread{border-collapse:collapse;font-size:.72rem;min-width:540px}.att-spread th{background:var(--navy);color:#ffffffd9;padding:7px 4px;text-align:center;font-size:.62rem;font-weight:600;position:sticky;top:0;white-space:nowrap}.att-spread th:first-child{text-align:left;padding-left:8px;min-width:96px;position:sticky;left:0;z-index:3;background:var(--navy)}.att-spread th.ot-th{background:#4a1480}.att-spread td{padding:3px 2px;text-align:center;border-bottom:1px solid var(--gray-100);background:#fff}.att-spread td:first-child{text-align:left;padding-left:8px;font-weight:500;font-size:.78rem;position:sticky;left:0;background:#fff;z-index:1;white-space:nowrap;min-width:96px}.att-spread tr:hover td,.att-spread tr:hover td:first-child{background:var(--gray-50)}.att-spread td.weekoff,.att-spread th.weekoff{background:#f3f0ff}.day-cell{width:22px;height:22px;border-radius:50%;border:1px solid var(--gray-300);cursor:pointer;font-size:.58rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;color:var(--gray-500);background:#fff}.day-cell.P{background:var(--green);border-color:var(--green);color:#fff}.day-cell.A{background:var(--red-light);border-color:#ef9a9a;color:var(--red)}.day-cell.H{background:#dbeafe;border-color:#90caf9;color:#1d4ed8}.day-cell.L{background:var(--yellow-light);border-color:#fde047;color:var(--yellow)}.ot-input{width:28px;height:18px;margin-top:2px;border:1px solid #ce93d8;border-radius:4px;font-size:.55rem;text-align:center;font-weight:600;background:#f3e5f5;color:#6a1b9a}.ot-input:focus{outline:none;border-color:#6a1b9a;background:#fff}.att-spread td.total-col{font-weight:700;color:var(--navy);background:#dbeafe}.att-spread td.ot-col{font-weight:700;color:#6a1b9a;background:#f3e5f5}.att-sum-row{display:flex;gap:6px;overflow-x:auto;padding:4px 0 12px}.att-sum-item{flex-shrink:0;background:#fff;border:1px solid var(--gray-200);border-radius:8px;padding:6px 12px;text-align:center;min-width:56px}.att-sum-val{font-size:1.1rem;font-weight:700}.att-sum-lbl{font-size:.62rem;color:var(--gray-500);margin-top:1px}.ci-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);padding:14px;margin-bottom:10px;box-shadow:var(--shadow)}.ci-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}.ci-times{display:flex;gap:8px;margin-bottom:8px}.ci-time-box{flex:1;background:var(--gray-50);border-radius:8px;padding:8px 10px;text-align:center}.ci-time-lbl{font-size:.62rem;color:var(--gray-500);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.ci-time-val{font-size:1rem;font-weight:700;color:var(--navy);margin-top:2px}.ci-time-val.empty{color:var(--gray-300)}.ci-btns{display:flex;gap:8px}.ci-btn{flex:1;border:none;border-radius:8px;padding:10px;font-size:.85rem;font-weight:600;cursor:pointer;font-family:inherit}.ci-in{background:var(--green-light);color:var(--green);border:1px solid #a5d6a7}.ci-out{background:var(--yellow-light);color:var(--yellow);border:1px solid #ffcc80}.ci-loc{margin-top:8px;font-size:.72rem;padding:7px 10px;border-radius:8px;display:flex;align-items:center;gap:6px}.ci-loc.ok{background:var(--green-light);color:var(--green)}.ci-loc.away{background:var(--red-light);color:var(--red)}.ci-loc.none{background:var(--gray-100);color:var(--gray-500)}.ci-worked{font-size:.72rem;color:var(--gray-500);margin-top:6px;text-align:right}.copyright-footer{padding:16px;text-align:center;font-size:.62rem;color:var(--gray-500);line-height:1.6;border-top:1px solid var(--gray-200);margin-top:12px}.copyright-footer strong{color:var(--gray-700)}
