*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--forge-navy: #171C2E;--forge-indigo: #6E8C78;--forge-indigo-light: #EEF2EE;--forge-indigo-mid: rgba(110,140,120,.25);--forge-sage: #7FA98C;--forge-sage-light: #ECFDF5;--forge-sage-dark: #065F46;--forge-amber: #C9A55C;--forge-amber-light: #FFFBEB;--forge-amber-dark: #92400E;--forge-red: #B07A6E;--forge-red-light: #FEF2F2;--forge-red-dark: #991B1B;--forge-slate: #64748B;--forge-border: rgba(15,22,41,.1);--forge-bg: #F7F6F2;--forge-surface: #FFFFFF;--forge-text: #171C2E;--forge-muted: #64748B;--sidebar-w: 220px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px}html,body,#root{height:100%;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;color:var(--forge-text);background:var(--forge-bg);-webkit-font-smoothing:antialiased}.sr-only{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius-md);font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;border:none;transition:all .15s;text-decoration:none;white-space:nowrap}.btn-primary{background:var(--forge-indigo);color:#fff}.btn-primary:hover{background:#5a7463}.btn-ghost{background:transparent;color:var(--forge-text);border:1px solid var(--forge-border)}.btn-ghost:hover{background:var(--forge-bg)}.btn-danger{background:var(--forge-red-light);color:var(--forge-red-dark);border:1px solid #FCA5A5}.btn-danger:hover{background:#fee2e2}.btn-success{background:var(--forge-sage-light);color:var(--forge-sage-dark);border:1px solid #A7F3D0}.btn-success:hover{background:#d1fae5}.btn-sm{padding:4px 10px;font-size:12px}.btn-icon{padding:7px;border-radius:var(--radius-md)}.btn:disabled{opacity:.5;cursor:not-allowed}.card{background:var(--forge-surface);border:1px solid var(--forge-border);border-radius:var(--radius-lg);padding:18px 20px}.card-title{font-size:13px;font-weight:600;color:var(--forge-text);margin-bottom:14px;display:flex;align-items:center;justify-content:space-between}.badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:500}.badge-pending{background:var(--forge-amber-light);color:var(--forge-amber-dark)}.badge-approved{background:var(--forge-sage-light);color:var(--forge-sage-dark)}.badge-declined{background:var(--forge-red-light);color:var(--forge-red-dark)}.form-group{margin-bottom:16px}.form-label{display:block;font-size:12px;font-weight:500;color:var(--forge-text);margin-bottom:6px}.form-hint{font-size:11px;color:var(--forge-muted);margin-top:4px}.form-control{width:100%;padding:8px 12px;border:1px solid var(--forge-border);border-radius:var(--radius-md);font-family:inherit;font-size:13px;color:var(--forge-text);background:#fff;outline:none;transition:border .15s,box-shadow .15s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-control:focus{border-color:var(--forge-indigo);box-shadow:0 0 0 3px #6e8c782e}textarea.form-control{resize:vertical;min-height:80px}select.form-control{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}.stat-card{background:var(--forge-surface);border:1px solid var(--forge-border);border-radius:var(--radius-lg);padding:16px 18px}.stat-label{font-size:11px;color:var(--forge-muted);font-weight:400;margin-bottom:6px;letter-spacing:.2px}.stat-value{font-size:26px;font-weight:600;color:var(--forge-text);letter-spacing:-.5px;line-height:1}.stat-sub{font-size:11px;color:var(--forge-muted);margin-top:4px}.stat-accent{width:3px;height:32px;border-radius:2px;float:right;margin-left:12px}.accent-indigo{background:var(--forge-indigo)}.accent-sage{background:var(--forge-sage)}.accent-amber{background:var(--forge-amber)}.accent-red{background:var(--forge-red)}.toast-container{position:fixed;bottom:20px;right:20px;z-index:1000;display:flex;flex-direction:column;gap:8px}.toast{background:var(--forge-navy);color:#fff;padding:12px 18px;border-radius:var(--radius-lg);font-size:13px;font-weight:500;display:flex;align-items:center;gap:10px;max-width:340px;animation:toastIn .25s ease}.toast-icon{color:var(--forge-sage);font-size:16px}.toast-error .toast-icon{color:var(--forge-red)}@keyframes toastIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f162973;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.modal{background:#fff;border-radius:var(--radius-xl);padding:28px;width:100%;max-width:460px;max-height:90vh;overflow-y:auto}.modal-title{font-size:17px;font-weight:600;margin-bottom:4px}.modal-sub{font-size:13px;color:var(--forge-muted);margin-bottom:22px;line-height:1.5}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px;padding-top:18px;border-top:1px solid var(--forge-border)}.info-banner{background:var(--forge-indigo-light);border-radius:var(--radius-md);padding:10px 12px;font-size:12px;color:#5a7463;display:flex;align-items:flex-start;gap:8px}.empty-state{text-align:center;padding:48px 20px;color:var(--forge-muted)}.empty-state i{font-size:36px;margin-bottom:12px;display:block;opacity:.5}.empty-state p{font-size:13px}.heatmap-wrap{overflow-x:auto}.heatmap-grid{display:grid;gap:3px}.heatmap-header-row,.heatmap-row{display:flex;align-items:center;gap:3px}.heatmap-name{font-size:11px;color:var(--forge-muted);width:80px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.heatmap-day-label{font-size:9px;color:var(--forge-muted);width:18px;text-align:center;flex-shrink:0}.heatmap-cell{width:18px;height:18px;border-radius:3px;background:var(--forge-bg);flex-shrink:0;border:1px solid rgba(0,0,0,.04)}.heatmap-cell.off{background:var(--forge-indigo);opacity:.85}.heatmap-cell.pending{background:var(--forge-amber);opacity:.75}.heatmap-cell.today{box-shadow:0 0 0 2px var(--forge-indigo)}.data-table{width:100%;border-collapse:collapse;font-size:12px}.data-table th{text-align:left;padding:6px 8px;color:var(--forge-muted);font-weight:500;border-bottom:1px solid var(--forge-border)}.data-table td{padding:8px;border-bottom:1px solid var(--forge-border)}.data-table tr:last-child td{border-bottom:none}@media (max-width: 768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.sidebar{display:none}.main-layout{padding-left:0}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.app-shell{display:flex;min-height:100vh}.main-layout{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-width:0}.page-topbar{background:var(--forge-surface);border-bottom:1px solid var(--forge-border);padding:14px 24px;display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:10}.page-title{font-size:15px;font-weight:600;flex:1}.page-content{padding:24px;flex:1}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-title{font-size:15px;font-weight:600}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.sidebar{width:var(--sidebar-w);background:var(--forge-navy);display:flex;flex-direction:column;min-height:100vh;position:fixed;top:0;left:0;z-index:50}.sidebar-logo{padding:20px 20px 16px;border-bottom:1px solid rgba(255,255,255,.08)}.logo-mark{display:flex;align-items:center;gap:10px}.logo-icon{width:32px;height:32px;background:var(--forge-indigo);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:700;flex-shrink:0}.logo-name{color:#fff;font-weight:600;font-size:15px;letter-spacing:-.3px}.logo-sub{color:#ffffff59;font-size:10px;letter-spacing:.8px;text-transform:uppercase;margin-top:1px}.user-pill{margin:12px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:10px 12px;display:flex;align-items:center;gap:10px;cursor:default}.avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.avatar-initials{background:var(--forge-indigo);color:#fff;font-size:11px;font-weight:600}.user-info{flex:1;min-width:0}.user-name{color:#fff;font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{color:#fff6;font-size:10px;margin-top:1px}.online-dot{width:6px;height:6px;background:var(--forge-sage);border-radius:50%;flex-shrink:0}.sidebar-nav{padding:8px 12px;flex:1;overflow-y:auto}.nav-section{margin-bottom:20px}.nav-label{color:#ffffff4d;font-size:10px;letter-spacing:.8px;text-transform:uppercase;padding:0 8px;margin-bottom:4px}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;color:#ffffff8c;font-size:13px;font-weight:400;cursor:pointer;transition:all .15s;margin-bottom:2px;text-decoration:none}.nav-item:hover{background:#ffffff12;color:#ffffffd9}.nav-item--active{background:var(--forge-indigo-mid);color:#fff}.nav-item i{font-size:16px}.nav-badge{margin-left:auto;background:var(--forge-amber);color:#fff;font-size:10px;font-weight:600;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}.sidebar-footer{padding:12px;border-top:1px solid rgba(255,255,255,.08)}.balance-card{background:#6e8c782e;border:1px solid rgba(110,140,120,.3);border-radius:10px;padding:12px;margin-bottom:8px}.balance-label{color:#ffffff73;font-size:10px;letter-spacing:.6px;text-transform:uppercase;margin-bottom:6px}.balance-days{color:#fff;font-size:22px;font-weight:600;letter-spacing:-.5px;line-height:1}.balance-unit{font-size:13px;font-weight:400;opacity:.55}.balance-sub{color:#ffffff59;font-size:11px;margin-top:2px}.balance-bar-bg{background:#ffffff1a;border-radius:4px;height:4px;margin-top:8px}.balance-bar-fill{background:var(--forge-indigo);border-radius:4px;height:4px;transition:width .4s}.signout-btn{width:100%;color:#fff6;border-color:#ffffff1a;font-size:12px;justify-content:center}.signout-btn:hover{background:#ffffff12;color:#ffffffb3;border-color:#ffffff26}.signin-screen{min-height:100vh;background:var(--forge-bg);display:flex;align-items:center;justify-content:center;padding:20px}.signin-card{background:var(--forge-surface);border:1px solid var(--forge-border);border-radius:var(--radius-xl);padding:40px;width:100%;max-width:380px;text-align:center}.signin-title{font-size:22px;font-weight:600;letter-spacing:-.4px;margin-bottom:8px}.signin-sub{font-size:13px;color:var(--forge-muted);line-height:1.6;margin-bottom:28px}.btn-google{width:100%;padding:11px 16px;background:#fff;border:1px solid #dadce0;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;gap:10px;font-size:14px;font-weight:500;font-family:inherit;color:#3c4043;cursor:pointer;transition:background .15s;margin-bottom:20px}.btn-google:hover{background:#f8f9fa}.signin-legal{font-size:11px;color:var(--forge-muted);line-height:1.6}.portal-section{padding:24px 28px;border-bottom:1px solid var(--forge-border);scroll-margin-top:16px}.booking-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}.booking-card{background:var(--forge-surface);border:1px solid var(--forge-border);border-radius:var(--radius-lg);padding:14px 16px;text-align:left;cursor:pointer;font-family:inherit;display:flex;flex-direction:column;transition:border-color .15s,background .15s;color:var(--forge-text)}.booking-card:hover{border-color:var(--forge-indigo);background:var(--forge-indigo-light)}.booking-card i{font-size:19px;color:var(--forge-indigo);margin-bottom:8px}.booking-card-label{font-size:13px;font-weight:500;margin-bottom:3px}.booking-card-hint{font-size:11px;color:var(--forge-muted);line-height:1.5}.chip-stat{background:var(--forge-surface);border:1px solid var(--forge-border);border-radius:var(--radius-md);padding:8px 14px;font-size:12px;color:var(--forge-muted);display:flex;align-items:center;gap:8px}.chip-stat strong{font-size:14px;color:var(--forge-text);font-weight:600}.reason-quote{font-size:12px;color:var(--forge-slate);background:var(--forge-bg);border-radius:var(--radius-sm);padding:8px 10px;margin-bottom:10px;font-style:italic}
