:root{color-scheme:light;--bg: #ffffff;--bg-elevated: #ffffff;--bg-subtle: #f7f8fa;--accent: #0066cc;--accent-hover: #0052a3;--accent-soft: rgba(0, 102, 204, .08);--pink: #e91e8c;--pink-hover: #c2185b;--pink-soft: rgba(233, 30, 140, .1);--text: #1e293b;--text-muted: #64748b;--border-subtle: #e2e8f0;--shadow: 0 1px 3px rgba(0, 0, 0, .06);--shadow-card: 0 4px 12px rgba(0, 0, 0, .06);--danger: #dc2626}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-subtle);color:var(--text);-webkit-font-smoothing:antialiased}.app{min-height:100vh;display:flex;flex-direction:column}.header{padding:1rem 2rem;border-bottom:1px solid var(--border-subtle);background:var(--bg);position:sticky;top:0;z-index:10;box-shadow:var(--shadow)}.header-inner{display:flex;align-items:center;gap:1rem}.header-logo{height:32px;width:auto;display:block}.header h1{margin:0;font-size:1.35rem;font-weight:600;letter-spacing:-.02em;color:var(--text)}.layout{display:grid;grid-template-columns:minmax(260px,320px) minmax(0,1fr);padding:1.5rem 2rem 2rem;gap:1.5rem}.sidebar,.content{display:flex;flex-direction:column;gap:1rem}.content-tabs{display:flex;gap:.25rem;margin-bottom:1rem}.content-tabs .tab{padding:.5rem 1rem;font-size:.9rem;font-weight:500;border-radius:6px;background:var(--bg-subtle);color:var(--text-muted);border:1px solid var(--border-subtle)}.content-tabs .tab:hover{background:var(--border-subtle);color:var(--text)}.content-tabs .tab.active{background:#ca005d;color:#fff;border-color:#ca005d}.content-top,.content-bottom{display:flex;flex-direction:column;gap:1rem}.card{background:var(--bg);border-radius:8px;padding:1.25rem 1.4rem;border:1px solid var(--border-subtle);box-shadow:var(--shadow-card)}.card h2{margin:0 0 .75rem;font-size:.8rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted)}select,input[type=date],input[type=number]{width:100%;padding:.5rem .65rem;border-radius:6px;border:1px solid var(--border-subtle);background:var(--bg);color:var(--text);font-size:.9rem;font-family:inherit}select:focus,input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.form-grid{display:grid;gap:.75rem}label{display:flex;flex-direction:column;gap:.25rem;font-size:.8rem;font-weight:500;color:var(--text-muted)}button{border:none;cursor:pointer;font-family:inherit}.primary{margin-top:.25rem;padding:.55rem 1rem;border-radius:6px;background:var(--accent);color:#fff;font-size:.875rem;font-weight:500;transition:background .15s ease,transform .1s ease}.primary:hover{background:var(--accent-hover);transform:translateY(-.5px)}.primary:active{transform:translateY(0)}.primary-with-pink{background:#e91e8c;color:#fff}.primary-with-pink:hover{background:#c2185b;color:#fff}.secondary{padding:.5rem .9rem;border-radius:6px;background:var(--bg-subtle);color:var(--text);border:1px solid var(--border-subtle);font-size:.875rem}.secondary:hover{background:var(--border-subtle)}.form-inline{display:flex;gap:.5rem;margin-top:.5rem}.input-inline{flex:1;padding:.45rem .6rem;border-radius:6px;border:1px solid var(--border-subtle);font-size:.9rem}.department-list{margin:0;padding-left:1.25rem;font-size:.9rem}.department-list li{margin-bottom:.25rem}.checkbox-group{border:none;padding:0;margin:0 0 .5rem}.checkbox-group legend{font-size:.8rem;font-weight:500;color:var(--text-muted);margin-bottom:.35rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;flex-direction:row;margin-bottom:.25rem;font-weight:400;cursor:pointer}.form-actions{display:flex;gap:.5rem}.btn-approve,.btn-decline{padding:.3rem .6rem;border-radius:6px;font-size:.8rem;margin-right:.35rem}.btn-approve{background:#15803d;color:#fff}.btn-approve:hover{background:#166534}.btn-decline{background:var(--danger);color:#fff}.btn-decline:hover{background:#b91c1c}.current-user-badge{font-size:.75rem;color:var(--text-muted);margin-left:auto}.current-user-badge select{margin-left:.35rem;padding:.25rem .4rem;font-size:.8rem;max-width:140px}.table{width:100%;border-collapse:collapse;font-size:.875rem}.table th,.table td{padding:.5rem;text-align:left;vertical-align:middle}.table thead th{font-weight:600;color:var(--text-muted);border-bottom:2px solid var(--border-subtle);font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;background:#f5f5f5}.th-sort{display:inline-flex;align-items:center;gap:.25rem;padding:0;margin:0;background:none;border:none;color:inherit;font:inherit;cursor:pointer}.th-sort:hover{color:var(--accent)}.sort-icon{font-size:.7rem;opacity:.7}.table tbody tr{border-bottom:1px solid var(--border-subtle)}.table tbody tr:hover{background:var(--bg-subtle)}.table tbody tr:last-child{border-bottom:none}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:1.7rem;height:1.7rem;border-radius:999px;border:1px solid var(--border-subtle);background:transparent;padding:0;margin-right:.25rem;cursor:pointer;color:#9ca3af;transition:background-color .12s ease,border-color .12s ease,color .12s ease}.icon-btn-edit,.icon-btn-cancel{border-color:var(--border-subtle)}.icon-btn:hover:not(:disabled){background:#00000008;border-color:var(--text-muted);color:var(--text-muted)}.icon-btn:disabled{opacity:.4;cursor:not-allowed}.icon-btn span{font-size:.85rem}.icon-outline{display:block;width:1rem;height:1rem}.icon-outline svg{width:100%;height:100%;display:block}.icon-cancelling{font-size:1rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.status{padding:.2rem .6rem;border-radius:6px;font-size:.75rem;font-weight:500;text-transform:capitalize}.status-approved{background:#16a34a1f;color:#15803d}.status-pending{background:#d8d8d8;color:#444}.status-rejected,.status-declined,.status-cancelled{background:#dc26261f;color:var(--danger)}.muted{color:var(--text-muted);font-size:.875rem}.balance-negative{color:var(--danger);font-weight:600}.calendar-wrapper{display:flex;flex-direction:column;gap:.5rem}.calendar-single-month .calendar-nav{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:.5rem}.calendar-single-month .calendar-month-title{margin:0;font-size:1.1rem;font-weight:600;min-width:10rem;text-align:center}.calendar-single-month .calendar-single{max-width:100%}.calendar-single-month .month-large{font-size:.9rem}.calendar-single-month .month-large .month-body{padding:.5rem .75rem .75rem}.calendar-single-month .month-large .weekday-row,.calendar-single-month .month-large .week-row{gap:.15rem}.calendar-single-month .month-large .weekday{font-size:.75rem;padding:.25rem 0}.calendar-single-month .day-large{min-height:7.5rem;padding:.35rem .4rem;flex-direction:column;align-items:flex-start;justify-content:flex-start;position:relative}.calendar-single-month .day-large.day-weekend{background:#f0f0f0}.calendar-single-month .day-large.day-today{outline:2px solid #888;outline-offset:-2px}.calendar-single-month .day-large .day-num{font-weight:600;font-size:.85rem}.calendar-single-month .day-large .day-names{margin-top:.15rem;display:flex;flex-direction:column;gap:.1rem;font-size:.7rem;line-height:1.1;overflow:hidden}.calendar-single-month .day-large .day-name-line,.calendar-single-month .day-large .day-name-more{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-single-month .day-large .day-name-more{font-weight:600}.calendar-single-month .month-large{max-width:28rem;margin:0 auto}.calendar-legend{display:flex;gap:1rem;font-size:.7rem;color:var(--text-muted)}.legend-item{display:inline-flex;align-items:center;gap:.35rem}.legend-item:before{content:"";width:.75rem;height:.75rem;border-radius:3px}.legend-approved:before{background:#16a34a33;border:1px solid rgba(22,163,74,.35)}.legend-pending:before{background:#d8d8d8;border:1px solid #bbb}.legend-public-holiday:before{background:#ca005d33;border:1px solid rgba(202,0,93,.4)}.calendar-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.75rem;font-size:.7rem}.month{border-radius:8px;border:1px solid var(--border-subtle);background:var(--bg);overflow:hidden;box-shadow:var(--shadow)}.month-header{padding:.4rem .5rem;text-align:center;font-weight:600;font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border-subtle);background:var(--bg-subtle)}.month-body{padding:.35rem .4rem .5rem}.weekday-row,.week-row{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:.05rem}.weekday{text-align:center;color:var(--text-muted);padding-bottom:.15rem;font-weight:500}.day{height:1.35rem;text-align:center;border-radius:4px;display:flex;align-items:center;justify-content:center;background:var(--bg-subtle);color:var(--text)}.day-vacation{background:linear-gradient(135deg,var(--accent-soft) 0%,var(--pink-soft) 100%);color:var(--accent);font-weight:500;border:1px solid rgba(0,102,204,.25)}.day-vacation-approved{background:#16a34a33;color:#15803d;font-weight:500;border:1px solid rgba(22,163,74,.35)}.day-vacation-pending{background:#eab30840;color:#a16207;font-weight:500;border:1px solid rgba(234,179,8,.4)}.day-public-holiday{background:#ca005d26;color:#ca005d;border:1px solid rgba(202,0,93,.35)}.dp-day.day-public-holiday{background:#ca005d26;color:#ca005d;border-color:#ca005d59}.day-public-holiday .day-holiday-name{display:block;font-size:.65rem;line-height:1.1;margin-top:.1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.day-vacation-both{background:linear-gradient(135deg,#16a34a33,#eab30840);color:#15803d;font-weight:500;border:1px solid rgba(22,163,74,.35)}.day-names{display:block;font-size:.5rem;line-height:1.1;margin-top:.05rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;font-weight:400}.card-hint-pink{border-left:3px solid var(--pink)}.day.empty{background:transparent;color:transparent}.dp-wrapper{position:relative;width:100%}.dp-label{font-size:.8rem;font-weight:500;color:var(--text-muted);margin-bottom:.1rem}.dp-input{width:100%;padding:.5rem .65rem;border-radius:6px;border:1px solid var(--border-subtle);background:var(--bg);color:var(--text-muted);font-size:.9rem;text-align:left;display:inline-flex;align-items:center;justify-content:space-between}.dp-input.has-value{color:var(--text)}.dp-input:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.dp-popup{position:absolute;z-index:20;top:calc(100% + .25rem);left:0;background:var(--bg);border-radius:8px;border:1px solid var(--border-subtle);box-shadow:var(--shadow-card);padding:.5rem .6rem .6rem}.dp-popup-portal{z-index:1000;background:var(--bg);border-radius:8px;border:1px solid var(--border-subtle);box-shadow:var(--shadow-card);padding:.5rem .6rem .6rem;max-height:calc(100vh - 16px);overflow-y:auto}.dp-calendar{min-width:14rem}.dp-calendar-nav{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.35rem}.dp-calendar-month{margin:0;font-size:.85rem;font-weight:600}.dp-calendar-grid{display:grid;grid-template-rows:auto;gap:.15rem}.dp-weekday-row,.dp-week-row{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:.05rem}.dp-weekday{font-size:.7rem;text-align:center;color:var(--text-muted)}.dp-day{height:1.7rem;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:.8rem;background:var(--bg-subtle);color:var(--text);border:1px solid transparent}.dp-day.dp-day-weekend{background:#f0f0f0}.dp-day.dp-day-today{outline:2px solid #888;outline-offset:-1px}.dp-day.dp-day-in-range{background:#0066cc14}.dp-day.dp-day-range-start,.dp-day.dp-day-range-end{background:#0066cc2e;border-color:var(--accent);color:var(--accent);font-weight:600}.dp-day.empty{background:transparent;border-color:transparent;cursor:default}.dp-day-selected{background:#0066cc29;border-color:var(--accent);color:var(--accent);font-weight:600}.dp-day:hover:not(.empty){border-color:var(--accent)}.dp-day-num{display:block}@media(max-width:1024px){.layout{grid-template-columns:minmax(0,1fr)}.calendar-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:768px){.header,.layout{padding-inline:1.25rem}.calendar-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.admin-settings{display:grid;grid-template-columns:220px minmax(0,1fr);gap:1.5rem;background:var(--bg);border-radius:8px;border:1px solid var(--border-subtle);box-shadow:var(--shadow-card);overflow:hidden}.admin-menu{display:flex;flex-direction:column;padding:.75rem 0;background:var(--bg-subtle);border-right:1px solid var(--border-subtle)}.admin-menu-item{padding:.75rem 1.25rem;text-align:left;font-size:.875rem;font-weight:500;color:var(--text-muted);background:transparent;border:none;border-left:3px solid transparent;transition:all .15s ease}.admin-menu-item:hover{color:var(--text);background:#00000008}.admin-menu-item.active{color:var(--pink);background:var(--pink-soft);border-left-color:var(--pink);font-weight:600}.admin-content{padding:1.25rem 1.5rem;overflow:auto}.admin-panel h2{margin:0 0 .5rem;font-size:1.1rem;font-weight:600;color:var(--text);text-transform:none;letter-spacing:normal}.admin-panel>.muted{margin-bottom:1rem}.admin-balance-matrix,.admin-user-table{display:flex;flex-direction:column;gap:.75rem}.table-scroll{width:100%;overflow-x:auto}@media(max-width:768px){.admin-settings{grid-template-columns:1fr}.admin-menu{flex-direction:row;overflow-x:auto;padding:0;border-right:none;border-bottom:1px solid var(--border-subtle)}.admin-menu-item{border-left:none;border-bottom:3px solid transparent;white-space:nowrap;padding:.75rem 1rem}.admin-menu-item.active{border-left-color:transparent;border-bottom-color:var(--pink)}}@media(min-width:1024px){.sidebar{position:sticky;top:6rem;align-self:flex-start;max-height:calc(100vh - 6rem);overflow-y:auto}}.pagination-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:.75rem;font-size:.8rem;color:var(--text-muted);flex-wrap:wrap}.pagination-bar label{flex-direction:row;font-size:.8rem}.pagination-bar select{width:auto;padding:.25rem .5rem}.pagination-bar button{padding:.3rem .6rem;font-size:.8rem}.pagination-bar button:disabled{opacity:.5;cursor:not-allowed}.calendar-single-month .month-large{max-width:56rem;margin:0 auto}.calendar-single-month .gantt-week-row{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:.15rem;position:relative}.calendar-single-month .gantt-bars-container{position:absolute;top:1.6rem;left:0;right:0;bottom:.3rem;display:flex;flex-direction:column;gap:.15rem;pointer-events:none;padding:0}.calendar-single-month .gantt-bar-row{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:.15rem;height:1.35rem}.gantt-bar{border-radius:4px;padding:0 .35rem;font-size:.65rem;font-weight:500;line-height:1.35rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:auto;cursor:default}.gantt-bar-approved{background:#16a34ad9;color:#fff}.gantt-bar-pending{background:#d8d8d8;color:#444}.day-overflow-badge{position:absolute;bottom:.25rem;left:.25rem;right:.25rem;font-size:.6rem;font-weight:600;color:var(--text-muted);background:#ffffffe6;padding:.1rem .25rem;border-radius:3px;text-align:center;pointer-events:auto;cursor:default;z-index:5}
