@import"https://fonts.googleapis.com/css2?family=DM+Mono:wght@400;500&family=Syne:wght@400;500;600;700;800&family=Inter:wght@300;400;500&display=swap";:root{--bg: #0d0f12;--bg-2: #13161b;--bg-3: #1a1e25;--border: #2a2f3a;--border-2: #363c4a;--text: #e8eaf0;--text-2: #9aa0b0;--text-3: #5a6070;--accent: #e84f4f;--accent-2: #ff7c5c;--teal: #3ecfcf;--yellow: #f5c842;--green: #52d68a;--purple: #9b7ff8;--font-head: "Syne", sans-serif;--font-body: "Inter", sans-serif;--font-mono: "DM Mono", monospace;--radius: 8px;--radius-lg: 14px;--shadow: 0 2px 16px rgba(0,0,0,.4);--shadow-lg: 0 8px 40px rgba(0,0,0,.5);--bg-primary: #0d0f12;--bg-secondary: #13161b;--bg-card: #16191f;--border-primary: #2a2f3a;--border-secondary: #363c4a;--text-primary: #e8eaf0;--text-secondary: #9aa0b0;--text-tertiary: #5a6070;--tl: #3ecfcf;--gr: #52d68a;--am: #f5c842;--bdr: #2a2f3a;--txt: #e8eaf0;--txt2: #9aa0b0;--txt3: #5a6070;--bg2: #13161b;--bg3: #1a1e25}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-body);background:var(--bg);color:var(--text);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}a{text-decoration:none;color:inherit}button{cursor:pointer;border:none;background:none;font-family:inherit}input:not([type=radio]):not([type=checkbox]),select,textarea{font-family:inherit;font-size:14px;color:var(--text);background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;width:100%;transition:border-color .2s;outline:none}input:focus,select:focus,textarea:focus{border-color:var(--teal)}input::placeholder,textarea::placeholder{color:var(--text-3)}select option{background:var(--bg-3)}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh}.spinner{width:32px;height:32px;border:2px solid var(--border-2);border-top-color:var(--teal);border-radius:50%;animation:spin .6s linear infinite}.page-loading{padding:48px;text-align:center;color:var(--text-2)}@keyframes spin{to{transform:rotate(360deg)}}.app-shell{display:flex;height:100vh;overflow:hidden}.sidebar{display:flex;flex-direction:column;background:var(--bg-2);border-right:1px solid var(--border);transition:width .25s ease;overflow:hidden;flex-shrink:0}.sidebar.open{width:220px}.sidebar.collapsed{width:60px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:20px 14px 16px;border-bottom:1px solid var(--border);min-height:64px}.brand{display:flex;align-items:center;gap:10px}.brand-icon{font-size:22px;color:var(--accent);flex-shrink:0}.brand-name{font-family:var(--font-head);font-size:16px;font-weight:700;white-space:nowrap;letter-spacing:-.3px}.brand-name em{color:var(--teal);font-style:normal}.collapse-btn{color:var(--text-3);font-size:10px;padding:4px;flex-shrink:0}.collapse-btn:hover{color:var(--text)}.sidebar-nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:12px;padding:9px 10px;border-radius:var(--radius);color:var(--text-2);font-size:13.5px;font-weight:500;transition:all .15s;white-space:nowrap}.nav-item:hover{background:var(--bg-3);color:var(--text)}.nav-item.active{background:#3ecfcf1a;color:var(--teal)}.nav-icon{font-size:16px;flex-shrink:0;width:20px;text-align:center}.sidebar-footer{padding:12px 8px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:6px}.user-card{display:flex;align-items:center;gap:10px;padding:8px 6px}.user-avatar{width:32px;height:32px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:700;font-size:14px;color:#000}.user-info{display:flex;flex-direction:column;overflow:hidden}.user-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.logout-btn{display:flex;align-items:center;gap:12px;padding:8px 10px;border-radius:var(--radius);color:var(--text-3);font-size:13px;white-space:nowrap;transition:all .15s}.logout-btn:hover{background:#e84f4f1a;color:var(--accent)}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.topbar{display:flex;align-items:center;justify-content:space-between;padding:0 28px;height:64px;flex-shrink:0;background:var(--bg-2);border-bottom:1px solid var(--border)}.page-greeting{font-family:var(--font-head);font-size:15px;font-weight:400;color:var(--text-2)}.page-greeting strong{color:var(--text);font-weight:600}.topbar-right{display:flex;align-items:center;gap:16px}.date-chip{font-family:var(--font-mono);font-size:12px;color:var(--text-3);background:var(--bg-3);padding:6px 12px;border-radius:20px;border:1px solid var(--border)}.notif-wrapper{position:relative}.notif-btn{position:relative;padding:6px;color:var(--text-2);font-size:18px}.notif-btn:hover{color:var(--text)}.notif-badge{position:absolute;top:2px;right:2px;width:16px;height:16px;border-radius:50%;background:var(--accent);color:#fff;font-size:10px;display:flex;align-items:center;justify-content:center;font-weight:700}.notif-dropdown{position:absolute;right:0;top:calc(100% + 8px);width:300px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:100;overflow:hidden}.notif-header{padding:12px 16px;font-weight:600;font-size:13px;border-bottom:1px solid var(--border)}.notif-empty{padding:24px 16px;text-align:center;color:var(--text-3);font-size:13px}.notif-item{padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}.notif-item:hover{background:var(--bg-3)}.notif-item.unread{border-left:3px solid var(--teal)}.notif-title{display:block;font-weight:600;font-size:13px;margin-bottom:2px}.notif-msg{display:block;font-size:12px;color:var(--text-2)}.page-body{flex:1;overflow-y:auto;padding:28px}.section-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px}.section-header h1,.section-header h3{font-family:var(--font-head);font-weight:700;letter-spacing:-.5px}.section-header h1{font-size:26px}.section-header h3{font-size:17px}.section-sub{display:block;color:var(--text-2);font-size:13px;margin-top:2px}.mt-32{margin-top:32px}.mt-24{margin-top:24px}.mt-8{margin-top:8px}.btn-primary{background:var(--teal);color:#000;font-weight:600;font-size:13px;padding:9px 18px;border-radius:var(--radius);font-family:var(--font-head);transition:opacity .15s,transform .1s;white-space:nowrap}.btn-primary:hover{opacity:.9;transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-secondary{background:var(--bg-3);color:var(--text);font-weight:500;font-size:13px;padding:9px 18px;border-radius:var(--radius);border:1px solid var(--border);transition:background .15s}.btn-secondary:hover{background:var(--border)}.btn-sm{display:inline-block;background:var(--bg-3);color:var(--teal);font-size:12px;font-weight:500;padding:5px 12px;border-radius:var(--radius);border:1px solid var(--border)}.btn-approve{background:#52d68a26;color:var(--green);border:1px solid rgba(82,214,138,.3);padding:8px 18px;border-radius:var(--radius);font-weight:600;font-size:13px;transition:all .15s}.btn-approve:hover{background:#52d68a40}.btn-reject{background:#e84f4f1a;color:var(--accent);border:1px solid rgba(232,79,79,.25);padding:8px 18px;border-radius:var(--radius);font-weight:600;font-size:13px;transition:all .15s}.btn-reject:hover{background:#e84f4f33}.btn-reject:disabled,.btn-approve:disabled{opacity:.4;cursor:not-allowed}.btn-pay{background:#9b7ff826;color:var(--purple);border-color:#9b7ff84d}.btn-pay:hover{background:#9b7ff840}.chip{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;font-family:var(--font-mono);padding:3px 9px;border-radius:20px;letter-spacing:.3px}.chip-in{background:#52d68a1f;color:var(--green)}.chip-out{background:#e84f4f1f;color:var(--accent)}.chip-warn{background:#f5c8421f;color:var(--yellow)}.chip-done{background:#3ecfcf1f;color:var(--teal)}.chip-wfh{background:#9b7ff81f;color:var(--purple)}.chip-grey{background:#5a607033;color:var(--text-3)}.chip-paid{background:#3ecfcf1f;color:var(--teal)}.status-banner{display:flex;align-items:center;gap:16px;padding:14px 20px;border-radius:var(--radius-lg);margin-bottom:24px;border:1px solid var(--border)}.status-banner.status-in{background:#52d68a0f;border-color:#52d68a33}.status-banner.status-out{background:#e84f4f0f;border-color:#e84f4f33}.status-banner.status-done{background:#3ecfcf0f;border-color:#3ecfcf33}.status-indicator{width:10px;height:10px;border-radius:50%;flex-shrink:0}.status-in .status-indicator{background:var(--green);box-shadow:0 0 8px var(--green);animation:pulse 2s infinite}.status-out .status-indicator{background:var(--accent)}.status-done .status-indicator{background:var(--teal)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.status-text{flex:1}.status-text strong{display:block;font-size:14px;font-weight:600;margin-bottom:2px}.status-text span{font-size:12px;color:var(--text-2);font-family:var(--font-mono)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:28px}.stat-card{display:flex;align-items:center;gap:14px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;position:relative;overflow:hidden;transition:border-color .2s,transform .15s}.stat-card:hover{border-color:var(--card-color, var(--border-2));transform:translateY(-2px)}.stat-highlight{border-color:#ffc83c4d!important}.stat-icon{font-size:24px;flex-shrink:0}.stat-label{font-size:11px;text-transform:uppercase;letter-spacing:.7px;color:var(--text-3);font-weight:600;margin-bottom:4px}.stat-value{font-family:var(--font-head);font-size:22px;font-weight:700;line-height:1.1}.stat-sub{font-size:11.5px;color:var(--text-2);margin-top:3px}.stat-accent{position:absolute;top:0;right:0;width:3px;height:100%;background:var(--card-color, transparent);border-radius:0 var(--radius-lg) var(--radius-lg) 0}.quick-actions h3{font-family:var(--font-head);font-size:16px;font-weight:600;margin-bottom:12px}.action-grid{display:flex;flex-wrap:wrap;gap:10px}.action-card{display:flex;align-items:center;gap:8px;background:var(--bg-2);border:1px solid var(--border);padding:10px 16px;border-radius:var(--radius);font-size:13px;font-weight:500;color:var(--text-2);transition:all .15s;position:relative}.action-card:hover{border-color:var(--teal);color:var(--teal)}.action-card.highlight{border-color:#f5c8424d;color:var(--yellow)}.action-icon{font-size:16px}.action-badge{background:var(--accent);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 4px}.clock-widget{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;text-align:center;margin-bottom:32px;max-width:480px}.clock-time{font-family:var(--font-mono);font-size:48px;font-weight:500;color:var(--text);letter-spacing:-1px;margin-bottom:12px}.clock-status{margin-bottom:20px}.clock-actions{display:flex;justify-content:center;gap:12px;margin-bottom:16px}.btn-clock{font-family:var(--font-head);font-size:15px;font-weight:700;padding:12px 32px;border-radius:var(--radius);transition:all .15s}.btn-clock-in{background:var(--green);color:#000}.btn-clock-in:hover{opacity:.9;transform:translateY(-1px)}.btn-clock-out{background:var(--accent);color:#fff}.btn-clock-out:hover{opacity:.9;transform:translateY(-1px)}.btn-clock:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.clock-times{display:flex;justify-content:center;gap:20px;font-size:13px;color:var(--text-2);font-family:var(--font-mono)}.attendance-table{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.att-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;padding:12px 16px;border-bottom:1px solid var(--border);font-size:13px;gap:8px}.att-row:last-child{border-bottom:none}.att-header{background:var(--bg-3);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-3)}.leave-summary{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.filter-pill{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;font-size:12.5px;font-weight:500;background:var(--bg-2);border:1px solid var(--border);color:var(--text-2);transition:all .15s}.filter-pill.active{background:#3ecfcf1a;border-color:var(--teal);color:var(--teal)}.pill-count{background:var(--bg-3);border-radius:10px;padding:0 6px;font-family:var(--font-mono);font-size:11px}.leave-list,.claims-list,.approvals-list{display:flex;flex-direction:column;gap:12px}.leave-card,.claim-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 20px;transition:border-color .15s}.leave-card:hover,.claim-card:hover{border-color:var(--border-2)}.leave-card-header,.claim-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px;gap:12px}.leave-type,.claim-title{font-weight:600;font-size:14px;display:block}.claim-category{display:block;font-size:12px;color:var(--text-2);margin-top:2px}.claim-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.claim-amount{font-family:var(--font-mono);font-size:15px;font-weight:500;color:var(--teal)}.leave-dates{display:flex;align-items:center;gap:8px;font-size:13px;font-family:var(--font-mono)}.date-arrow{color:var(--text-3)}.leave-days{color:var(--text-2)}.leave-reason,.claim-desc{font-size:13px;color:var(--text-2);margin-top:6px}.leave-card-footer,.claim-card-footer{display:flex;gap:16px;margin-top:10px;font-size:12px;color:var(--text-3);align-items:center;flex-wrap:wrap}.receipt-link{color:var(--teal);font-size:12px}.approval-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.approval-header{display:flex;justify-content:space-between;align-items:flex-start;padding:16px 20px 12px;border-bottom:1px solid var(--border);gap:12px}.approval-name{display:block;font-weight:600;font-size:14px}.approval-dept{display:block;font-size:12px;color:var(--text-2);font-family:var(--font-mono);margin-top:2px}.claim-amount-badge{font-family:var(--font-mono);font-size:18px;font-weight:500;color:var(--yellow)}.approval-body{padding:12px 20px;display:flex;flex-direction:column;gap:8px}.approval-detail{display:flex;gap:12px;font-size:13px}.detail-label{color:var(--text-3);min-width:80px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;padding-top:1px}.approval-actions{display:flex;justify-content:flex-end;gap:10px;padding:12px 20px;border-top:1px solid var(--border)}.tab-bar{display:flex;gap:4px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:4px;margin-bottom:20px;width:fit-content}.tab{padding:7px 16px;border-radius:6px;font-size:13px;font-weight:500;color:var(--text-2);transition:all .15s;display:flex;align-items:center;gap:7px}.tab.active{background:var(--bg-3);color:var(--text)}.tab-badge{background:var(--accent);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 4px}.form-page{max-width:680px}.form-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px}.app-form{display:flex;flex-direction:column;gap:18px}.form-row{display:flex;gap:16px}.form-row-2>*{flex:1}.form-field{display:flex;flex-direction:column;gap:6px}.form-field label{font-size:12.5px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.4px}.label-opt{color:var(--text-3);font-weight:400;text-transform:none;letter-spacing:0}.form-info{background:#3ecfcf12;border:1px solid rgba(62,207,207,.2);border-radius:var(--radius);padding:10px 14px;font-size:13px;color:var(--teal)}.form-error{background:#e84f4f14;border:1px solid rgba(232,79,79,.25);border-radius:var(--radius);padding:10px 14px;font-size:13px;color:var(--accent)}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:8px;padding-top:16px;border-top:1px solid var(--border)}.field-hint{font-size:11.5px;color:var(--yellow);margin-top:2px}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;position:relative;overflow:hidden}.login-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0}.login-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:40px 40px;-webkit-mask-image:radial-gradient(ellipse at center,black 40%,transparent 80%);mask-image:radial-gradient(ellipse at center,black 40%,transparent 80%);opacity:.3}.login-card{position:relative;z-index:1;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px 36px;width:100%;max-width:400px;box-shadow:var(--shadow-lg)}.login-brand{text-align:center;margin-bottom:32px}.login-icon{font-size:36px;color:var(--accent);display:block;margin-bottom:10px}.login-brand h1{font-family:var(--font-head);font-size:28px;font-weight:800;letter-spacing:-1px}.login-brand h1 em{color:var(--teal);font-style:normal}.login-brand p{color:var(--text-3);font-size:13px;margin-top:4px}.login-form{display:flex;flex-direction:column;gap:16px}.login-footer{text-align:center;font-size:11.5px;color:var(--text-3);margin-top:24px}.admin-kpis{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;margin-bottom:20px}.kpi-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.kpi-card.kpi-green{border-color:#52d68a33}.kpi-card.kpi-yellow{border-color:#f5c84233}.kpi-card.kpi-red{border-color:#e84f4f33}.kpi-value{font-family:var(--font-head);font-size:24px;font-weight:700;margin-bottom:4px}.kpi-green .kpi-value{color:var(--green)}.kpi-yellow .kpi-value{color:var(--yellow)}.kpi-red .kpi-value{color:var(--accent)}.kpi-label{font-size:12px;color:var(--text-2);text-transform:uppercase;letter-spacing:.4px;font-weight:600}.admin-overview{display:grid;grid-template-columns:1fr 2fr;gap:20px}.overview-section h3{font-family:var(--font-head);font-size:15px;font-weight:600;margin-bottom:14px}.role-breakdown{display:flex;flex-direction:column;gap:10px}.role-row{display:flex;align-items:center;gap:10px;font-size:13px}.role-name{min-width:120px;color:var(--text-2);text-transform:capitalize}.role-bar-wrap{flex:1;height:6px;background:var(--bg-3);border-radius:3px;overflow:hidden}.role-bar{height:100%;background:var(--teal);border-radius:3px;transition:width .5s}.role-count{min-width:24px;text-align:right;font-family:var(--font-mono)}.role-chip{background:var(--bg-3);border:1px solid var(--border);border-radius:12px;padding:2px 8px;font-size:12px;text-transform:capitalize}.mono{font-family:var(--font-mono);font-size:12px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.modal{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;max-width:420px;width:100%;box-shadow:var(--shadow-lg)}.modal h3{font-family:var(--font-head);font-size:18px;margin-bottom:8px}.modal p{font-size:13px;color:var(--text-2);margin-bottom:14px}.modal-textarea{width:100%;background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;color:var(--text);font-family:inherit;font-size:14px;resize:vertical;margin-bottom:16px}.modal-actions{display:flex;justify-content:flex-end;gap:10px}.empty-state{text-align:center;padding:40px;color:var(--text-2);font-size:14px;display:flex;flex-direction:column;align-items:center;gap:10px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-3)}.super-title{background:linear-gradient(90deg,#ff9f43,#fc0);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.super-badge{display:inline-block;background:#ff9f4326;color:#ff9f43;border:1px solid rgba(255,159,67,.3);border-radius:12px;font-size:11px;font-weight:700;padding:2px 9px;margin-left:10px;vertical-align:middle;letter-spacing:.5px}.nav-super.active{background:#ff9f4326!important;color:#ff9f43!important}.nav-super:hover{background:#ff9f4314!important;color:#ff9f43!important}.sa-kpis{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:8px}.sa-kpi{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px}.sa-kpi-green{border-color:#52d68a33}.sa-kpi-yellow{border-color:#f5c84233}.sa-kpi-orange{border-color:#ff9f4333}.sa-kpi-red{border-color:#e84f4f33}.sa-kpi-val{font-family:var(--font-head);font-size:22px;font-weight:700;margin-bottom:4px}.sa-kpi-lbl{font-size:11px;color:var(--text-2);text-transform:uppercase;letter-spacing:.4px;font-weight:600}.sa-kpi-green .sa-kpi-val{color:var(--green)}.sa-kpi-yellow .sa-kpi-val{color:var(--yellow)}.sa-kpi-orange .sa-kpi-val{color:#ff9f43}.sa-kpi-red .sa-kpi-val{color:var(--accent)}.sa-overview{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.sa-ov-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.sa-ov-card h4{font-family:var(--font-head);font-size:14px;font-weight:600;margin-bottom:14px;color:var(--text-2);text-transform:uppercase;letter-spacing:.5px}.sa-search{width:100%;max-width:360px;margin-bottom:16px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:9px 14px;color:var(--text);font-size:13px;outline:none}.sa-search:focus{border-color:var(--teal)}.sa-table-wrap{overflow-x:auto}.sa-table{width:100%;border-collapse:collapse;font-size:13px}.sa-table thead tr{background:var(--bg-3);border-bottom:2px solid var(--border)}.sa-table th{text-align:left;padding:10px 14px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-3);white-space:nowrap}.sa-table td{padding:10px 14px;border-bottom:1px solid var(--border);vertical-align:middle}.sa-table tbody tr:hover{background:var(--bg-3)}.sa-table tbody tr.row-inactive td{opacity:.5}.sa-actions{display:flex;gap:6px;flex-wrap:nowrap}.sa-btn-edit{background:#3ecfcf1a;color:var(--teal);border:1px solid rgba(62,207,207,.25);padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;transition:all .15s;white-space:nowrap}.sa-btn-edit:hover{background:#3ecfcf33}.sa-btn-del{background:#e84f4f1a;color:var(--accent);border:1px solid rgba(232,79,79,.25);padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;transition:all .15s;white-space:nowrap}.sa-btn-del:hover{background:#e84f4f33}.sa-btn-view{background:#9b7ff81a;color:var(--purple);border:1px solid rgba(155,127,248,.25);padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;white-space:nowrap}.sa-btn-deactivate{background:#e84f4f14;color:var(--accent);border:1px solid rgba(232,79,79,.2);padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;white-space:nowrap}.sa-btn-activate{background:#52d68a14;color:var(--green);border:1px solid rgba(82,214,138,.2);padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;white-space:nowrap}.td-truncate{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.empty-cell{text-align:center;color:var(--text-3);padding:32px}.audit-action{font-family:var(--font-mono);font-size:11px;background:var(--bg-3);border:1px solid var(--border);border-radius:4px;padding:2px 7px}.modal-lg{max-width:560px!important}.modal-sub{font-size:13px;color:var(--text-2);margin-top:-4px;margin-bottom:4px}.mt-16{margin-top:16px}.teal{color:var(--teal)}.location-row{display:flex;gap:14px;margin-top:16px;flex-wrap:wrap;justify-content:center}.loc-card{background:var(--bg-3);border:1px solid var(--border);border-left:3px solid var(--loc-color, var(--teal));border-radius:var(--radius-lg);padding:14px 18px;min-width:220px;flex:1;max-width:280px;text-align:left}.loc-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;margin-bottom:4px}.loc-time{font-family:var(--font-mono);font-size:20px;font-weight:500;margin-bottom:6px}.loc-address{font-size:11.5px;color:var(--text-2);margin-bottom:8px;line-height:1.4}.loc-no-gps{font-size:12px;color:var(--text-3)}.loc-map-btn{display:inline-flex;align-items:center;gap:5px;background:#3ecfcf1a;color:var(--teal);border:1px solid rgba(62,207,207,.25);border-radius:6px;padding:5px 12px;font-size:12px;font-weight:600;transition:all .15s}.loc-map-btn:hover{background:#3ecfcf33}.location-warn{color:var(--yellow);font-size:12px;margin-top:10px;background:#f5c84214;border:1px solid rgba(245,200,66,.2);border-radius:var(--radius);padding:8px 12px}.map-link{color:var(--teal);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px;display:inline-block}.map-link:hover{text-decoration:underline}.no-loc{color:var(--text-3);font-size:12px}.att-row{display:grid;grid-template-columns:1.2fr 1fr 1fr 2fr 1fr 2fr 1fr}.att-row.att-row-7{grid-template-columns:1.2fr 1fr .8fr 2fr .8fr 2fr .8fr}.att-row.att-row-6{grid-template-columns:1.5fr 1fr .8fr 2fr .8fr 1fr}.att-header{grid-template-columns:1.2fr 1fr .8fr 2fr .8fr 2fr .8fr}.btn-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(0,0,0,.3);border-top-color:#000;border-radius:50%;animation:spin .6s linear infinite}.mono-sm{font-family:var(--font-mono);font-size:12px}.leave-staff-name{display:block;font-size:13px;font-weight:700;color:var(--teal);margin-bottom:3px}.ais-page{padding:0}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.page-title{font-size:20px;font-weight:700;color:var(--text-primary)}.page-sub{font-size:11px;color:var(--text-tertiary);margin-top:3px}.hdr-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.kpi-row{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}.kpi-card{flex:1;min-width:100px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:10px;padding:11px 14px;text-align:center}.kpi-card.g{background:#1db98414;border-color:#1db98438}.kpi-card.a{background:#ef9f2714;border-color:#ef9f2738}.kpi-card.b{background:#185fa517;border-color:#185fa538}.kpi-card.r{background:#dc262612;border-color:#dc262638}.kpi-label{font-size:9px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px}.kpi-value{font-size:22px;font-weight:700;color:var(--text-primary)}.kpi-card.g .kpi-value{color:#4ade80}.kpi-card.a .kpi-value{color:#f59e0b}.kpi-card.b .kpi-value{color:#60a5fa}.kpi-card.r .kpi-value{color:#f87171}.two-panel{display:grid;grid-template-columns:230px 1fr;gap:12px;min-height:560px;align-items:start}.panel-left{display:flex;flex-direction:column;gap:6px;overflow-y:auto;max-height:calc(100vh - 260px)}.panel-right{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;min-height:520px}.nav-group{margin-bottom:2px}.nav-group-header{display:flex;justify-content:space-between;align-items:center;padding:8px 16px 2px;font-size:9px;font-weight:700;color:#ffffff38;text-transform:uppercase;letter-spacing:.1em;cursor:pointer;-webkit-user-select:none;user-select:none}.nav-group-header:hover{color:#fff6}.ticket-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:9px;padding:10px 12px;cursor:pointer;transition:all .12s}.ticket-card:hover{border-color:#1db98466}.ticket-card.selected{border-color:#1db984;background:#1db98412}.tc-top{display:flex;justify-content:space-between;align-items:flex-start;gap:6px;margin-bottom:3px}.tc-id{font-size:11px;font-weight:600;color:var(--text-primary);font-family:monospace}.tc-badge{font-size:9px;padding:2px 8px;border-radius:6px;font-weight:600;white-space:nowrap;flex-shrink:0}.tc-loc{font-size:10.5px;color:var(--text-secondary);margin-bottom:2px}.tc-items{font-size:9.5px;color:#60a5fa;margin-bottom:3px}.tc-pocs{display:flex;gap:4px;flex-wrap:wrap}.poc-chip{font-size:9px;background:#00d4a81f;color:#00d4a8;padding:1px 6px;border-radius:4px}.lcs{font-size:10px;color:var(--text-secondary);margin-bottom:2px}.lcm{font-size:9.5px;color:var(--text-tertiary)}.filter-pills{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:8px}.pill{font-size:9.5px;padding:3px 10px;border-radius:20px;border:1px solid var(--border-primary);color:var(--text-tertiary);background:transparent;cursor:pointer;transition:all .12s}.pill:hover{border-color:#1db98466;color:var(--text-secondary)}.pill.on{background:#1db984;color:#0d1117;border-color:#1db984;font-weight:600}.ticket-detail{display:flex;flex-direction:column;flex:1;overflow:hidden}.td-header{padding:12px 15px;border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;align-items:flex-start;flex-shrink:0}.td-title{font-size:13px;font-weight:700;color:var(--text-primary)}.td-sub{font-size:10px;color:var(--text-tertiary);margin-top:3px}.stage-bar-wrap{padding:8px 15px;border-bottom:1px solid var(--border-primary);flex-shrink:0}.stage-bar{display:flex;border-radius:6px;overflow:hidden}.stage-seg{flex:1;text-align:center;padding:5px 2px;font-size:8.5px;background:var(--bg-secondary);color:var(--text-tertiary);border-right:1px solid var(--bg-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stage-seg:last-child{border-right:none}.stage-seg.done{background:#1db98424;color:#4ade80}.stage-seg.active{background:#1db984;color:#0d1117;font-weight:700}.td-tabs{display:flex;border-bottom:1px solid var(--border-primary);overflow-x:auto;flex-shrink:0;background:var(--bg-primary)}.td-tabs::-webkit-scrollbar{height:2px}.td-tab{font-size:10.5px;padding:7px 12px;cursor:pointer;color:var(--text-tertiary);border-bottom:2px solid transparent;background:transparent;border-top:none;border-left:none;border-right:none;white-space:nowrap;transition:all .12s}.td-tab:hover{color:var(--text-secondary);background:#ffffff08}.td-tab.on{color:#1db984;border-bottom-color:#1db984;background:#1db9840d}.td-body{padding:13px 15px;overflow-y:auto;flex:1;max-height:calc(100vh - 220px)}.td-body::-webkit-scrollbar{width:3px}.tab-fields{display:flex;flex-direction:column;gap:0}.field-row{display:flex;justify-content:space-between;align-items:flex-start;padding:5px 0;border-bottom:1px solid var(--border-primary)}.field-row:last-child{border:none}.field-label{font-size:10px;color:var(--text-tertiary);flex-shrink:0;margin-right:8px;padding-top:1px}.field-value{font-size:11px;color:var(--text-primary);text-align:right}.field-group-header{font-size:9px;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.07em;margin:11px 0 5px;padding-bottom:4px;border-bottom:1px solid var(--border-primary)}.field-text{font-size:11px;color:var(--text-secondary);line-height:1.6}.green{color:#4ade80;font-weight:500}.amber{color:#f59e0b}.red{color:#f87171}.dim{color:var(--text-tertiary)}.link-text{color:#60a5fa;cursor:pointer}.link-text:hover{text-decoration:underline}.fa-table{width:100%;border-collapse:collapse;font-size:10.5px;margin-top:8px}.fa-table th{text-align:left;padding:5px 7px;font-size:9px;font-weight:700;color:var(--text-tertiary);border-bottom:1px solid var(--border-primary);background:var(--bg-primary);text-transform:uppercase;letter-spacing:.04em}.fa-table td{padding:5px 7px;border-bottom:1px solid var(--border-primary);color:var(--text-secondary)}.fa-table tr.added-row{background:#ef9f270f}.fa-table tr.added-row td{color:#f59e0b}.fa-table tr.total-row td{border-top:1px solid var(--border-secondary);font-weight:700;color:var(--text-primary);font-size:12px;border-bottom:none}.on-site-tag{font-size:8.5px;background:#ef9f2726;color:#f59e0b;padding:1px 5px;border-radius:3px;margin-left:5px}.del-btn{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;font-size:14px;padding:0 4px}.del-btn:hover{color:#f87171}.items-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.add-item-panel{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;padding:10px;margin-bottom:10px}.rate-list{max-height:160px;overflow-y:auto;margin-bottom:8px}.rate-row{display:flex;align-items:center;gap:8px;padding:5px 7px;border-radius:5px;cursor:pointer;transition:all .1s;font-size:10.5px}.rate-row:hover{background:#ffffff0d}.rate-row.selected{background:#1db9841a;border:1px solid rgba(29,185,132,.3)}.rate-code{font-family:monospace;color:#60a5fa;min-width:50px;font-weight:600}.rate-desc{flex:1;color:var(--text-secondary)}.rate-price{font-size:9.5px;color:var(--text-tertiary);white-space:nowrap}.add-item-form{background:var(--bg-primary);border-radius:6px;padding:8px;border:1px solid var(--border-primary);margin-top:6px}.mat-list{display:flex;flex-direction:column;gap:3px;margin-bottom:5px}.mat-row{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-secondary);padding:3px 0;border-bottom:1px solid var(--border-primary)}.mat-row span{flex:1}.pic-chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:5px}.pic-chip{display:flex;align-items:center;gap:5px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:20px;padding:3px 10px;font-size:10.5px;color:var(--text-secondary)}.pic-ava{width:20px;height:20px;border-radius:50%;background:#1db984;color:#0d1117;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;flex-shrink:0}.gdrive-row{display:flex;align-items:center;gap:9px;padding:8px 10px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:7px;margin-bottom:5px;cursor:pointer;transition:all .12s}.gdrive-row:hover{border-color:#1db98466;background:#1db9840a}.gdrive-row.restricted:hover{border-color:#dc262666}.gd-icon{width:30px;height:30px;border-radius:6px;background:#ef9f2726;color:#f59e0b;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.gd-icon.red{background:#dc26261f;color:#f87171}.gd-info{flex:1;min-width:0}.gd-name{font-size:11px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gd-note{font-size:9.5px;color:var(--text-tertiary);margin-top:1px}.gd-link{font-size:9.5px;color:#60a5fa;white-space:nowrap;flex-shrink:0}.gdrive-info-box{background:#00d4a812;border:1px solid rgba(0,212,168,.2);border-radius:8px;padding:9px 12px;margin-bottom:10px}.gib-title{font-size:11px;font-weight:600;color:#00d4a8;margin-bottom:4px}.gib-body{font-size:10.5px;color:#94b4a0;line-height:1.55}.log-timeline{padding-left:18px;position:relative;margin-bottom:12px}.log-timeline:before{content:"";position:absolute;left:7px;top:6px;bottom:0;width:1px;background:var(--border-primary)}.log-entry{position:relative;margin-bottom:12px}.log-dot{position:absolute;left:-12px;top:5px;width:7px;height:7px;border-radius:50%;background:#1db984;border:2px solid var(--bg-primary)}.log-content{padding-left:2px}.log-date{font-size:9px;color:var(--text-tertiary)}.log-note{font-size:11px;color:var(--text-primary);margin:2px 0;line-height:1.4}.log-stage-tag{font-size:9px;background:#1db9841f;color:#4ade80;padding:1px 6px;border-radius:4px}.add-log{display:flex;flex-direction:column;gap:6px}.log-inp{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:6px;padding:7px 10px;font-size:11px;color:var(--text-primary);resize:none;font-family:inherit}.log-inp:focus{outline:none;border-color:#1db984}.btn-primary{background:#1db984;color:#0d1117;border:none;padding:6px 14px;border-radius:7px;font-size:11px;font-weight:600;cursor:pointer;transition:all .12s}.btn-primary:hover{background:#16a371}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-success{background:#4ade80;color:#0d1117;border:none;padding:6px 14px;border-radius:7px;font-size:11px;font-weight:600;cursor:pointer}.btn-wa{background:#25d366;color:#fff;border:none;padding:6px 13px;border-radius:7px;font-size:11px;font-weight:500;cursor:pointer;transition:all .12s}.btn-wa:hover{background:#1ea952}.btn-email{background:#185fa526;color:#60a5fa;border:1px solid rgba(24,95,165,.3);padding:6px 13px;border-radius:7px;font-size:11px;font-weight:500;cursor:pointer}.btn-stage{width:100%;margin-top:8px;background:#1db9841f;color:#4ade80;border:1px solid rgba(29,185,132,.25);padding:7px;border-radius:7px;font-size:11px;font-weight:500;cursor:pointer;transition:all .12s}.btn-stage:hover{background:#1db984;color:#0d1117}.btn-stage:disabled{opacity:.5;cursor:not-allowed}.btn-q{background:transparent;color:var(--text-secondary);border:1px solid var(--border-primary);padding:6px 13px;border-radius:7px;font-size:11px;cursor:pointer}.btn-q:hover{border-color:#fff3}.tab-btn{background:transparent;color:var(--text-tertiary);border:1px solid var(--border-primary);padding:5px 12px;border-radius:7px;font-size:11px;cursor:pointer}.tab-btn.on{background:#1db9841f;color:#1db984;border-color:#1db9844d;font-weight:600}.btn-sm-g{background:#1db98426;color:#4ade80;border:1px solid rgba(29,185,132,.25);padding:4px 10px;border-radius:6px;font-size:10.5px;font-weight:500;cursor:pointer}.btn-sm-g:disabled{opacity:.5;cursor:not-allowed}.btn-sm{background:transparent;color:var(--text-secondary);border:1px solid var(--border-primary);padding:4px 10px;border-radius:6px;font-size:10.5px;cursor:pointer}.ghost-btn{background:transparent;border:1px dashed var(--border-primary);color:var(--text-tertiary);padding:5px 12px;border-radius:6px;font-size:10.5px;cursor:pointer;width:100%;text-align:center;margin-top:6px}.ghost-btn:hover{border-color:#1db98466;color:#1db984}.ghost-add-btn{background:transparent;border:1px dashed var(--border-primary);color:var(--text-tertiary);padding:7px;border-radius:8px;font-size:10.5px;cursor:pointer;text-align:center}.ghost-add-btn:hover{border-color:#1db98466;color:#1db984}.action-row{display:flex;gap:8px;flex-wrap:wrap}.btn-row{display:flex;gap:6px;margin-top:6px}.inline-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:6px}.inp-sm{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:5px;padding:4px 8px;font-size:11px;color:var(--text-primary)}.inp-sm:focus{outline:none;border-color:#1db984}.inp-lbl{font-size:9.5px;color:var(--text-tertiary)}.empty-panel{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:12px;color:var(--text-tertiary);font-size:13px;padding:40px}.empty-icon{font-size:36px;opacity:.4}.loading-panel{display:flex;align-items:center;justify-content:center;flex:1}.loading-msg,.empty-msg{font-size:11px;color:var(--text-tertiary);padding:10px;text-align:center}.weekly-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.wh-title{font-size:15px;font-weight:600;color:var(--text-primary)}.wh-sub{font-size:10.5px;color:var(--text-tertiary);margin-top:2px}.weekly-table{width:100%;border-collapse:collapse;font-size:10.5px}.weekly-table th{text-align:left;padding:6px 9px;font-size:9px;font-weight:700;color:var(--text-tertiary);border-bottom:1px solid var(--border-primary);background:var(--bg-primary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.weekly-table td{padding:7px 9px;border-bottom:1px solid var(--border-primary);color:var(--text-secondary);vertical-align:middle}.weekly-table tr:hover td{background:#ffffff05}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d1;display:flex;align-items:center;justify-content:center;z-index:999;padding:16px;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal-box{background:#1c2130;border:1px solid rgba(62,207,207,.35);box-shadow:0 0 0 1px #3ecfcf1a,0 24px 64px #000000b3;border-radius:14px;width:100%;max-width:560px;max-height:90vh;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid rgba(62,207,207,.15);flex-shrink:0}.modal-title{font-size:14px;font-weight:700;color:#e8eaf0}.modal-close{background:transparent;border:none;color:#5a6070;font-size:20px;cursor:pointer;line-height:1}.modal-close:hover{color:#e8eaf0}.modal-body{padding:16px 18px;overflow-y:auto;flex:1;background:#1c2130}.modal-body::-webkit-scrollbar{width:3px}.modal-footer{display:flex;gap:8px;justify-content:flex-end;padding:12px 18px;border-top:1px solid rgba(62,207,207,.15);flex-shrink:0;background:#191e2b;border-radius:0 0 14px 14px}.form-row{margin-bottom:10px}.form-lbl{display:block;font-size:10px;color:#7a8499;margin-bottom:4px;font-weight:500;letter-spacing:.03em}.form-inp{width:100%;background:#131720;border:1px solid #2e3648;border-radius:7px;padding:7px 10px;font-size:11.5px;color:#e8eaf0;font-family:inherit;transition:border .12s}.form-inp:focus{outline:none;border-color:#3ecfcf}.form-inp[readonly]{opacity:.7;cursor:default}.form-sel{width:100%;background:#131720;border:1px solid #2e3648;border-radius:7px;padding:7px 10px;font-size:11.5px;color:#9aa0b0;font-family:inherit}.form-sel:focus{outline:none;border-color:#3ecfcf}.form-ta{width:100%;background:#131720;border:1px solid #2e3648;border-radius:7px;padding:7px 10px;font-size:11.5px;color:#e8eaf0;font-family:inherit;resize:vertical;transition:border .12s}.form-ta:focus{outline:none;border-color:#3ecfcf}.form-2col{display:grid;grid-template-columns:1fr 1fr;gap:10px}.llist{display:flex;flex-direction:column;gap:6px;overflow-y:auto;max-height:calc(100vh - 280px)}.llist::-webkit-scrollbar{width:3px}.cal-wrap{position:relative}.cal-input{display:flex;align-items:center;gap:7px;background:#131720;border:1px solid #2e3648;border-radius:7px;padding:7px 10px;font-size:11.5px;color:var(--text-2);cursor:pointer;transition:border .12s;-webkit-user-select:none;user-select:none;min-height:34px}.cal-input:hover{border-color:#3a4255}.cal-input:focus{outline:none;border-color:var(--teal)}.cal-input.disabled{opacity:.5;cursor:default;pointer-events:none}.cal-popup{position:absolute;top:calc(100% + 6px);left:0;z-index:500;background:#1c2130;border:1px solid rgba(62,207,207,.25);border-radius:12px;padding:12px;box-shadow:0 8px 32px #0009;min-width:240px;width:240px}.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.cal-month-label{font-size:12px;font-weight:600;color:var(--text)}.cal-nav{background:none;border:none;color:var(--text-2);font-size:18px;cursor:pointer;padding:2px 6px;border-radius:5px;line-height:1}.cal-nav:hover{background:#ffffff14;color:var(--text)}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cal-dow{text-align:center;font-size:9px;font-weight:600;color:var(--text-3);padding:3px 0;letter-spacing:.04em}.cal-day{text-align:center;font-size:11px;color:var(--text-2);padding:5px 2px;border-radius:5px;border:none;background:none;cursor:pointer;transition:background .1s,color .1s}.cal-day:hover{background:#ffffff1a;color:var(--text)}.cal-day.today{color:var(--teal);font-weight:700}.cal-day.selected{background:var(--teal);color:#0d1117;font-weight:700;border-radius:50%}.cal-day.today.selected{background:var(--teal);color:#0d1117}.cal-footer{margin-top:10px;border-top:1px solid rgba(255,255,255,.06);padding-top:8px;text-align:center}.cal-today-btn{background:none;border:1px solid rgba(62,207,207,.3);color:var(--teal);font-size:10px;padding:4px 14px;border-radius:6px;cursor:pointer;transition:background .12s}.cal-today-btn:hover{background:#3ecfcf1a}.bd-overview{padding:0}.bd-kpi-row{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:16px}@media (max-width: 900px){.bd-kpi-row{grid-template-columns:repeat(3,1fr)}}.bd-kpi-card{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:12px 14px}.bd-kpi-label{font-size:9px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}.bd-kpi-value{font-size:24px;font-weight:700;color:var(--text);line-height:1}.bd-kpi-sub{font-size:10px;color:var(--text-3);margin-top:4px}.bd-must-banner{display:flex;align-items:center;gap:10px;flex:1;min-width:220px;border-radius:10px;padding:10px 14px;border-left:3px solid;transition:opacity .15s}.bd-must-banner:hover{opacity:.85}.bd-must-banner.blue{background:#60a5fa14;border-left-color:#60a5fa}.bd-must-banner.amber{background:#f5c84214;border-left-color:#f5c842}.bd-must-icon{font-size:18px;flex-shrink:0}.bd-must-title{font-size:12px;font-weight:600;color:var(--text)}.bd-must-sub{font-size:10px;color:var(--text-3);margin-top:2px}.bd-must-arrow{font-size:16px;color:var(--text-3);margin-left:auto}.bd-two-col{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media (max-width: 800px){.bd-two-col{grid-template-columns:1fr}}.bd-card{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:14px 16px}.bd-card-title{font-size:11px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.05em}.bd-empty{font-size:11px;color:var(--text-3);padding:12px 0;text-align:center}.bd-survey-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border)}.bd-survey-row:last-child{border:none}.bd-btn-sm{font-size:10px;padding:3px 8px;border-radius:5px;border:1px solid var(--border-2);background:none;color:var(--text-2);cursor:pointer}.bd-btn-sm.teal{border-color:#3ecfcf66;color:var(--teal)}.bd-btn-sm:hover{background:var(--bg-3)}.bd-action-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border);cursor:pointer}.bd-action-item:last-child{border:none}.bd-action-item:hover{opacity:.8}.bd-action-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.bd-action-title{font-size:12px;font-weight:500;color:var(--text)}.bd-action-sub{font-size:10px;color:var(--text-3);margin-top:2px}.bd-action-chip{font-size:9px;padding:2px 8px;border-radius:6px;border:1px solid;white-space:nowrap;flex-shrink:0;font-weight:500}.bd-panel-wrap{display:flex;gap:12px;height:calc(100vh - 180px);min-height:500px}.bd-left{width:230px;flex-shrink:0;display:flex;flex-direction:column;gap:8px;overflow:hidden}.bd-right{flex:1;background:var(--bg-2);border:1px solid var(--border);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;min-width:0}.bd-filters{display:flex;flex-direction:column;gap:6px;flex-shrink:0}.bd-search{width:100%;background:var(--bg-2);border:1px solid var(--border);border-radius:7px;padding:7px 10px;font-size:11.5px;color:var(--text);font-family:inherit}.bd-search:focus{outline:none;border-color:var(--teal)}.bd-select{width:100%;background:var(--bg-2);border:1px solid var(--border);border-radius:7px;padding:6px 10px;font-size:11px;color:var(--text-2);font-family:inherit;cursor:pointer}.bd-select:focus{outline:none;border-color:var(--teal)}.bd-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:5px}.bd-list::-webkit-scrollbar{width:2px}.bd-list-card{background:var(--bg-2);border:1px solid var(--border);border-radius:8px;padding:9px 11px;cursor:pointer;transition:border-color .12s,background .12s}.bd-list-card:hover{border-color:#3ecfcf4d;background:var(--bg-3)}.bd-list-card.active{border-color:var(--teal);background:#3ecfcf0f}.bd-list-name{font-size:12px;font-weight:600;color:var(--text)}.bd-list-meta{font-size:10px;color:var(--text-3);margin-top:2px}.bd-rp-head{padding:12px 14px;border-bottom:1px solid var(--border);flex-shrink:0;display:flex;align-items:flex-start;justify-content:space-between}.bd-rp-name{font-size:13px;font-weight:700;color:var(--text)}.bd-rp-sub{font-size:10px;color:var(--text-3);margin-top:2px}.bd-tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0;overflow-x:auto}.bd-tab{font-size:10px;padding:8px 12px;cursor:pointer;color:var(--text-3);border-bottom:2px solid transparent;white-space:nowrap;flex-shrink:0;background:none;border-top:none;border-left:none;border-right:none;font-family:inherit}.bd-tab:hover{color:var(--text-2)}.bd-tab.active{color:var(--teal);border-bottom-color:var(--teal);font-weight:600}.bd-tab-body{padding:12px 14px;overflow-y:auto;flex:1}.bd-tab-body::-webkit-scrollbar{width:2px}.bd-field-row{display:flex;justify-content:space-between;align-items:flex-start;padding:5px 0;border-bottom:1px solid var(--border)}.bd-field-row:last-child{border:none}.bd-field-lbl{font-size:10px;color:var(--text-3);flex-shrink:0;padding-top:1px}.bd-field-val{font-size:11px;color:var(--text);text-align:right;max-width:60%}.bd-field-val.green{color:#52d68a;font-weight:600}.bd-field-val.amber{color:#f5c842}.bd-field-val.red{color:#f87171}.bd-field-val.link{color:var(--teal);cursor:pointer}.bd-section{font-size:9px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;margin:12px 0 6px}.bd-contact-chip{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--border)}.bd-contact-chip:last-child{border:none}.bd-avatar{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;flex-shrink:0}.bd-contact-name{font-size:11px;font-weight:600;color:var(--text)}.bd-contact-pos{font-size:10px;color:var(--text-3)}.bd-wa-btn{font-size:9px;color:#25d366;background:#25d3661f;border:1px solid rgba(37,211,102,.25);padding:2px 7px;border-radius:5px;cursor:pointer;white-space:nowrap}.bd-ix{padding:7px 0;border-bottom:1px solid var(--border)}.bd-ix:last-child{border:none}.bd-ix-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:3px}.bd-ix-date{font-size:9px;color:var(--text-3)}.bd-ix-note{font-size:10.5px;color:var(--text-2);line-height:1.4}.bd-ix-link{font-size:9px;color:var(--teal);margin-top:3px}.bd-type-badge{font-size:9px;font-weight:600;padding:2px 6px;border-radius:4px}.bd-prop-row{display:flex;align-items:center;gap:7px;padding:6px 0;border-bottom:1px solid var(--border);font-size:11px}.bd-prop-row:last-child{border:none}.bd-prop-num{font-family:monospace;font-size:9px;color:var(--text-3);min-width:90px}.bd-prop-desc{flex:1;color:var(--text)}.bd-prop-myr{font-size:10px;color:#52d68a;font-weight:600;min-width:60px;text-align:right}.bd-status-badge{font-size:9px;font-weight:600;padding:2px 7px;border-radius:6px;white-space:nowrap}.bd-add-btn{width:100%;font-size:10px;border:1px dashed var(--border-2);background:none;color:var(--text-3);padding:6px;border-radius:7px;cursor:pointer;margin-top:8px;font-family:inherit;text-align:center}.bd-add-btn:hover{border-color:var(--teal);color:var(--teal)}.bd-btn-pri{font-size:11px;padding:6px 14px;border-radius:7px;border:none;background:var(--teal);color:#0d1117;cursor:pointer;font-weight:600;font-family:inherit}.bd-btn-pri:hover{opacity:.88}.bd-btn-sec{font-size:11px;padding:6px 12px;border-radius:7px;border:1px solid var(--border-2);background:none;color:var(--text-2);cursor:pointer;font-family:inherit}.bd-btn-sec:hover{background:var(--bg-3)}.bd-pills{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:8px}.bd-pill{font-size:10px;padding:3px 9px;border-radius:10px;border:1px solid var(--border);color:var(--text-3);cursor:pointer;background:none;font-family:inherit}.bd-pill:hover{border-color:#3ecfcf66;color:var(--text-2)}.bd-pill.active{background:var(--teal);color:#0d1117;border-color:var(--teal);font-weight:600}.bd-rp-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-3);gap:8px;padding:40px}.bd-rp-empty-icon{font-size:32px;opacity:.4}.bd-rp-empty-text{font-size:12px}.ix-alert-card{display:flex;align-items:center;gap:10px;flex:1;min-width:200px;border-radius:10px;padding:9px 13px;border-left:3px solid}.ix-alert-card.red{background:#f8717112;border-left-color:#f87171}.ix-alert-card.amber{background:#f5c84212;border-left-color:#f5c842}.ix-alert-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.ix-alert-dot.red{background:#f87171}.ix-alert-dot.amber{background:#f5c842}.ix-alert-title{font-size:11px;font-weight:600;color:var(--text)}.ix-alert-names{font-size:10px;color:var(--text-3);margin-top:2px}.btn-site{background:#3ecfcf1f;color:var(--teal);border:1px solid rgba(62,207,207,.3);border-radius:var(--radius);padding:10px 20px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.btn-site:hover{background:var(--teal);color:#0d1117}.site-badge{display:flex;align-items:center;margin-top:8px}.chip-site{background:#3ecfcf1f;color:var(--teal);border:1px solid rgba(62,207,207,.25);padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600}.att-summary-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px;margin-top:12px;display:flex;flex-direction:column;gap:4px}.att-sum-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid var(--border);font-size:13px}.att-sum-row:last-child{border-bottom:none}.att-sum-label{color:var(--text-3);font-size:11px}.att-sum-val{color:var(--text);display:flex;align-items:center;gap:6px}.chip-blue{background:#185fa51f;color:#60a5fa;border:1px solid rgba(24,95,165,.25);padding:2px 8px;border-radius:6px;font-size:11px;font-weight:600}.chip-teal{background:#3ecfcf1f;color:var(--teal);border:1px solid rgba(62,207,207,.25);padding:2px 8px;border-radius:6px;font-size:11px;font-weight:600}.chip-paid{background:#52d68a1f;color:var(--green);border:1px solid rgba(82,214,138,.25);padding:2px 8px;border-radius:6px;font-size:11px;font-weight:600}.hamburger-btn{display:none;background:none;border:none;cursor:pointer;padding:4px 8px;font-size:20px;color:var(--text-2);line-height:1;flex-shrink:0}@media (max-width: 768px){.app-shell{flex-direction:column;height:100dvh}.sidebar{position:fixed!important;top:0;left:0;bottom:0;z-index:200;transform:translate(-100%);transition:transform .22s ease,width .22s ease;width:260px!important;box-shadow:4px 0 24px #00000080}.sidebar.open{transform:translate(0);width:260px!important}.sidebar.collapsed{transform:translate(-100%)}.sidebar-backdrop{display:block!important;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:199;animation:fadeIn .18s ease}.topbar{padding:8px 12px}.hamburger-btn{display:flex;align-items:center}.page-greeting{font-size:14px}.collapse-btn{display:none}.main-content{flex:1;overflow-y:auto;width:100%}.page-content{padding:12px}.kpi-row,.stats-row,[class*=kpi-grid],.dashboard-kpis{grid-template-columns:repeat(2,1fr)!important;gap:8px!important}.btn-clock{min-height:52px;font-size:16px!important;padding:14px 24px!important;width:100%}.clock-actions{flex-direction:column;gap:10px}.table-wrap,.attendance-table,[class*=-table]{overflow-x:auto;-webkit-overflow-scrolling:touch}.form-row-2,.form-row-3{grid-template-columns:1fr!important}.tab-bar{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap!important}.tab{white-space:nowrap;flex-shrink:0}.modal-box{width:100%!important;max-width:100%!important;max-height:92dvh;border-radius:16px 16px 0 0;position:fixed;bottom:0;left:0;right:0;overflow-y:auto}.modal-overlay{align-items:flex-end!important}.stage-bar>div{font-size:9px!important;padding:6px 3px!important}.section-header{flex-direction:column;align-items:flex-start;gap:8px}.section-header>*:last-child{align-self:flex-start}.nav-link,.nav-item{padding:10px 16px!important;font-size:14px!important}.nav-group-label{font-size:10px!important;padding:8px 16px 4px!important}.claim-card,.leave-card{padding:12px!important}.site-modal-grid,.two-col-layout{grid-template-columns:1fr!important}.sidebar-badge{display:none}}@media (max-width: 480px){.kpi-row,.stats-row,.dashboard-kpis{grid-template-columns:1fr!important}.page-content{padding:8px}.btn-clock{min-height:56px;font-size:17px!important}}.sidebar-backdrop{display:none}@keyframes panelSlideIn{0%{transform:translate(30%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.pipeline-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;align-items:start}.pipeline-col{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;overflow:hidden;min-height:200px}.pipeline-col-header{padding:8px 10px;border-bottom:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between}.pipeline-col-name{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.pipeline-col-count{font-size:9px;padding:1px 6px;border-radius:10px;font-weight:600}.pipeline-cards{padding:8px;display:flex;flex-direction:column;gap:6px}.pipeline-card{background:#0c1018;border:1px solid var(--border-primary);border-radius:7px;padding:8px 9px;cursor:pointer;transition:all .12s}.pipeline-card:hover{border-color:#3a4a5c;background:#0f151e}.pipeline-card.sel{border-color:var(--teal);background:#00d4a80d}.pc-id{font-size:10px;font-family:monospace;color:#60a5fa;font-weight:600;margin-bottom:2px}.pc-loc{font-size:10px;color:var(--text-secondary);margin-bottom:3px}.pc-fa{font-size:9px;color:#60a5fa;margin-bottom:5px}.pc-checks{display:flex;flex-direction:column;gap:3px}.pc-check{display:flex;align-items:center;gap:5px;font-size:9px}.pc-check.ok .chk-label{color:#4a7a60}.pc-check.no .chk-label{color:#8a3030}.chk-label{font-size:9px}.chk{width:13px;height:13px;border-radius:3px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:8px;font-weight:700}.chk-ok{background:#1db98433;color:#4ade80}.chk-no{background:#dc262626;color:#f87171}.chk-pd{background:#ffffff0f;color:var(--text-tertiary)}.chk-am{background:#ef9f2726;color:var(--amber)}.pcol-req .pipeline-col-header{border-top:2px solid #dc2626}.pcol-prep .pipeline-col-header{border-top:2px solid var(--blue)}.pcol-site .pipeline-col-header{border-top:2px solid var(--amber)}.pcol-rpt .pipeline-col-header{border-top:2px solid #534AB7}.pcol-done .pipeline-col-header{border-top:2px solid var(--green)}.pcol-req .pipeline-col-name{color:#f87171}.pcol-prep .pipeline-col-name{color:#60a5fa}.pcol-site .pipeline-col-name{color:var(--amber)}.pcol-rpt .pipeline-col-name{color:#c084fc}.pcol-done .pipeline-col-name{color:#4ade80}.pcol-req .pipeline-col-count{background:#dc262626;color:#f87171}.pcol-prep .pipeline-col-count{background:#185fa526;color:#60a5fa}.pcol-site .pipeline-col-count{background:#ef9f2726;color:var(--amber)}.pcol-rpt .pipeline-col-count{background:#534ab726;color:#c084fc}.pcol-done .pipeline-col-count{background:#1db98426;color:#4ade80}.view-tabs{display:flex;border-bottom:1px solid var(--border-primary);margin-bottom:12px;background:var(--bg-primary);border-radius:8px 8px 0 0;overflow:hidden}.view-tab{font-size:11px;padding:8px 16px;cursor:pointer;color:var(--text-tertiary);border:none;border-bottom:2px solid transparent;background:transparent;white-space:nowrap;transition:all .12s}.view-tab:hover{color:var(--text-secondary);background:#ffffff06}.view-tab.on{color:var(--teal);border-bottom-color:var(--teal);background:#00d4a80d}.wcal-wrap{overflow-x:auto}.wcal-grid-header{display:grid;grid-template-columns:60px repeat(7,1fr);gap:4px;margin-bottom:4px}.wcal-grid-row{display:grid;grid-template-columns:60px repeat(7,1fr);gap:4px}.wcal-label-cell{padding:6px 4px;font-size:9px;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.week-col-head{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:6px;padding:6px 8px;text-align:center}.wch-label{font-size:10px;font-weight:700;color:var(--text-secondary)}.wch-date{font-size:9px;color:var(--text-tertiary);margin-top:1px}.today-head{border-color:#00d4a866!important;background:#00d4a80d!important}.today-head .wch-label{color:var(--teal)!important}.overdue-head{border-color:#dc26264d!important;background:#dc26260d!important}.week-cell{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:6px;padding:6px 7px;min-height:80px;display:flex;flex-direction:column;gap:6px}.week-cell.today-cell{background:#00d4a80a;border-color:#00d4a833}.week-cell.overdue-cell{background:#dc26260d;border-color:#dc262633}.week-ticket{cursor:pointer;padding:4px 0;border-bottom:1px solid rgba(255,255,255,.04)}.week-ticket:last-child{border-bottom:none}.week-ticket:hover .wc-job{text-decoration:underline}.wc-job{font-size:9px;font-family:monospace;color:#60a5fa;font-weight:600;margin-bottom:2px}.wc-loc{font-size:8.5px;color:var(--text-tertiary);margin-bottom:2px}.wc-fa{font-size:8px;color:#60a5fa;margin-bottom:3px}.wc-stages{display:flex;flex-wrap:wrap;gap:2px}.wcs{font-size:7.5px;padding:1px 4px;border-radius:3px;font-weight:700}.wcs-ok{background:#1db98426;color:#4ade80}.wcs-x{background:#dc26261f;color:#f87171}.wcs-am{background:#ef9f271f;color:var(--amber)}.weekly-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.scope-gate{margin:8px 0 10px;border-radius:8px;border:1px solid;padding:9px 12px}.sg-lock{background:#dc262612;border-color:#dc262640}.sg-open{background:#1db98412;border-color:#1db98440}.sg-row{display:flex;align-items:center;gap:7px}.sg-icon{width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;flex-shrink:0}.sgi-l{background:#dc262633;color:#f87171}.sgi-o{background:#1db98433;color:#4ade80}.sg-label{font-size:11px;font-weight:600}.sg-lock .sg-label{color:#f87171}.sg-open .sg-label{color:#4ade80}.sg-items{display:flex;gap:6px;margin-top:7px;flex-wrap:wrap}.sg-item{display:flex;align-items:center;gap:4px;font-size:9px;padding:2px 7px;border-radius:4px;border:1px solid}.sgi-ok{background:#1db98414;border-color:#1db98433;color:#4ade80}.sgi-no{background:#ffffff08;border-color:var(--border-primary);color:var(--text-tertiary)}.sdot{width:5px;height:5px;border-radius:50%;flex-shrink:0}.sdot-ok{background:#4ade80}.sdot-no{background:#3a4454}.tracks-grid{display:grid;gap:6px;margin-bottom:12px}.t3{grid-template-columns:repeat(3,1fr)}.t4{grid-template-columns:repeat(4,1fr)}.track-card{border-radius:7px;border:1px solid;padding:9px 10px}.tr-done{background:#1db98412;border-color:#1db98438}.tr-pend{background:#2a304066;border-color:#2a3040}.tr-warn{background:#ef9f2712;border-color:#ef9f2740}.tr-top{display:flex;align-items:flex-start;justify-content:space-between;gap:4px;margin-bottom:5px}.tr-name{font-size:10px;font-weight:600;line-height:1.3}.tr-done .tr-name{color:#4ade80}.tr-pend .tr-name{color:var(--text-tertiary)}.tr-warn .tr-name{color:var(--amber)}.tr-st{font-size:8.5px;padding:2px 5px;border-radius:3px;font-weight:600;white-space:nowrap;flex-shrink:0}.ts-done{background:#1db98426;color:#4ade80}.ts-pend{background:#ffffff0a;color:var(--text-tertiary)}.ts-warn{background:#ef9f271f;color:var(--amber)}.tr-body{font-size:9.5px;color:var(--text-tertiary);line-height:1.4}.tr-done .tr-body{color:#4a7a60}.scope-option{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:6px;padding:9px 11px}.scope-option-title{font-size:11px;font-weight:600;color:var(--text);margin-bottom:3px}.scope-option-body{font-size:10.5px;color:var(--text-secondary);line-height:1.5;margin-bottom:7px}.info-badge{font-size:10.5px;padding:7px 10px;border-radius:6px;line-height:1.5}.info-badge.teal{background:#00d4a812;border:1px solid rgba(0,212,168,.2);color:#94b4a0}.info-badge.amber{background:#ef9f2712;border:1px solid rgba(239,159,39,.2);color:#8a6530}.info-badge.grey{background:#ffffff08;border:1px solid var(--border-primary);color:var(--text-tertiary)}.gdrive-row{display:flex;align-items:center;gap:8px;padding:7px 10px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:7px;margin-bottom:5px;cursor:pointer;transition:all .12s;text-decoration:none;color:inherit}.gdrive-row:hover{border-color:var(--teal);background:#1db9840a}.gdrive-arrow{font-size:11px;color:#60a5fa;flex-shrink:0}.gdrive-tree{font-family:Courier New,monospace;font-size:11px;color:var(--text-secondary);background:var(--bg-primary);border-radius:6px;padding:10px 12px;border:1px solid var(--border-primary);line-height:1.9;margin-bottom:8px}.btn-teal{background:#00d4a81f;color:var(--teal);border:1px solid rgba(0,212,168,.25);border-radius:6px;cursor:pointer;font-weight:500;transition:all .12s}.btn-teal:hover{background:var(--teal);color:#0d1117}.btn-amber{background:#ef9f271f;color:var(--amber);border:1px solid rgba(239,159,39,.25);border-radius:6px;cursor:pointer;font-weight:500;transition:all .12s}.btn-amber:hover{background:var(--amber);color:#0d1117}.btn-sm{font-size:10px;padding:4px 10px}.fa-table{width:100%;border-collapse:collapse;font-size:10.5px;margin-bottom:8px}.fa-table th{text-align:left;padding:5px 6px;font-size:9px;font-weight:700;color:var(--text-tertiary);border-bottom:1px solid var(--border-primary);background:var(--bg-primary);text-transform:uppercase;letter-spacing:.04em}.fa-table td{padding:5px 6px;border-bottom:1px solid rgba(255,255,255,.04);color:var(--text-secondary)}.fa-total-row td{border-top:1px solid var(--border-primary);font-weight:600;padding-top:7px}.fa-picker-row{display:flex;align-items:center;gap:8px;padding:7px 4px;border-bottom:1px solid rgba(255,255,255,.04);cursor:pointer;transition:background .1s;border-radius:4px}.fa-picker-row:hover{background:#ffffff08}.fa-checkbox-row{display:flex;align-items:center;gap:7px;padding:5px 4px;cursor:pointer;border-bottom:1px solid rgba(255,255,255,.03)}.fa-checkbox-row:hover{background:#ffffff05}.btn-icon-del{background:none;border:none;color:#f87171;cursor:pointer;font-size:14px;padding:0 4px}.badge-amber{font-size:8.5px;background:#ef9f2726;color:var(--amber);padding:1px 5px;border-radius:3px}.client-portal{padding:0}.cp-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;flex-wrap:wrap;gap:12px}.cp-greeting{font-size:20px;font-weight:700;color:var(--text)}.cp-sub{font-size:11px;color:var(--text-3);margin-top:3px}.cp-stats{display:flex;gap:12px}.cp-stat{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;padding:10px 16px;text-align:center;min-width:80px}.cp-stat-val{font-size:22px;font-weight:700;color:var(--text)}.cp-stat-lbl{font-size:9px;color:var(--text-3);margin-top:2px;text-transform:uppercase;letter-spacing:.04em}.cp-loading{padding:40px;text-align:center;color:var(--text-3)}.cp-empty{padding:60px;text-align:center;color:var(--text-3)}.cp-layout{display:grid;grid-template-columns:240px 1fr;gap:12px;align-items:start}.cp-list{display:flex;flex-direction:column;gap:6px}.cp-list-title{font-size:9px;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}.cp-ticket-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;padding:10px 12px;cursor:pointer;transition:all .12s}.cp-ticket-card:hover{border-color:#3a4a5c}.cptc-top{display:flex;justify-content:space-between;align-items:center;gap:6px;margin-bottom:4px}.cptc-id{font-size:11px;font-family:monospace;color:#60a5fa;font-weight:600}.cptc-badge{font-size:9px;padding:2px 7px;border-radius:5px;font-weight:600;white-space:nowrap}.cptc-loc{font-size:10px;color:var(--text-2)}.cptc-date{font-size:9.5px;color:var(--text-3);margin-top:3px}.cp-detail{background:#0c1018;border:1px solid var(--border-primary);border-radius:10px;overflow:hidden}.cpd-header{padding:14px 16px;border-bottom:1px solid #1e2a3a;display:flex;justify-content:space-between;align-items:flex-start}.cpd-title{font-size:14px;font-weight:600;color:var(--text)}.cpd-sub{font-size:10px;color:var(--text-3);margin-top:3px}.cpd-steps{display:flex;align-items:flex-start;padding:14px 16px;border-bottom:1px solid #1e2a3a;gap:0;position:relative}.cpd-step{display:flex;flex-direction:column;align-items:center;flex:1;position:relative}.cpd-step-dot{width:28px;height:28px;border-radius:50%;border:2px solid var(--border-primary);background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--text-3);z-index:1;margin-bottom:6px;transition:all .2s}.cpd-step-dot.done{color:#0d1117}.cpd-step-dot.active{color:#0d1117;box-shadow:0 0 0 4px #00d4a826}.cpd-step-label{font-size:9px;color:var(--text-3);text-align:center;white-space:pre-line;line-height:1.3}.cpd-step-line{position:absolute;top:14px;left:calc(50% + 14px);right:calc(-50% + 14px);height:2px;z-index:0;transition:background .3s}.cpd-sections{padding:12px 16px;display:flex;flex-direction:column;gap:14px}.cpd-section-title{font-size:9px;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:8px;padding-bottom:4px;border-bottom:1px solid #1e2a3a}.cp-check-row{display:flex;align-items:center;font-size:12px;color:var(--text-2)}.cp-gdrive-row{display:flex;align-items:center;gap:8px;padding:7px 10px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:7px;text-decoration:none;color:inherit;transition:all .12s;font-size:12px}.cp-gdrive-row:hover{border-color:var(--teal);background:#1db9840a}.cp-table{width:100%;border-collapse:collapse;font-size:11px}.cp-table th{text-align:left;padding:5px 6px;font-size:9px;font-weight:700;color:var(--text-3);border-bottom:1px solid var(--border-primary);background:var(--bg-primary);text-transform:uppercase;letter-spacing:.04em}.cp-table td{padding:5px 6px;border-bottom:1px solid rgba(255,255,255,.04);color:var(--text-2)}.cp-info-badge{font-size:11px;padding:7px 10px;border-radius:6px;line-height:1.5;margin-top:4px}.cp-info-badge.teal{background:#00d4a812;border:1px solid rgba(0,212,168,.2);color:#94b4a0}.cp-info-badge.amber{background:#ef9f2712;border:1px solid rgba(239,159,39,.2);color:#8a6530}
