*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,sans-serif;background:#f0f2f5;color:#1a1a2e;min-height:100vh}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;font-size:1.1rem;color:#555}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;border-radius:12px;padding:40px;max-width:400px;width:100%;text-align:center;box-shadow:0 2px 12px #00000014}.login-card h1{font-size:1.5rem;margin-bottom:12px;color:#1a1a2e}.login-card p{color:#666;margin-bottom:24px;line-height:1.5}.login-btn{background:#0078d4;color:#fff;border:none;border-radius:6px;padding:12px 28px;font-size:1rem;cursor:pointer;width:100%;transition:background .2s}.login-btn:hover{background:#106ebe}.login-btn:disabled{opacity:.6;cursor:not-allowed}.mid-input{width:100%;padding:10px 14px;border:1px solid #d0d0d0;border-radius:6px;font-size:1rem;margin-bottom:12px;outline:none}.mid-input:focus{border-color:#0078d4}.auth-error{color:#d32f2f;margin-top:12px;font-size:.9rem}.logout-link{background:none;border:none;color:#0078d4;cursor:pointer;margin-top:16px;font-size:.9rem;text-decoration:underline}.dashboard{max-width:1200px;margin:0 auto;padding:0 16px}.dashboard-header{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid #e0e0e0}.header-left{display:flex;align-items:center;gap:12px}.header-left h1{font-size:1.3rem;color:#1a1a2e}.header-user{font-size:.85rem;color:#666;margin-left:12px}.header-right{display:flex;gap:8px;align-items:center}.switch-btn{background:#e8e8e8;border:none;border-radius:6px;padding:6px 14px;font-size:.85rem;cursor:pointer;transition:background .2s}.switch-btn:hover{background:#d0d0d0}.logout-btn{background:none;border:1px solid #d0d0d0;border-radius:6px;padding:6px 14px;font-size:.85rem;cursor:pointer;color:#555;transition:all .2s}.logout-btn:hover{background:#f5f5f5}.tab-nav{display:flex;gap:0;border-bottom:2px solid #e0e0e0;margin-top:8px}.tab-btn{background:none;border:none;padding:10px 20px;font-size:.95rem;cursor:pointer;color:#666;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}.tab-btn:hover{color:#1a1a2e}.tab-btn.active{color:#0078d4;border-bottom-color:#0078d4;font-weight:600}.dashboard-content{padding:20px 0}.tab-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 0;gap:0}.loadingspinner{--square: 26px;--offset: 30px;--duration: 2.4s;--delay: .2s;--timing-function: ease-in-out;--in-duration: .4s;--in-delay: .1s;--in-timing-function: ease-out;width:calc(3 * var(--offset) + var(--square));height:calc(2 * var(--offset) + var(--square));margin:0 auto 8px;position:relative}.loadingspinner .sq{display:inline-block;background:#ff8c00;border:none;border-radius:2px;width:var(--square);height:var(--square);position:absolute}.loadingspinner .sq1{left:calc(0 * var(--offset));top:calc(0 * var(--offset));animation:sq1-anim var(--duration) var(--delay) var(--timing-function) infinite,squarefadein var(--in-duration) calc(1 * var(--in-delay)) var(--in-timing-function) both}.loadingspinner .sq2{left:calc(0 * var(--offset));top:calc(1 * var(--offset));animation:sq2-anim var(--duration) var(--delay) var(--timing-function) infinite,squarefadein var(--in-duration) calc(1 * var(--in-delay)) var(--in-timing-function) both}.loadingspinner .sq3{left:calc(1 * var(--offset));top:calc(1 * var(--offset));animation:sq3-anim var(--duration) var(--delay) var(--timing-function) infinite,squarefadein var(--in-duration) calc(2 * var(--in-delay)) var(--in-timing-function) both}.loadingspinner .sq4{left:calc(2 * var(--offset));top:calc(1 * var(--offset));animation:sq4-anim var(--duration) var(--delay) var(--timing-function) infinite,squarefadein var(--in-duration) calc(3 * var(--in-delay)) var(--in-timing-function) both}.loadingspinner .sq5{left:calc(3 * var(--offset));top:calc(1 * var(--offset));animation:sq5-anim var(--duration) var(--delay) var(--timing-function) infinite,squarefadein var(--in-duration) calc(4 * var(--in-delay)) var(--in-timing-function) both}@keyframes sq1-anim{0%{left:calc(0 * var(--offset));top:calc(0 * var(--offset))}8.333%{left:calc(0 * var(--offset));top:calc(1 * var(--offset))}to{left:calc(0 * var(--offset));top:calc(1 * var(--offset))}}@keyframes sq2-anim{0%{left:calc(0 * var(--offset));top:calc(1 * var(--offset))}8.333%{left:calc(0 * var(--offset));top:calc(2 * var(--offset))}16.67%{left:calc(1 * var(--offset));top:calc(2 * var(--offset))}25.00%{left:calc(1 * var(--offset));top:calc(1 * var(--offset))}83.33%{left:calc(1 * var(--offset));top:calc(1 * var(--offset))}91.67%{left:calc(1 * var(--offset));top:calc(0 * var(--offset))}to{left:calc(0 * var(--offset));top:calc(0 * var(--offset))}}@keyframes sq3-anim{0%,to{left:calc(1 * var(--offset));top:calc(1 * var(--offset))}16.67%{left:calc(1 * var(--offset));top:calc(1 * var(--offset))}25.00%{left:calc(1 * var(--offset));top:calc(0 * var(--offset))}33.33%{left:calc(2 * var(--offset));top:calc(0 * var(--offset))}41.67%{left:calc(2 * var(--offset));top:calc(1 * var(--offset))}66.67%{left:calc(2 * var(--offset));top:calc(1 * var(--offset))}75.00%{left:calc(2 * var(--offset));top:calc(2 * var(--offset))}83.33%{left:calc(1 * var(--offset));top:calc(2 * var(--offset))}91.67%{left:calc(1 * var(--offset));top:calc(1 * var(--offset))}}@keyframes sq4-anim{0%{left:calc(2 * var(--offset));top:calc(1 * var(--offset))}33.33%{left:calc(2 * var(--offset));top:calc(1 * var(--offset))}41.67%{left:calc(2 * var(--offset));top:calc(2 * var(--offset))}50.00%{left:calc(3 * var(--offset));top:calc(2 * var(--offset))}58.33%{left:calc(3 * var(--offset));top:calc(1 * var(--offset))}to{left:calc(3 * var(--offset));top:calc(1 * var(--offset))}}@keyframes sq5-anim{0%{left:calc(3 * var(--offset));top:calc(1 * var(--offset))}50.00%{left:calc(3 * var(--offset));top:calc(1 * var(--offset))}58.33%{left:calc(3 * var(--offset));top:calc(0 * var(--offset))}66.67%{left:calc(2 * var(--offset));top:calc(0 * var(--offset))}75.00%{left:calc(2 * var(--offset));top:calc(1 * var(--offset))}to{left:calc(2 * var(--offset));top:calc(1 * var(--offset))}}@keyframes squarefadein{0%{transform:scale(.75);opacity:0}to{transform:scale(1);opacity:1}}.tab-error,.tab-empty{text-align:center;padding:40px;color:#666}.tab-error{color:#d32f2f}.loader-wrapper{position:relative;display:flex;align-items:center;justify-content:center;height:60px;width:auto;font-family:Poppins,-apple-system,sans-serif;font-size:1.6em;font-weight:600;-webkit-user-select:none;user-select:none;color:#1a1a2e}.loader{position:absolute;top:0;left:0;height:100%;width:100%;z-index:1;background-color:transparent;mask:repeating-linear-gradient(90deg,transparent 0,transparent 6px,black 7px,black 8px)}.loader:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-image:radial-gradient(circle at 50% 50%,#ff0 0%,transparent 50%),radial-gradient(circle at 45% 45%,#f00 0%,transparent 45%),radial-gradient(circle at 55% 55%,#0ff 0%,transparent 45%),radial-gradient(circle at 45% 55%,#0f0 0%,transparent 45%),radial-gradient(circle at 55% 45%,#00f 0%,transparent 45%);mask:radial-gradient(circle at 50% 50%,transparent 0%,transparent 10%,black 25%);animation:loader-transform .5s infinite alternate,loader-opacity .9s infinite;animation-timing-function:cubic-bezier(.6,.8,.5,1)}@keyframes loader-transform{0%{transform:translate(-55%)}to{transform:translate(55%)}}@keyframes loader-opacity{0%,to{opacity:0}8%{opacity:1}75%{opacity:0}}.loader-letter{display:inline-block;opacity:0;animation:loader-letter-anim 2s infinite linear;z-index:2}@keyframes loader-letter-anim{0%{opacity:0}5%{opacity:1;text-shadow:0 0 4px #1a1a2e;transform:scale(1.1) translateY(-2px)}20%{opacity:.2}to{opacity:0}}.spin-loader{position:relative;width:2.5em;height:2.5em;transform:rotate(165deg);margin-top:16px}.spin-loader:before,.spin-loader:after{content:"";position:absolute;top:50%;left:50%;display:block;width:.5em;height:.5em;border-radius:.25em;transform:translate(-50%,-50%)}.spin-loader:before{animation:spin-before 2s infinite}.spin-loader:after{animation:spin-after 2s infinite}@keyframes spin-before{0%{width:.5em;box-shadow:1em -.5em #e11462bf,-1em .5em #6fcadcbf}35%{width:2.5em;box-shadow:0 -.5em #e11462bf,0 .5em #6fcadcbf}70%{width:.5em;box-shadow:-1em -.5em #e11462bf,1em .5em #6fcadcbf}to{box-shadow:1em -.5em #e11462bf,-1em .5em #6fcadcbf}}@keyframes spin-after{0%{height:.5em;box-shadow:.5em 1em #3db88fbf,-.5em -1em #e9a920bf}35%{height:2.5em;box-shadow:.5em 0 #3db88fbf,-.5em 0 #e9a920bf}70%{height:.5em;box-shadow:.5em -1em #3db88fbf,-.5em 1em #e9a920bf}to{box-shadow:.5em 1em #3db88fbf,-.5em -1em #e9a920bf}}.speeder-wrap{position:relative;width:220px;height:60px;margin-top:20px;overflow:hidden}.speeder-loader{position:absolute;top:50%;left:50%;margin-left:-50px;animation:speeder .4s linear infinite}.speeder-loader>span{height:5px;width:35px;background:#000;position:absolute;top:-19px;left:60px;border-radius:2px 10px 1px 0}.speeder-base span{position:absolute;width:0;height:0;border-top:6px solid transparent;border-right:100px solid #000;border-bottom:6px solid transparent}.speeder-base span:before{content:"";height:22px;width:22px;border-radius:50%;background:#000;position:absolute;right:-110px;top:-16px}.speeder-base span:after{content:"";position:absolute;width:0;height:0;border-top:0 solid transparent;border-right:55px solid #000;border-bottom:16px solid transparent;top:-16px;right:-98px}.speeder-face{position:absolute;height:12px;width:20px;background:#000;border-radius:20px 20px 0 0;transform:rotate(-40deg);right:-125px;top:-15px}.speeder-face:after{content:"";height:12px;width:12px;background:#000;right:4px;top:7px;position:absolute;transform:rotate(40deg);transform-origin:50% 50%;border-radius:0 0 0 2px}.speeder-loader>span>span:nth-child(1),.speeder-loader>span>span:nth-child(2),.speeder-loader>span>span:nth-child(3),.speeder-loader>span>span:nth-child(4){width:30px;height:1px;background:#000;position:absolute;animation:fazer1 .2s linear infinite}.speeder-loader>span>span:nth-child(2){top:3px;animation:fazer2 .4s linear infinite}.speeder-loader>span>span:nth-child(3){top:1px;animation:fazer3 .4s linear infinite;animation-delay:-1s}.speeder-loader>span>span:nth-child(4){top:4px;animation:fazer4 1s linear infinite;animation-delay:-1s}@keyframes fazer1{0%{left:0}to{left:-80px;opacity:0}}@keyframes fazer2{0%{left:0}to{left:-100px;opacity:0}}@keyframes fazer3{0%{left:0}to{left:-50px;opacity:0}}@keyframes fazer4{0%{left:0}to{left:-150px;opacity:0}}@keyframes speeder{0%{transform:translate(2px,1px) rotate(0)}10%{transform:translate(-1px,-3px) rotate(-1deg)}20%{transform:translate(-2px) rotate(1deg)}30%{transform:translate(1px,2px) rotate(0)}40%{transform:translate(1px,-1px) rotate(1deg)}50%{transform:translate(-1px,3px) rotate(-1deg)}60%{transform:translate(-1px,1px) rotate(0)}70%{transform:translate(3px,1px) rotate(-1deg)}80%{transform:translate(-2px,-1px) rotate(1deg)}90%{transform:translate(2px,1px) rotate(0)}to{transform:translate(1px,-2px) rotate(-1deg)}}.speeder-longfazers{position:absolute;width:100%;height:100%;top:0;left:0}.speeder-longfazers span{position:absolute;height:2px;width:20%;background:#000}.speeder-longfazers span:nth-child(1){top:20%;animation:lf .6s linear infinite;animation-delay:-5s}.speeder-longfazers span:nth-child(2){top:40%;animation:lf2 .8s linear infinite;animation-delay:-1s}.speeder-longfazers span:nth-child(3){top:60%;animation:lf3 .6s linear infinite}.speeder-longfazers span:nth-child(4){top:80%;animation:lf4 .5s linear infinite;animation-delay:-3s}@keyframes lf{0%{left:200%}to{left:-200%;opacity:0}}@keyframes lf2{0%{left:200%}to{left:-200%;opacity:0}}@keyframes lf3{0%{left:200%}to{left:-100%;opacity:0}}@keyframes lf4{0%{left:200%}to{left:-100%;opacity:0}}.truck-loader{width:fit-content;height:fit-content;display:flex;align-items:center;justify-content:center;margin-top:20px}.truckWrapper{width:200px;height:100px;display:flex;flex-direction:column;position:relative;align-items:center;justify-content:flex-end;overflow-x:hidden}.truckBody{width:130px;height:fit-content;margin-bottom:6px;animation:truckMotion 1s linear infinite}@keyframes truckMotion{0%{transform:translateY(0)}50%{transform:translateY(3px)}to{transform:translateY(0)}}.truckTires{width:130px;height:fit-content;display:flex;align-items:center;justify-content:space-between;padding:0 10px 0 15px;position:absolute;bottom:0}.truckTires svg{width:24px}.road{width:100%;height:1.5px;background-color:#282828;position:relative;bottom:0;align-self:flex-end;border-radius:3px}.road:before{content:"";position:absolute;width:20px;height:100%;background-color:#282828;right:-50%;border-radius:3px;animation:roadAnimation 1.4s linear infinite;border-left:10px solid white}.road:after{content:"";position:absolute;width:10px;height:100%;background-color:#282828;right:-65%;border-radius:3px;animation:roadAnimation 1.4s linear infinite;border-left:4px solid white}.lampPost{position:absolute;bottom:0;right:-90%;height:90px;animation:roadAnimation 1.4s linear infinite}@keyframes roadAnimation{0%{transform:translate(0)}to{transform:translate(-350px)}}.section-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:#888;margin-bottom:8px}.bucket-cards-section{margin-bottom:20px}.bucket-cards-row{display:flex;gap:8px;flex-wrap:wrap}.bucket-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:10px 14px;min-width:80px;cursor:pointer;text-align:center;transition:all .2s;flex:1}.bucket-card:hover{box-shadow:0 2px 8px #00000014}.bucket-card.active{border-color:#0078d4;box-shadow:0 0 0 2px #0078d433}.bucket-card.total{background:#e8f0fe;border-color:#b0c4de}.bucket-card.lt5{border-left:3px solid #4caf50}.bucket-card.d5_9{border-left:3px solid #ff9800}.bucket-card.d10_14{border-left:3px solid #f44336}.bucket-card.d15plus{border-left:3px solid #9c27b0}.bucket-card.d30plus{border-left:3px solid #673ab7}.bucket-card.d90plus{border-left:3px solid #3f51b5}.bucket-label{font-size:.7rem;color:#666;text-transform:uppercase;letter-spacing:.5px}.bucket-value{font-size:1.3rem;font-weight:700;margin-top:2px;color:#1a1a2e}.my-cases-topbar{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px;gap:12px}.status-toggle{display:flex;align-items:center;gap:4px}.toggle-btn{background:#f0f0f0;border:1px solid #d0d0d0;border-radius:6px;padding:6px 16px;font-size:.85rem;cursor:pointer;transition:all .2s}.toggle-btn.active{background:#0078d4;color:#fff;border-color:#0078d4}.case-count{margin-left:auto;font-size:.85rem;color:#888}.download-btn{background:#fff;border:1px solid #0078d4;color:#0078d4;border-radius:6px;padding:6px 14px;font-size:.85rem;cursor:pointer;margin-left:8px;transition:all .2s}.download-btn:hover{background:#e8f0fe}.download-btn:disabled{opacity:.4;cursor:not-allowed}.period-label{font-size:1.05rem;color:#1a1a2e}.last-refreshed{display:block;font-size:.78rem;color:#888;font-weight:400;margin-top:2px}.kpi-cards{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:20px}.kpi-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:14px 18px;min-width:130px;flex:1;text-align:center;box-shadow:0 1px 3px #0000000a}.kpi-label{font-size:.72rem;color:#666;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.kpi-value{font-size:1.4rem;font-weight:700;color:#1a1a2e}.kpi-sub{font-size:.7rem;color:#999;margin-top:2px}.cases-table-wrapper{overflow-x:auto}.cases-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 4px #0000000f}.cases-table th{background:#f8f9fa;padding:10px 12px;text-align:left;font-size:.8rem;color:#555;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e0e0e0;white-space:nowrap}.cases-table td{padding:10px 12px;font-size:.88rem;border-bottom:1px solid #f0f0f0;white-space:nowrap}.cases-table tbody tr:hover{background:#f8f9fa}.cases-table .missed-highlight{background:#fff8e1}.cases-table .missed-highlight:hover{background:#fff3cd}.sr-cell{font-family:Courier New,monospace;font-size:.85rem}.remarks-cell{white-space:normal!important;word-break:break-word;min-width:140px;max-width:260px;line-height:1.45}.empty-row{text-align:center;color:#999;padding:24px!important}.bucket-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:600}.bucket-badge.lt5{background:#e8f5e9;color:#2e7d32}.bucket-badge.d5_9{background:#fff3e0;color:#e65100}.bucket-badge.d10_14{background:#ffebee;color:#c62828}.bucket-badge.d15plus{background:#f3e5f5;color:#6a1b9a}.rating-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:600;white-space:nowrap}.rating-tb{background:#e8f5e9;color:#2e7d32}.rating-mb{background:#fff3e0;color:#e65100}.rating-bb{background:#ffebee;color:#c62828}.cvr-up,.cvr-down{font-size:1rem}.missed-btn{background:#fff3e0;border:1px solid #ff9800;border-radius:4px;padding:2px 10px;cursor:pointer;font-size:.85rem;font-weight:600;color:#e65100}.missed-btn:hover{background:#ffe0b2}.missed-dates-row td{background:#fafafa;padding:8px 12px!important}.missed-dates{font-size:.82rem;color:#555}.scores-table-wrapper{overflow-x:auto;margin-bottom:24px}.scores-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 4px #0000000f}.scores-table th{background:#0078d4;color:#fff;padding:10px 14px;text-align:center;font-size:.82rem;font-weight:600;white-space:nowrap;border-right:1px solid rgba(255,255,255,.2)}.scores-table th:last-child{border-right:none}.scores-table td{padding:10px 14px;font-size:.9rem;text-align:center;border-bottom:1px solid #e0e0e0;border-right:1px solid #f0f0f0;white-space:nowrap}.scores-table td:last-child{border-right:none}.scores-table tbody tr:hover{background:#f0f7ff}.scores-table .date-cell{text-align:left;font-weight:500;min-width:140px}.charts-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.mini-chart{background:#fff;border-radius:8px;padding:12px 16px;box-shadow:0 1px 4px #0000000f}.mini-chart-title{font-weight:600;font-size:.95rem;text-align:center;margin-bottom:8px;color:#1a1a2e}.mini-chart-svg{width:100%;height:auto}.sub-tab-nav{display:flex;gap:0;margin-bottom:20px;border-bottom:1px solid #e0e0e0}.sub-tab-btn{background:none;border:none;padding:8px 18px;font-size:.9rem;cursor:pointer;color:#666;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .2s}.sub-tab-btn:hover{color:#1a1a2e}.sub-tab-btn.active{color:#0078d4;border-bottom-color:#0078d4;font-weight:600}.module-form{background:#fff;border-radius:8px;padding:24px;max-width:640px;box-shadow:0 1px 4px #0000000f}.form-title{font-size:1.1rem;color:#1a1a2e;margin-bottom:16px}.form-note{font-size:.82rem;color:#888;margin-bottom:16px;font-style:italic}.form-row{display:flex;gap:16px}.form-row .form-group{flex:1}.form-group{margin-bottom:14px}.form-group label{display:block;font-size:.82rem;font-weight:600;color:#444;margin-bottom:4px}.required{color:#d32f2f}.form-group input,.form-group select,.form-group textarea{width:100%;padding:8px 12px;border:1px solid #d0d0d0;border-radius:6px;font-size:.9rem;font-family:inherit;outline:none;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#0078d4}.readonly-input{background:#f5f5f5;color:#888;cursor:not-allowed}.form-info{font-size:.88rem;color:#555;margin-bottom:14px;padding:8px 12px;background:#f0f7ff;border-radius:6px}.form-message{padding:10px 14px;border-radius:6px;margin-bottom:16px;font-size:.88rem}.form-message.success{background:#e8f5e9;color:#2e7d32;border:1px solid #c8e6c9}.form-message.error{background:#ffebee;color:#c62828;border:1px solid #ffcdd2}.file-upload{font-size:.85rem}.submit-btn{background:#0078d4;color:#fff;border:none;border-radius:6px;padding:10px 24px;font-size:.92rem;cursor:pointer;transition:background .2s}.submit-btn:hover{background:#106ebe}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.section-header h3{font-size:1rem;color:#1a1a2e}.filter-bar{display:flex;gap:12px;align-items:flex-end;margin-bottom:16px;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:4px}.filter-group label{font-size:.78rem;font-weight:600;color:#666}.filter-group input,.filter-group select{padding:6px 10px;border:1px solid #d0d0d0;border-radius:6px;font-size:.88rem;outline:none}.filter-group input:focus,.filter-group select:focus{border-color:#0078d4}.filter-btn{background:#0078d4;color:#fff;border:none;border-radius:6px;padding:7px 16px;font-size:.85rem;cursor:pointer;transition:background .2s}.filter-btn:hover{background:#106ebe}.action-link{display:inline-block;background:#e8f0fe;border:1px solid #c2d4f8;color:#1a5fbd;cursor:pointer;font-size:.78rem;font-weight:500;padding:3px 10px;border-radius:4px;text-decoration:none;transition:background .15s,border-color .15s}.action-link:hover{background:#d0e2ff;border-color:#1a5fbd}.action-link:disabled{opacity:.5;cursor:not-allowed}.action-link-danger{background:#fdecea;border-color:#f5a8a8;color:#c62828}.action-link-danger:hover{background:#f9c4c4;border-color:#c62828}.action-link-danger:disabled{opacity:.5;cursor:not-allowed}.action-cell{display:flex;gap:6px;align-items:center}.action-link-change{display:inline-block;background:#fdecea;border:1px solid #f5a8a8;color:#c62828;cursor:pointer;font-size:.78rem;font-weight:500;padding:3px 10px;border-radius:4px;text-decoration:none;transition:background .15s,border-color .15s}.action-link-change:hover{background:#f9c4c4;border-color:#c62828}.action-link-change:disabled{opacity:.5;cursor:not-allowed}.status-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:600}.status-badge.status-approved{background:#e8f5e9;color:#2e7d32}.status-badge.status-pending{background:#fff3e0;color:#e65100}.status-badge.status-rejected{background:#ffebee;color:#c62828}.detail-view{background:#fff;border-radius:8px;padding:24px;box-shadow:0 1px 4px #0000000f}.back-btn{background:none;border:none;color:#0078d4;cursor:pointer;font-size:.9rem;margin-bottom:16px;padding:0}.back-btn:hover{color:#106ebe}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.detail-item{display:flex;flex-direction:column;gap:2px}.detail-item.full-width{grid-column:1 / -1}.detail-label{font-size:.75rem;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.4px}.detail-value{font-size:.92rem;color:#1a1a2e}.leave-application-layout{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start;width:100%}.leave-policy-panel{position:sticky;top:20px}.leave-form-panel{background:#fff;border-radius:8px;padding:24px;display:flex;flex-direction:column;gap:0}.leave-policy-card{border:1px solid #c9d6f0;border-radius:8px;overflow:hidden}.leave-policy-header{background:#dce8fb;padding:8px 14px;font-size:.75rem;font-weight:700;color:#2d4e8a;text-transform:uppercase;letter-spacing:.6px}.leave-policy-body{background:#f4f8ff;padding:12px 14px;display:flex;flex-direction:column;gap:9px}.leave-policy-item{display:flex;gap:10px;align-items:flex-start;font-size:.81rem;color:#444;line-height:1.55}.policy-tag{display:inline-block;flex-shrink:0;padding:2px 8px;border-radius:3px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px;margin-top:1px}.policy-planned{background:#e8f5e9;color:#2e7d32}.policy-emergency{background:#ffebee;color:#c62828}.policy-casual{background:#fff3e0;color:#e65100}.leave-policy-note{font-size:.78rem;color:#888;font-style:italic;padding-top:2px}.leave-form-section{background:#fafafa;border:1px solid #e8e8e8;border-radius:8px;padding:14px 16px;margin-bottom:14px}.leave-form-section-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:#999;margin-bottom:12px}.days-preview{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;border-radius:6px;margin-top:6px}.days-preview-ok{background:#e8f5e9;border:1px solid #c8e6c9}.days-preview-warn{background:#fff3e0;border:1px solid #ffe0b2}.days-preview-label{font-size:.82rem;font-weight:600;color:#555}.days-preview-value{font-size:1.15rem;font-weight:700;color:#1a1a2e}.emergency-indicator{background:#ffebee;color:#c62828;border:1px solid #ffcdd2;border-radius:6px;padding:8px 12px;font-size:.88rem;font-weight:600}.emergency-indicator-note{font-size:.78rem;font-weight:400;color:#888}.cl-balance-card{background:#f0f7ff;border:1px solid #c9d6f0;border-radius:6px;margin-bottom:14px;overflow:hidden}.cl-balance-month-label{padding:5px 14px;font-size:.75rem;font-weight:600;color:#2d4e8a;background:#dce8fb;border-bottom:1px solid #c9d6f0}.cl-balance-row{display:flex;align-items:center}.cl-balance-item{display:flex;flex-direction:column;align-items:center;flex:1;padding:10px 8px;gap:3px}.cl-balance-divider{width:1px;align-self:stretch;background:#c9d6f0}.cl-balance-label{font-size:.7rem;color:#888;text-transform:uppercase;letter-spacing:.4px}.cl-balance-val{font-size:1.15rem;font-weight:700;color:#1a1a2e}.cl-balance-remaining{color:#2e7d32!important}.cl-balance-insufficient{color:#c62828!important}.cl-balance-card-warn .cl-balance-month-label{background:#ffebee;border-bottom-color:#ffcdd2;color:#c62828}.cl-balance-card-warn{border-color:#ffcdd2}.cl-balance-days-tag{float:right;font-size:.72rem;font-weight:400;opacity:.85}.days-preview-breakdown{display:block;font-size:.75rem;font-weight:400;color:#666;margin-top:2px}.form-label-note{font-weight:400;font-size:.78rem;color:#999}.file-upload-area{display:flex;align-items:center;gap:10px}.file-upload-btn{display:inline-block;padding:6px 14px;background:#fff;border:1px solid #c0c0c0;border-radius:6px;font-size:.83rem;color:#444;cursor:pointer;transition:background .2s,border-color .2s;white-space:nowrap}.file-upload-btn:hover{background:#f0f0f0;border-color:#0078d4;color:#0078d4}.file-upload-hidden{display:none}.file-upload-name{font-size:.82rem;color:#666;font-style:italic}.leave-submit-btn{width:100%;padding:12px;font-size:.95rem}.cl-block-notice{background:#ffebee;border:1px solid #ffcdd2;border-radius:6px;padding:9px 14px;font-size:.83rem;color:#c62828;margin-bottom:10px;line-height:1.5}@media(max-width:768px){.tab-nav{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tab-nav::-webkit-scrollbar{display:none}.tab-btn{white-space:nowrap;flex-shrink:0}.dashboard-header{flex-direction:column;align-items:flex-start;gap:8px}.header-user{margin-left:0;display:block}.my-cases-topbar{flex-direction:column}.bucket-card{min-width:70px;padding:8px 10px}.bucket-value{font-size:1.1rem}.charts-row{grid-template-columns:1fr}.form-row{flex-direction:column;gap:0}.detail-grid{grid-template-columns:1fr}.module-form,.detail-view{padding:16px}.section-header{flex-direction:column;align-items:flex-start;gap:8px}.leave-application-layout{grid-template-columns:1fr}.leave-policy-panel{position:static}.leave-form-panel{padding:16px}}.screen-loader-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#ffffff8c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:9999;pointer-events:all}.screen-loader-spinner{width:44px;height:44px;border:4px solid #d0d9f0;border-top-color:#2d4e8a;border-radius:50%;animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal-card{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000002e;width:100%;max-width:560px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px 14px;border-bottom:1px solid #e8eaed}.modal-title{font-size:1.05rem;font-weight:600;color:#1a1a2e;margin:0}.modal-close{background:none;border:none;font-size:1.4rem;line-height:1;color:#888;cursor:pointer;padding:0 4px}.modal-close:hover{color:#333}.modal-body{padding:20px 24px;overflow-y:auto}.error-modal-card{max-width:420px;border-top:4px solid #d32f2f}.error-modal-header{background:#fff5f5;border-bottom:1px solid #ffd0d0;gap:10px}.error-modal-icon{font-size:1.4rem;color:#d32f2f;line-height:1}.error-modal-header .modal-title{color:#d32f2f;flex:1}.error-modal-body{color:#333;font-size:.95rem;line-height:1.6}.error-modal-footer{padding:12px 24px 18px;display:flex;justify-content:flex-end}.error-modal-dismiss{background:#d32f2f;color:#fff;border:none;border-radius:6px;padding:8px 22px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .15s}.error-modal-dismiss:hover{background:#b71c1c}.header-logo{height:44px;object-fit:contain}.profile-dropdown{position:relative}.profile-avatar{width:34px;height:34px;border-radius:50%;background:#3b82f6;color:#fff;border:none;font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:box-shadow .15s}.profile-avatar:hover{box-shadow:0 0 0 3px #3b82f640}.profile-menu{position:absolute;top:calc(100% + 6px);right:0;background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 10px 30px #0000001f;min-width:240px;z-index:100;overflow:hidden}.profile-menu-header{padding:14px 16px}.profile-menu-name{font-weight:700;font-size:14px;color:#1e293b;margin-bottom:4px}.profile-menu-detail{font-size:12px;color:#64748b;line-height:1.5}.impersonate-tag{display:inline-block;background:#f59e0b;color:#1e293b;padding:1px 8px;border-radius:10px;font-size:11px;font-weight:600;margin-top:6px}.profile-menu-divider{height:1px;background:#e2e8f0}.profile-menu-item{display:block;width:100%;text-align:left;padding:10px 16px;border:none;background:none;font-size:13px;color:#334155;cursor:pointer}.profile-menu-item:hover{background:#f1f5f9}.manual-link{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border:1px solid #e2e8f0;border-radius:6px;font-size:13px;font-weight:500;color:#334155;text-decoration:none;transition:background .15s,border-color .15s}.manual-link:hover{background:#eff6ff;border-color:#3b82f6;color:#2563eb}.bug-report-trigger{background:none;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;font-size:16px;line-height:1;padding:3px 7px;transition:background .15s,border-color .15s}.bug-report-trigger:hover{background:#fef3c7;border-color:#f59e0b}.bug-report-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.bug-report-modal{background:#fff;border-radius:12px;width:480px;max-width:92vw;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.bug-report-header{display:flex;justify-content:space-between;align-items:center;padding:18px 20px 12px;border-bottom:1px solid #e2e8f0}.bug-report-header h3{font-size:16px;color:#1e293b}.bug-report-close-btn{background:none;border:none;font-size:22px;color:#94a3b8;cursor:pointer;padding:0 4px}.bug-report-close-btn:hover{color:#475569}.bug-report-form{padding:16px 20px 20px;display:flex;flex-direction:column;gap:10px}.bug-report-form label{font-size:13px;font-weight:600;color:#334155;margin-bottom:-4px}.bug-report-form select,.bug-report-form input[type=text],.bug-report-form textarea{width:100%;padding:8px 10px;border:1px solid #cbd5e1;border-radius:6px;font-size:13px;font-family:inherit;outline:none;transition:border-color .15s;box-sizing:border-box}.bug-report-form select:focus,.bug-report-form input[type=text]:focus,.bug-report-form textarea:focus{border-color:#2563eb}.bug-report-form textarea{resize:vertical;min-height:80px}.bug-report-file-row{display:flex;align-items:center;gap:6px}.bug-report-file-btn{flex:1;padding:7px 10px;border:1px dashed #cbd5e1;border-radius:6px;background:#f8fafc;font-size:13px;color:#64748b;cursor:pointer;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bug-report-file-btn:hover{border-color:#94a3b8;background:#f1f5f9}.bug-report-file-clear{background:none;border:none;font-size:18px;color:#94a3b8;cursor:pointer;padding:0 4px}.bug-report-file-clear:hover{color:#dc2626}.bug-report-error{color:#dc2626;font-size:13px;margin:0;padding:4px 0}.bug-report-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}.bug-report-cancel-btn{padding:8px 16px;border:1px solid #cbd5e1;border-radius:6px;background:#fff;font-size:13px;cursor:pointer;color:#475569}.bug-report-cancel-btn:hover{background:#f1f5f9}.bug-report-submit-btn{padding:8px 20px;border:none;border-radius:6px;background:#2563eb;color:#fff;font-size:13px;font-weight:600;cursor:pointer}.bug-report-submit-btn:hover{background:#1d4ed8}.bug-report-submit-btn:disabled{background:#94a3b8;cursor:not-allowed}
