:root{font-family:Segoe UI,Trebuchet MS,Arial,sans-serif;line-height:1.5;font-weight:400;color:#14213d;background:radial-gradient(circle at top left,#f0f7ff,#f9fbfd 45%,#f5f5f5);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg-surface: #ffffff;--bg-muted: #f4f6fb;--border: #d9e1ee;--text: #14213d;--muted: #5b6780;--primary: #0f6cbd;--primary-strong: #0a5a9f;--success: #157347;--danger: #b02a37;--danger-bg: #fdecef;--success-bg: #e9f8ef;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--shadow-sm: 0 6px 16px rgba(15, 40, 80, .08);--focus-ring: 0 0 0 3px rgba(15, 108, 189, .22)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;color:var(--text);background:transparent;overflow-x:hidden}#root{min-height:100vh}a{color:inherit}button,input,select,textarea{font:inherit}button,input,select,textarea{border:1px solid var(--border);border-radius:10px;padding:10px 12px;background:#fff}button{cursor:pointer}button:disabled{opacity:.65;cursor:not-allowed}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,a:focus-visible{outline:none;box-shadow:var(--focus-ring)}.primary-btn{border:1px solid var(--primary);background:var(--primary);color:#fff}.primary-btn:hover{background:var(--primary-strong)}.ghost-btn{border:1px solid var(--border);background:var(--bg-surface);color:var(--text)}.danger-btn{border:1px solid var(--danger);background:var(--danger);color:#fff;box-shadow:0 6px 14px #b02a372e}.danger-btn:hover{filter:brightness(.96)}.success-btn{border:1px solid #1f8f5f;background:#1f8f5f;color:#fff}.success-btn:hover{background:#16784f}.warning-btn{border:1px solid #c78217;background:#c78217;color:#fff}.warning-btn:hover{background:#a96c11}.muted{color:var(--muted)}.center-page{min-height:100vh;display:grid;place-items:center}.auth-page{min-height:100vh;display:grid;place-items:center;padding:20px}.auth-card{width:min(420px,100%);border:1px solid var(--border);border-radius:16px;background:var(--bg-surface);padding:20px;box-shadow:0 14px 36px #0f285014}.auth-form{display:grid;gap:10px}.permission-splash{display:grid;gap:12px}.splash-logo{width:132px;height:132px;margin:0 auto;border-radius:22px;overflow:hidden;box-shadow:0 14px 34px #0f285038}.splash-logo img{width:100%;height:100%;object-fit:cover;display:block}.perm-grid{display:grid;gap:8px}.perm-step{display:grid;grid-template-columns:18px 1fr;gap:10px;align-items:center;padding:10px;border-radius:10px;border:1px solid var(--border);background:#fff;transition:all .14s ease}.perm-step-title{font-weight:600}.perm-step-detail{font-size:12px;color:var(--muted)}.perm-step-icon{width:14px;height:14px;border-radius:999px;border:2px solid #bcc7d9}.perm-step.pending{background:#f5f9ff;border-color:#c6d9f3}.perm-step.pending .perm-step-icon{border-color:#0f6cbd transparent #0f6cbd transparent;animation:spin .7s linear infinite}.perm-step.success{background:var(--success-bg);border-color:#b8e6c8}.perm-step.success .perm-step-icon{background:var(--success);border-color:var(--success)}.perm-step.error{background:#fff4f4;border-color:#f0c4c9}.perm-step.error .perm-step-icon{background:var(--danger);border-color:var(--danger)}.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh;align-items:start}.app-sidebar{border-right:1px solid var(--border);background:var(--bg-surface);padding:16px;display:grid;grid-template-rows:auto auto 1fr auto;gap:14px;position:sticky;top:0;align-self:start;height:100vh;overflow-x:hidden;overflow-y:auto}.sidebar-header{display:flex;justify-content:space-between;align-items:center}.brand{font-weight:800;letter-spacing:.02em}.user-summary{border:1px solid var(--border);background:linear-gradient(145deg,#f7faff,#eef4ff);border-radius:12px;padding:10px;font-size:13px;display:grid;grid-template-columns:40px 1fr;gap:10px;align-items:center}.user-avatar{width:40px;height:40px;border-radius:999px;display:grid;place-items:center;font-weight:700;color:#fff;background:linear-gradient(145deg,#0f6cbd,#0a4f91);box-shadow:0 8px 20px #0f6cbd40}.user-meta{min-width:0;display:grid;gap:2px}.user-name{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role-badge{justify-self:start;border:1px solid #c3d6f2;background:#e9f2ff;color:#184b82;border-radius:999px;font-size:11px;line-height:1;padding:5px 8px}.user-subtle{color:var(--muted);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-nav{display:grid;gap:10px;align-content:start;min-height:auto;overflow:visible;padding-right:0}.nav-group{display:grid;gap:6px}.nav-group-title{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#6a768f;padding:0 4px}.nav-group-links{display:grid;gap:6px}.nav-link{text-decoration:none;border-radius:10px;padding:10px 12px;border:1px solid transparent}.nav-link:hover{background:var(--bg-muted)}.nav-link.active{border-color:#b7c6de;background:linear-gradient(145deg,#eaf2ff,#ddeaff);font-weight:600}.sidebar-logout{width:100%}.sidebar-version{margin-top:6px;font-size:12px;text-align:center}.content-shell{min-width:0;position:relative}.mobile-header{display:flex;justify-content:flex-start;gap:12px;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);background:#fffffff5;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);min-height:64px;position:sticky;top:0;z-index:25}.app-content{padding:18px}.status-banner-stack{position:fixed;left:12px;bottom:12px;z-index:130;display:grid;gap:8px;width:min(460px,calc(100vw - 24px))}.system-update-overlay{position:fixed;inset:0;z-index:140;background:#ffffffeb;display:grid;place-items:center;padding:16px}.status-banner{border:1px solid var(--border);background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:10px}.status-banner-actions{display:inline-flex;align-items:center;gap:8px}.status-banner-close{border:0;background:transparent;color:inherit;padding:0 4px;min-height:unset;font-size:18px;line-height:1;opacity:.85}.status-banner-close:hover{opacity:1}.status-banner-warning{border-color:#f3d19c;background:#fffaf2;color:#9a5b00}.status-banner-info{border-color:#c6d9f3;background:#f5f9ff;color:#245281}.status-banner-success{border-color:#b8e6c8;background:var(--success-bg);color:#0d5d35}.panel-card{border:1px solid var(--border);border-radius:14px;background:var(--bg-surface);padding:16px;box-shadow:var(--shadow-sm)}.panel-card>h3:first-child:not(.modal-title),.panel-card>h4:first-child:not(.modal-title){margin:0 0 8px;padding:0 0 10px;border-bottom:1px solid #e8edf6;display:flex;align-items:center;gap:8px;color:#1a2f4c}.panel-card>h3:first-child:not(.modal-title):before,.panel-card>h4:first-child:not(.modal-title):before{content:"";width:8px;height:8px;border-radius:999px;background:linear-gradient(180deg,var(--primary),#5ea0ea);box-shadow:0 0 0 4px #0f6cbd1a}.page-title{margin:0 0 12px;display:flex;align-items:center;justify-content:center;gap:10px;text-align:center;color:#12243d;font-size:22px;line-height:1.2;font-weight:800;letter-spacing:.01em}.page-title:before{content:"";width:6px;height:22px;border-radius:999px;background:linear-gradient(180deg,var(--primary),#5ea0ea);box-shadow:0 2px 8px #0f6cbd40}.page-title-left{justify-content:flex-start;text-align:left}.page-subtitle{margin:-4px 0 10px;color:var(--muted);font-size:13px;line-height:1.45;text-align:center}.page-subtitle-left{text-align:left}.quick-grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));align-items:stretch}.quick-groups{display:grid;gap:12px}.quick-group{display:grid;gap:8px}.quick-group-head{display:flex;align-items:end;justify-content:space-between;gap:10px;padding:0 4px}.quick-group-title{margin:0;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#6a768f}.quick-group-subtitle{margin-top:2px;font-size:12px;color:#4f6079}.quick-group-badge{border:1px solid #c9d7ea;background:#eef4ff;color:#32537e;border-radius:999px;font-size:11px;line-height:1;padding:4px 8px;font-weight:700}.quick-group .quick-grid{padding-top:2px}.dashboard-stats{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.dashboard-stat-link{text-decoration:none}.dashboard-stat-card{min-height:118px;display:grid;gap:4px;align-content:start;position:relative;overflow:hidden;border-color:#cdd9eb;background:linear-gradient(145deg,#f8fbff,#f0f6ff)}.dashboard-stat-card:before{content:"";position:absolute;inset:0 auto 0 0;width:4px;background:#4d84ce}.dashboard-stat-card.warning:before{background:#ce8d2f}.dashboard-stat-card.success:before{background:#2f8f62}.dashboard-stat-title{font-size:12px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:#355a89}.dashboard-stat-card.warning .dashboard-stat-title{color:#9a6821}.dashboard-stat-card.success .dashboard-stat-title{color:#206c4a}.dashboard-stat-value{font-size:28px;line-height:1.1;font-weight:800;color:#1c3558}.dashboard-stat-subtitle{font-size:12px;color:#5f6f88}.dashboard-page{display:grid;gap:14px}.dashboard-welcome{text-align:center}.quick-link{--quick-accent: #3f7fcb;display:grid;grid-template-columns:66px 1fr auto;align-items:center;gap:14px;text-decoration:none;border:1px solid #d6e0ef;border-radius:12px;background:radial-gradient(circle at top right,color-mix(in srgb,var(--quick-accent) 10%,transparent),transparent 55%),linear-gradient(180deg,#fff,#f9fbff);padding:17px 16px;min-height:116px;box-shadow:0 8px 18px #0f28500f;transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}.quick-link:hover{border-color:color-mix(in srgb,var(--quick-accent) 36%,#b7c6de);transform:translateY(-1px);box-shadow:0 12px 22px #0f28501a}.quick-link-icon{width:66px;height:66px;border-radius:12px;display:grid;place-items:center;border:1px solid color-mix(in srgb,var(--quick-accent) 22%,#d7e0ef);background:color-mix(in srgb,var(--quick-accent) 12%,#ffffff);color:color-mix(in srgb,var(--quick-accent) 82%,#1f3556);font-size:18px;font-weight:700;line-height:1}.quick-link-icon svg{width:24px;height:24px}.quick-link-body{min-width:0;display:grid;gap:3px}.quick-link-title{display:block;color:#1d304d;font-size:16px;line-height:1.2}.quick-link-subtitle{display:block;color:#5e6f88;font-size:14px;line-height:1.35}.quick-link-arrow{color:color-mix(in srgb,var(--quick-accent) 60%,#6b7a92);font-size:24px;line-height:1;margin-left:4px}.quick-link-arrow svg{width:18px;height:18px}.quick-link-blue{--quick-accent: #3f7fcb}.quick-link-teal{--quick-accent: #2f8e86}.quick-link-slate{--quick-accent: #5d728f}.quick-link-indigo{--quick-accent: #5a67d8}.quick-link-amber{--quick-accent: #c78a2a}.quick-link-green{--quick-accent: #2f945e}.quick-link-violet{--quick-accent: #7a5ccf}.quick-link-rose{--quick-accent: #c95a7f}.quick-link strong,.quick-link .muted{color:inherit}.hide-desktop{display:none}.desktop-only{display:block}.mobile-only{display:none}.mobile-personnel-list{gap:12px}.mobile-only.mobile-personnel-list{display:none}.personnel-mobile-card{border:1px solid #d6e3f2;border-radius:14px;background:radial-gradient(circle at 100% 0%,rgba(15,108,189,.08),transparent 48%),linear-gradient(180deg,#fff,#f7faff);padding:12px;display:grid;gap:9px;box-shadow:0 8px 18px #0f285012,0 1px #ffffffe6 inset}.personnel-mobile-title{font-weight:700;font-size:15px;line-height:1.35;margin:0;padding-bottom:8px;border-bottom:1px solid #e6eef9;color:#142b49}.personnel-mobile-card .muted{margin:0;padding:7px 10px;border:1px solid #e5edf8;border-radius:10px;background:#f7faff;color:#3d5676;font-size:13px;line-height:1.4}.personnel-mobile-card button{min-height:42px}.sidebar-overlay{position:fixed;inset:0;z-index:35;border:0;padding:0;margin:0;background:#0f213d6b;border-radius:0}.menu-toggle-btn{width:44px;height:44px;min-width:44px;padding:0;font-size:20px;line-height:1;border-radius:12px}.mobile-header-center{min-width:0;display:grid;gap:2px}.mobile-user-meta{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal-overlay{position:fixed;inset:0;background:radial-gradient(circle at 20% 10%,rgba(77,133,207,.12),transparent 48%),#0f213d85;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:70;display:grid;place-items:center;padding:16px}.modal-card{width:min(920px,100%);max-height:calc(100vh - 32px);overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;border:1px solid #d8e2ef;border-radius:16px;background:linear-gradient(180deg,#f9fcfff5,#fffffffa);box-shadow:0 20px 48px #0f213d3d,0 6px 18px #0f213d1f;padding:16px;display:grid;gap:12px;animation:modal-in .18s ease-out}.modal-header{display:grid;gap:8px;padding:2px 2px 10px;border-bottom:1px solid #e9eef6}.modal-title-row{display:grid;grid-template-columns:34px 1fr;align-items:center;gap:10px}.modal-icon{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-weight:800;font-size:16px;border:1px solid #d9e6f5;background:#eef5ff;color:#245488;box-shadow:inset 0 1px #ffffffa6}.modal-header-danger .modal-icon{border-color:#efc7cd;background:#fff0f2;color:#b02a37}.modal-header-success .modal-icon{border-color:#cde8d9;background:#eefbf3;color:#157347}.modal-header-warning .modal-icon{border-color:#ecd8b0;background:#fff7e7;color:#9c6a09}.modal-header-info .modal-icon{border-color:#c9ddf7;background:#eef5ff;color:#245488}.modal-title{margin:0;font-size:18px;line-height:1.25;color:#14213d}.modal-message{color:var(--muted);margin-top:0;line-height:1.4;overflow-wrap:anywhere;word-break:break-word}.modal-actions{display:flex;justify-content:flex-end;gap:8px;padding-top:10px;margin-top:2px;border-top:1px solid #e9eef6;background:linear-gradient(180deg,#fff0,#ffffffe6);position:sticky;bottom:-16px}.modal-card .modal-actions button{min-height:42px;min-width:112px}@keyframes modal-in{0%{opacity:0;transform:translateY(10px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}.btn-with-icon{display:inline-flex;align-items:center;gap:6px}.modal-actions .btn-with-icon{justify-content:center}.modal-card .modal-actions .btn-with-icon{display:flex;align-items:center;justify-content:center;text-align:center}.modal-card .responsive-two-col>*,.modal-card .filter-row>*,.modal-card .row-wrap>*,.modal-card .stack>*{min-width:0}.modal-card input,.modal-card select,.modal-card textarea{width:100%;max-width:100%}.modal-card .table-wrap{max-width:100%}.btn-icon{display:inline-block;min-width:10px;text-align:center;font-weight:700;opacity:.9}.btn-icon svg{width:14px;height:14px;stroke:currentColor;vertical-align:middle}.toast-stack{position:fixed;inset:0;z-index:120;display:grid;gap:8px;align-content:center;justify-items:center;padding:16px;pointer-events:none}.toast{width:min(520px,calc(100vw - 24px));border:1px solid var(--border);border-radius:14px;background:#fffffffa;padding:10px 12px;box-shadow:0 18px 38px #0f213d2e;display:grid;grid-template-columns:28px 1fr auto;align-items:start;gap:10px;pointer-events:auto;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:toast-in .18s ease-out}.toast-success{border-color:#b8e6c8;background:linear-gradient(180deg,#f4fff8,#ebfaf1)}.toast-error{border-color:#f4c7cd;background:linear-gradient(180deg,#fff8f9,#fdf0f2)}.toast-info{border-color:#c6d9f3;background:linear-gradient(180deg,#f7fbff,#eef6ff)}.toast-icon{width:28px;height:28px;border-radius:999px;display:grid;place-items:center;font-size:14px;font-weight:800;line-height:1;border:1px solid #d5e0ef;color:#245281;background:#f6f9ff}.toast-icon-success{border-color:#b8e6c8;color:#11653c;background:#e9f8ef}.toast-icon-error{border-color:#f4c7cd;color:#9b2330;background:#fdecef}.toast-content{min-width:0;display:grid;align-items:center;padding-top:2px}.toast-message{color:#1b2f4a;font-size:13px;line-height:1.4}.toast-close{border:0;background:transparent;color:var(--muted);padding:2px 4px;min-height:unset;line-height:1;font-size:16px;border-radius:8px}.toast-close:hover{background:#0f213d0f}.inline-error{color:var(--danger);background:var(--danger-bg);border:1px solid #f4c7cd;border-radius:var(--radius-sm);padding:8px 10px}.inline-success{color:var(--success);background:var(--success-bg);border:1px solid #b8e6c8;border-radius:var(--radius-sm);padding:8px 10px}.empty-state{border:1px dashed #cfdbeb;border-radius:var(--radius-md);padding:16px;text-align:center;color:var(--muted);background:radial-gradient(circle at top center,rgba(15,108,189,.04),transparent 62%),#fbfdff;display:grid;justify-items:center;gap:4px}.empty-state-info{border-color:#bfd4f4;background:radial-gradient(circle at top center,rgba(15,108,189,.08),transparent 62%),#f7fbff}.empty-state-warning{border-color:#ebd6ad;background:radial-gradient(circle at top center,rgba(199,138,42,.08),transparent 62%),#fffaf2}.empty-icon{width:30px;height:30px;border-radius:999px;display:grid;place-items:center;font-weight:800;font-size:13px;border:1px solid #d7e3f3;background:#f2f7ff;color:#2b5a8f}.empty-title{font-weight:600;color:var(--text)}.empty-subtitle{font-size:12px;color:var(--muted);line-height:1.35}.empty-action{margin-top:8px}.skeleton-list{display:grid;gap:8px}.skeleton-line{height:16px;border-radius:999px;background:linear-gradient(90deg,#ecf2fb,#f8fbff,#ecf2fb);background-size:200% 100%;animation:pulse 1.1s linear infinite}.table-wrap{overflow-x:auto;border:1px solid #dfe6f2;border-radius:12px;background:#fff;box-shadow:0 6px 16px #0f28500d}.form-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));align-items:start}.form-grid .field{align-content:start}.table-basic{width:100%;border-collapse:collapse;min-width:640px}.table-basic th{text-align:left;border-bottom:1px solid #dfe6f2;padding:10px 8px;font-size:12px;text-transform:uppercase;letter-spacing:.03em;color:#3f5879;background:#f7f9fc;position:sticky;top:0;z-index:1}.table-basic td{border-bottom:1px solid #edf1f7;padding:10px 8px;font-size:13px;color:#1d304d}.table-basic tbody tr:nth-child(2n){background:#fbfdff}.table-basic tbody tr:hover{background:#f4f8ff}.table-basic tbody tr:last-child td{border-bottom:0}.holiday-table-wrap{border:1px solid #dfe6f2;border-radius:12px;background:#fff}.holiday-form-grid{display:grid;gap:10px;grid-template-columns:minmax(180px,220px) minmax(220px,1fr) auto;align-items:end}.holiday-table{min-width:620px}.holiday-table thead th{position:sticky;top:0;z-index:1;background:#f7f9fc;color:#2f4768;font-weight:700;text-transform:uppercase;letter-spacing:.03em;font-size:11px}.holiday-table tbody tr:nth-child(2n){background:#fafcff}.holiday-table tbody tr:hover{background:#f3f7fd}.holiday-date-chip{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;border:1px solid #d1deef;background:#f4f8ff;color:#2c4d78;font-weight:600;font-size:12px}.holiday-name{font-weight:600}.holiday-mobile-list{display:none;gap:10px}.holiday-mobile-card{border:1px solid #dfe6f2;border-radius:12px;background:#fff;padding:10px;display:grid;gap:8px;box-shadow:0 4px 12px #0f28500f;justify-items:center;text-align:center}.holiday-mobile-top{display:flex;gap:8px;flex-wrap:wrap;align-items:center;justify-content:center}.holiday-weekday-chip{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;border:1px solid #d7e3f2;background:#f8fbff;color:#385b86;font-size:12px;font-weight:600}.tab-strip{display:flex;flex-wrap:wrap;gap:8px;padding:8px;border:1px solid #d9e4f2;border-radius:14px;background:#f7fafd}.tab-btn{border:1px solid #cfe0f2;background:#fff;color:#17324d;border-radius:10px;padding:10px 14px;font-weight:600;cursor:pointer}.tab-btn-active{background:#17324d;color:#fff;border-color:#17324d}.status-pill{display:inline-flex;align-items:center;justify-content:center;padding:4px 8px;border-radius:999px;font-size:12px;font-weight:700;border:1px solid #d6e0eb;background:#f4f7fb;color:#2b4055}.status-success{background:#e9f8ef;border-color:#bfe7cd;color:#15693d}.status-warning{background:#fff4e5;border-color:#ffd39c;color:#9a5700}.status-danger{background:#fdecef;border-color:#f4c7cd;color:#9b2330}.status-muted{background:#f0f2f5;border-color:#dde2e8;color:#56616d}.pager-row{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}.pagination-toolbar{display:flex;align-items:end;justify-content:space-between;gap:12px;flex-wrap:wrap}.pagination-toolbar-size{min-width:200px}.pagination-toolbar-size .field{margin:0}.pager-info{color:#4c6177;font-size:13px;font-weight:600}.json-view{margin:0;padding:10px 12px;border-radius:10px;border:1px solid #deebf7;background:#f8fbfe;color:#17324d;max-height:220px;overflow:auto;font-size:12px;line-height:1.45;white-space:pre-wrap;word-break:break-word}.modal-card-wide{width:min(920px,calc(100vw - 24px))}.responsive-two-col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.checkbox-row{display:inline-flex;align-items:center;gap:8px;min-height:40px}@media(max-width:900px){.tab-strip{display:grid;grid-template-columns:1fr}.tab-btn{width:100%;min-height:44px}.pager-row{justify-content:center}.pagination-toolbar{justify-content:center;align-items:stretch}.pagination-toolbar-size{width:100%;min-width:0}.responsive-two-col{grid-template-columns:1fr}}.holiday-mobile-actions{display:flex;justify-content:center;width:100%}.field{display:grid;gap:6px}.field-label,.field-hint{font-size:12px;color:var(--muted)}.field-error{font-size:12px;color:var(--danger)}.filter-row,.row-wrap{display:flex;gap:8px;flex-wrap:wrap;align-items:end}.filter-card{border:1px solid #dce5f2;border-radius:14px;background:radial-gradient(circle at top right,rgba(15,108,189,.06),transparent 55%),#fbfdff;padding:10px;box-shadow:0 6px 14px #0f28500a}.form-actions{display:flex;gap:8px;justify-content:flex-end;align-items:center;flex-wrap:wrap;padding-top:10px;border-top:1px solid #e8edf6}.attendance-settings-layout{display:grid;gap:12px;grid-template-columns:1.3fr 1.3fr .9fr;align-items:start}.attendance-settings-card{border:1px solid var(--border);border-radius:14px;background:linear-gradient(180deg,#fff,#f8fbff);padding:12px;display:grid;gap:10px;box-shadow:0 8px 18px #0f28500f}.attendance-settings-card-title{font-size:13px;font-weight:700;color:#1f2e45}.attendance-settings-card-subtitle{font-size:12px;color:var(--muted);line-height:1.4}.attendance-settings-grid{display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr));align-items:start}.attendance-settings-grid .field:last-child:nth-child(odd){grid-column:1 / -1}.attendance-settings-grid .field{align-content:start}.attendance-settings-actions{position:relative}.attendance-settings-actions-row{display:grid;gap:8px;margin-top:auto}.attendance-settings-actions .ghost-btn,.attendance-settings-actions .primary-btn{width:100%}.stack{display:grid;gap:12px}.stats-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.stat-card{--stat-accent: #8ea6c7;--stat-value: #1f2e45;border:1px solid var(--border);border-radius:12px;background:#fff;padding:12px;display:grid;gap:6px;min-height:92px;position:relative;overflow:hidden;box-shadow:0 8px 18px #0f285014;transition:transform .14s ease,box-shadow .14s ease}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--stat-accent)}.stat-card:after{content:"";position:absolute;width:96px;height:96px;right:-24px;top:-24px;border-radius:999px;background:color-mix(in srgb,var(--stat-accent) 14%,transparent);pointer-events:none}.stat-card:hover{transform:translateY(-1px);box-shadow:0 12px 24px #0f28501f}.stat-card-info{--stat-accent: #5e94d6;border-color:#c8dcf6;background:#f4f9ff}.stat-card-primary{--stat-accent: #3677c8;border-color:#b9cff0;background:#edf5ff}.stat-card-success{--stat-accent: #3d9b69;border-color:#b9e6c8;background:#eefbf3}.stat-card-success-strong{--stat-accent: #228652;border-color:#9fd8b3;background:#e4f7ec}.stat-card-warning{--stat-accent: #ce8d2f;--stat-value: #7c5411;border-color:#ecd2a6;background:linear-gradient(135deg,#fff8eb,#fff2d8)}.stat-card-danger-soft{--stat-accent: #c85a68;--stat-value: #7f2632;border-color:#f0c0c7;background:linear-gradient(135deg,#fff6f7,#fdecef)}.stat-card-total{--stat-accent: #4a88d1;--stat-value: #184b82;border-color:#bfd8fb;background:linear-gradient(135deg,#f2f8ff,#e8f2ff)}.stat-card-total-strong{--stat-accent: #2f76cc;--stat-value: #153f6f;border-color:#9fc4f4;background:linear-gradient(135deg,#e9f3ff,#dae9ff)}.stat-card-approved{--stat-accent: #349764;--stat-value: #1b6640;border-color:#a9dfbf;background:linear-gradient(135deg,#effcf4,#e3f7eb)}.stat-card-approved-strong{--stat-accent: #247f51;--stat-value: #145233;border-color:#84cfaa;background:linear-gradient(135deg,#e5f8ee,#d5f0e2)}.stat-label{font-size:11px;letter-spacing:.03em;text-transform:uppercase;color:color-mix(in srgb,var(--stat-accent) 70%,#40506b);font-weight:700}.stat-value{font-size:22px;line-height:1.2;font-weight:700;color:var(--stat-value)}.stat-helper{font-size:11px;line-height:1.35;color:#61728d}@media(max-width:640px){.stats-grid{grid-template-columns:1fr 1fr}.stat-card{min-height:84px;padding:10px}.stat-value{font-size:20px}}.loading-visual{display:inline-flex;align-items:center;gap:10px;color:var(--muted);background:#f5f9ff;border:1px solid #c6d9f3;border-radius:999px;padding:8px 12px;position:relative;overflow:hidden}.loading-visual:after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.6) 48%,transparent 100%);transform:translate(-120%);animation:shimmer 1.25s ease-in-out infinite}.loading-spinner{width:14px;height:14px;border-radius:999px;border:2px solid #0f6cbd;border-right-color:transparent;animation:spin .7s linear infinite}.mobile-data-list{display:none;gap:10px}.mobile-data-card{border:1px solid #d5e2f2;border-radius:14px;background:radial-gradient(circle at 100% 0%,rgba(15,108,189,.08),transparent 46%),linear-gradient(180deg,#fff,#f9fbff);padding:12px;display:grid;gap:10px;box-shadow:0 8px 18px #0f285012,0 1px #ffffffe6 inset}.mobile-data-title{font-weight:700;font-size:15px;line-height:1.35;margin-bottom:0;padding:0 0 8px;border-bottom:1px solid #e5edf7;color:#132845}.mobile-data-row{display:grid;grid-template-columns:minmax(90px,120px) 1fr;gap:8px;align-items:start;padding:8px 10px;border:1px solid #e5edf8;border-radius:10px;background:#f7faff}.mobile-data-label{color:#45607f;font-size:12px;font-weight:600;line-height:1.35;letter-spacing:.01em;text-transform:uppercase}.mobile-data-value{color:#123154;font-size:14px;line-height:1.45;font-weight:600;word-break:break-word}.mobile-data-actions{display:flex;gap:8px;margin-top:2px;padding-top:10px;border-top:1px solid #e5edf7;flex-wrap:wrap;justify-content:flex-end}@keyframes pulse{0%{background-position:0% 50%}to{background-position:100% 50%}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shimmer{0%{transform:translate(-120%)}to{transform:translate(120%)}}@media(max-width:900px){.app-shell{grid-template-columns:1fr}.hide-desktop{display:inline-flex}.desktop-only{display:none!important}.mobile-only{display:block!important}.mobile-personnel-list,.mobile-data-list{display:grid!important}.app-sidebar{position:fixed;left:0;top:0;bottom:0;width:100vw;max-width:100vw;z-index:40;transform:translate(-104%);transition:transform .18s ease;box-shadow:0 20px 30px #0f285033;padding-bottom:calc(16px + env(safe-area-inset-bottom));overflow:hidden}.sidebar-nav{min-height:0;overflow-y:auto;padding-right:4px;scrollbar-gutter:stable}.app-sidebar.open{transform:translate(0)}.mobile-header{width:100%;padding-top:calc(10px + env(safe-area-inset-top))}.app-content{padding:12px}.panel-card{padding:12px;border-radius:12px}.page-title{font-size:18px;line-height:1.3;gap:8px;margin-bottom:10px}.page-title:before{width:5px;height:18px}.page-subtitle{font-size:12px;margin:-2px 0 8px}button,input,select{min-height:44px}input[type=date][value=""]{color:transparent;-webkit-text-fill-color:transparent;position:relative}input[type=date][value=""]::-webkit-datetime-edit{color:transparent;-webkit-text-fill-color:transparent}input[type=date][value=""]:before{content:"Tarih seçin";color:var(--muted);position:absolute;left:12px;right:34px;top:50%;transform:translateY(-50%);pointer-events:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.quick-grid{grid-template-columns:1fr}.quick-group-title{font-size:12px}.quick-group-subtitle{font-size:11px}.quick-group-badge{font-size:10px;padding:4px 7px}.holiday-form-grid{grid-template-columns:1fr}.filter-card{padding:8px;border-radius:12px}.form-actions{flex-direction:column-reverse;align-items:stretch}.form-actions>button{width:100%}.attendance-settings-layout{grid-template-columns:1fr;gap:10px}.attendance-settings-card{padding:10px;border-radius:12px}.attendance-settings-grid{grid-template-columns:1fr;gap:8px}.attendance-settings-grid .field:last-child:nth-child(odd){grid-column:auto}.holiday-form-grid .primary-btn{width:100%}.holiday-mobile-list{display:grid}.dashboard-stats{grid-template-columns:1fr}.quick-link{grid-template-columns:52px 1fr auto;min-height:96px;padding:14px}.quick-link-icon{width:52px;height:52px;border-radius:11px;font-size:19px}.quick-link-icon svg{width:22px;height:22px}.quick-link-arrow svg{width:16px;height:16px}.quick-link-title{font-size:14px}.quick-link-subtitle{font-size:12px}.auth-page{padding:14px}.auth-card{padding:16px;border-radius:14px}.modal-overlay{padding:10px}.modal-card{width:100%;max-height:calc(100vh - 12px);min-height:min(420px,calc(100vh - 12px));padding:12px;border-radius:14px;gap:10px}.modal-card-wide{width:100%}.modal-header{padding-bottom:8px;gap:6px}.modal-title-row{grid-template-columns:30px 1fr;gap:8px}.modal-icon{width:30px;height:30px;border-radius:9px;font-size:14px}.status-banner-stack{left:10px;bottom:10px;width:calc(100vw - 20px)}.modal-actions{flex-direction:column-reverse;position:static;border-top:1px solid #e9eef6;background:transparent;padding-top:10px;gap:10px}.modal-card .modal-actions button{width:100%;min-width:0;min-height:44px}.modal-title{font-size:16px;line-height:1.3}.modal-message{font-size:13px;line-height:1.45}.toast-stack{padding:10px}.mobile-data-row{grid-template-columns:1fr;gap:2px}.toast{width:calc(100vw - 20px);grid-template-columns:24px 1fr auto;gap:8px;padding:10px;border-radius:12px}.toast-icon{width:24px;height:24px;font-size:12px}.toast-message{font-size:12px}}@keyframes toast-in{0%{opacity:0;transform:translateY(6px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}
