:root{--surface-page: #f5f6f8;--surface-card: #ffffff;--surface-chrome: #e8eef4;--surface-bar: #f0f4f8;--text-primary: #1a1a1a;--text-secondary: #4a4a4a;--text-hero: #0d2d5c;--text-disabled: #9a9ea2;--accent: #1a4d8c;--accent-dark: #0d2d5c;--accent-hover: #2563a8;--accent-hr: #0e7c6b;--border: #d0d4d8;--border-light: #e0e4e8;--topbar-start: #1a4d8c;--topbar-end: #0d2d5c;--font-sans: "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;--text-portal-title: 30px;--text-module-title: 26px;--text-card-title: 16px;--text-section: 14px;--text-body: 13px;--text-small: 12px;--space-page-h: 48px;--space-page-v: 40px;--space-card-pad: 28px;--space-card-gap: 24px;--space-section: 44px;--radius: 4px;--radius-card: 8px}.app-shell{min-height:100vh;background-color:var(--surface-page);display:flex;flex-direction:column}.app-shell--sidebar{flex-direction:row}.portal-sidebar{width:240px;min-width:240px;background:linear-gradient(180deg,var(--topbar-start) 0%,var(--topbar-end) 100%);display:flex;flex-direction:column;flex-shrink:0}.portal-sidebar__brand{padding:20px 16px;border-bottom:1px solid rgba(255,255,255,.15)}.portal-sidebar__logo-box{background-color:#fff;border-radius:var(--radius-card);padding:8px 12px;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 3px #0000001f}.portal-sidebar__logo{height:28px;width:auto;display:block;object-fit:contain}.portal-sidebar__title{color:#fff;font-size:var(--text-card-title);font-weight:700;margin:8px 0 0;letter-spacing:.02em}.portal-sidebar__nav{flex:1;padding:12px 8px;overflow-y:auto}.portal-sidebar__link{display:block;color:#fffffff2;text-decoration:none;padding:10px 12px;font-size:var(--text-body);border-radius:var(--radius);margin-bottom:2px;transition:background-color .15s ease,color .15s ease}.portal-sidebar__link:hover{background-color:#ffffff26;color:#fff}.portal-sidebar__link:focus-visible{outline:none;background-color:#fff3;box-shadow:0 0 0 2px #fff6}.portal-sidebar__link.active{background-color:#ffffff40;color:#fff;font-weight:600}.portal-sidebar__link--muted{font-size:var(--text-small);opacity:.92}.portal-sidebar__footer{padding:12px 8px;border-top:1px solid rgba(255,255,255,.15);display:flex;flex-direction:column;gap:4px}.portal-sidebar__icon-btn{background:transparent;border:none;color:#fff;width:100%;padding:8px 12px;display:flex;align-items:center;gap:10px;font-size:var(--text-body);border-radius:var(--radius);cursor:pointer;transition:background-color .15s ease;text-align:left}.portal-sidebar__icon-btn:hover{background-color:#ffffff26}.portal-sidebar__icon-btn:focus-visible{outline:none;box-shadow:0 0 0 2px #fff6}.portal-sidebar__logout{background:transparent;border:none;color:#fff;padding:10px 12px;font-size:var(--text-body);cursor:pointer;border-radius:var(--radius);width:100%;text-align:left;transition:background-color .15s ease}.portal-sidebar__logout:hover{background-color:#ffffff26}.portal-sidebar__logout:focus-visible{outline:none;box-shadow:0 0 0 2px #fff6}.portal-sidebar__icon-badge{position:relative}.portal-sidebar__icon-badge:after{content:"";position:absolute;top:8px;left:20px;width:6px;height:6px;background-color:#ef4444;border-radius:50%}.portal-content-area{flex:1;display:flex;flex-direction:column;min-width:0}.portal-topbar{background:linear-gradient(180deg,var(--topbar-start) 0%,var(--topbar-end) 100%);min-height:48px;display:flex;align-items:center;flex-wrap:nowrap;gap:0;padding:0 24px;flex-shrink:0}.portal-topbar__brand{display:flex;align-items:center;gap:12px}.portal-topbar__logo-box{background-color:#fff;border-radius:12px;padding:6px 12px;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 3px #0000001f}.portal-topbar__logo{height:28px;width:auto;display:block;object-fit:contain}.portal-topbar__title{color:#fff;font-size:var(--text-card-title);font-weight:700;margin:0;letter-spacing:.02em}.portal-topbar__nav{display:flex;align-items:center;flex-wrap:nowrap;gap:2px 4px;margin-left:24px;padding:6px 0;min-width:0;overflow-x:auto;overflow-y:hidden;scrollbar-width:thin;-webkit-overflow-scrolling:touch}.portal-topbar__nav::-webkit-scrollbar{height:4px}.portal-topbar__nav::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:2px}.portal-topbar__link{color:#fff;text-decoration:none;padding:6px 12px;font-size:var(--text-body);border-radius:var(--radius);transition:background-color .15s ease,box-shadow .15s ease}.portal-topbar__link:hover{background-color:#fff3}.portal-topbar__link:focus-visible{outline:none;background-color:#fff3;box-shadow:0 0 0 2px #ffffff80}.portal-topbar__link.active{background-color:#ffffff40;font-weight:600}.portal-topbar__spacer{flex:1}.portal-topbar__logout{background:transparent;border:none;color:#fff;padding:6px 12px;font-size:var(--text-body);cursor:pointer;border-radius:var(--radius);transition:background-color .15s ease,box-shadow .15s ease}.portal-topbar__logout:hover{background-color:#fff3}.portal-topbar__logout:focus-visible{outline:none;background-color:#fff3;box-shadow:0 0 0 2px #ffffff80}.portal-breadcrumb{background-color:var(--surface-chrome);border-bottom:1px solid var(--border);min-height:36px;display:flex;align-items:center;gap:12px;padding:0 var(--space-page-h);flex-shrink:0}.portal-breadcrumb__menu-btn{display:none;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-page);cursor:pointer;flex-shrink:0}.portal-breadcrumb__menu-btn:focus-visible{outline:none;box-shadow:0 0 0 2px #1a4d8c59}.portal-breadcrumb__menu-icon,.portal-breadcrumb__menu-icon:before,.portal-breadcrumb__menu-icon:after{display:block;width:16px;height:2px;background:var(--text-primary);border-radius:1px;position:relative}.portal-breadcrumb__menu-icon:before,.portal-breadcrumb__menu-icon:after{content:"";position:absolute;left:0}.portal-breadcrumb__menu-icon:before{top:-5px}.portal-breadcrumb__menu-icon:after{top:5px}.portal-breadcrumb__path{color:var(--text-secondary);font-size:var(--text-body);margin:0}.portal-main{flex:1;padding:var(--space-page-v) var(--space-page-h);overflow:auto}.portal-content{max-width:960px;margin:0 auto}.portal-content--leave{max-width:1100px}.portal-form{display:flex;flex-direction:column;gap:1.25rem}.portal-field{display:flex;flex-direction:column;align-items:stretch;gap:.4rem;margin:0}.portal-field>span:first-child{font-size:var(--text-small);font-weight:600;color:var(--text-primary)}.portal-field input[type=text],.portal-field input[type=password],.portal-field input[type=email],.portal-field input[type=number],.portal-field input[type=date],.portal-field input[type=time],.portal-field select,.portal-field textarea{width:100%;max-width:100%;box-sizing:border-box;padding:10px 12px;font-size:var(--text-body);font-family:inherit;border:1px solid var(--border);border-radius:var(--radius);background:#fff;color:var(--text-primary);line-height:1.35}.portal-field select{min-height:40px;cursor:pointer}.portal-field textarea{min-height:88px;resize:vertical}.portal-field input:focus-visible,.portal-field select:focus-visible,.portal-field textarea:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #1a4d8c33}.portal-form__actions{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;margin-top:.25rem;padding-top:.25rem}.portal-inline-link{color:var(--accent);text-decoration:none;font-weight:600}.portal-inline-link:hover{text-decoration:underline}.leave-card__header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:0}.leave-card__header .portal-card__title{margin-bottom:0}.leave-form{margin-top:4px}.leave-form__grid{display:grid;grid-template-columns:1fr;gap:1.25rem}@media (min-width: 720px){.leave-form__grid--dates{grid-template-columns:repeat(3,minmax(0,1fr))}}.portal-page-header{margin-bottom:var(--space-section)}.portal-page-title{font-size:var(--text-module-title);font-weight:700;color:var(--text-hero);margin:0 0 8px}.portal-page-subtitle{font-size:14px;color:var(--text-secondary);margin:0}.portal-card{background-color:var(--surface-card);border:1px solid var(--border-light);border-radius:var(--radius-card);padding:var(--space-card-pad) var(--space-card-pad) 24px;margin-bottom:var(--space-card-gap);box-shadow:0 1px 3px #0000000a;transition:border-color .2s ease,box-shadow .2s ease}.portal-card:hover{border-color:var(--border);box-shadow:0 2px 8px #0000000f}.portal-card__title{font-size:var(--text-card-title);font-weight:700;color:var(--text-primary);margin:0 0 12px}.portal-card__body{font-size:var(--text-body);color:var(--text-secondary);margin:0}.btn{display:inline-flex;align-items:center;justify-content:center;padding:6px 14px;min-height:36px;font-size:var(--text-body);font-family:inherit;border-radius:var(--radius);border:1px solid var(--border);background-color:var(--surface-chrome);color:var(--text-primary);cursor:pointer;transition:background-color .15s ease,border-color .15s ease,box-shadow .15s ease}.btn:hover:not(:disabled){background-color:#d8e0e8;border-color:#b0b8c0}.btn:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #1a4d8c40}.btn:disabled{background-color:#f0f2f4;color:var(--text-disabled);cursor:not-allowed}.btn--primary{background-color:var(--accent);color:#fff;border-color:var(--accent-dark)}.btn--primary:hover:not(:disabled){background-color:var(--accent-hover)}.btn--primary:focus-visible{border-color:var(--accent-dark);box-shadow:0 0 0 2px #fff6}.btn--primary:disabled{background-color:#9a9ea2;border-color:#9a9ea2}.btn--secondary{background-color:var(--surface-card);color:var(--text-primary);border-color:var(--border)}.btn--secondary:hover:not(:disabled){background-color:#eef2f6;border-color:#b8c0c8}.btn--danger{background-color:#b42318;color:#fff;border-color:#912018}.btn--danger:hover:not(:disabled){background-color:#912018}.btn--danger:focus-visible{box-shadow:0 0 0 2px #b4231859}.input-group{margin-bottom:20px}.input-group label{display:block;font-size:var(--text-body);font-weight:500;color:var(--text-primary);margin-bottom:6px}.input{width:100%;padding:8px 12px;min-height:40px;font-size:var(--text-body);font-family:inherit;color:var(--text-primary);background-color:var(--surface-card);border:1px solid var(--border);border-radius:var(--radius);box-sizing:border-box;transition:border-color .15s ease,box-shadow .15s ease}.input:focus,.input:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #1a4d8c33}.input::placeholder{color:var(--text-disabled)}.input:disabled{background-color:#f0f2f4;color:var(--text-disabled)}.select{min-width:160px;padding:8px 12px;min-height:40px;font-size:var(--text-body);font-family:inherit;color:var(--text-primary);background-color:var(--surface-card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;margin-right:12px;transition:border-color .15s ease,box-shadow .15s ease}.select:focus,.select:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #1a4d8c33}.alert{padding:12px 16px;border-radius:var(--radius);font-size:var(--text-body);margin-bottom:20px}.alert--error{background-color:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.login-layout{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,var(--topbar-start) 0%,var(--topbar-end) 50%,var(--surface-page) 50%);padding:40px 24px}.login-card{width:100%;max-width:400px;background-color:var(--surface-card);border-radius:var(--radius-card);box-shadow:0 8px 32px #0000001f;padding:40px;border:1px solid var(--border-light);transition:box-shadow .2s ease}.login-card:focus-within{box-shadow:0 12px 40px #00000024}.login-card__brand{text-align:center;margin-bottom:28px}.login-card__logo{max-width:180px;height:40px;width:auto;object-fit:contain;margin-bottom:16px;display:block;margin-left:auto;margin-right:auto}.login-card__title{font-size:var(--text-module-title);font-weight:700;color:var(--text-hero);margin:0 0 8px}.login-card__subtitle{font-size:var(--text-body);color:var(--text-secondary);margin:0}.login-card__register-hint{font-size:var(--text-body);color:var(--text-secondary);margin:1rem 0 0;text-align:center}.login-card__register-hint a{color:var(--accent);font-weight:500;text-decoration:none}.login-card__register-hint a:hover{color:var(--accent-hover);text-decoration:underline}.dl-grid{display:grid;grid-template-columns:160px 1fr;gap:12px 24px;max-width:520px}.dl-grid dt{font-size:var(--text-body);color:var(--text-secondary);margin:0;font-weight:500}.dl-grid dd{font-size:var(--text-body);color:var(--text-primary);margin:0}.portal-list-unstyled{list-style:none;padding:0;margin:0}.portal-list-unstyled li+li{margin-top:6px}.portal-label-inline{font-size:var(--text-body);color:var(--text-secondary);font-weight:500}.request-list{list-style:none;padding:0;margin:0}.request-card{background-color:var(--surface-card);border:1px solid var(--border-light);border-radius:var(--radius);padding:16px 20px;margin-bottom:12px;transition:border-color .2s ease,background-color .2s ease,box-shadow .2s ease}.request-card:hover{border-color:var(--border);background-color:#fafbfc;box-shadow:0 2px 6px #0000000a}.request-card__head{font-weight:600;color:var(--text-primary);font-size:var(--text-body);margin-bottom:4px}.request-card__meta{font-size:var(--text-small);color:var(--text-secondary)}.action-bar{display:flex;align-items:center;flex-wrap:wrap;gap:12px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border-light)}.portal-card .action-bar+.request-list{margin-top:4px}.address-block{margin-bottom:24px;padding:16px;background-color:var(--surface-bar);border-radius:var(--radius);border:1px solid var(--border-light)}.address-block__label{font-size:var(--text-small);font-weight:600;color:var(--text-secondary);margin:0 0 6px}.address-block__value{font-size:var(--text-body);color:var(--text-primary);margin:0}.address-form{margin-top:8px}.address-form__label{font-size:var(--text-card-title);font-weight:600;color:var(--text-primary);margin:0 0 12px}.address-form__row{display:grid;grid-template-columns:1fr 1fr 120px;gap:16px}@media (max-width: 640px){.address-form__row{grid-template-columns:1fr}}.loading-block{padding:48px 24px;text-align:center;color:var(--text-secondary);font-size:var(--text-body)}.portal-card .loading-block{padding:40px 24px;margin:0 -var(--space-card-pad);background:var(--surface-bar);border-radius:var(--radius)}.loading-spinner{display:inline-block;width:32px;height:32px;border:3px solid var(--border-light);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:48px 24px;color:var(--text-secondary);font-size:var(--text-body);background-color:var(--surface-bar);border:1px dashed var(--border);border-radius:var(--radius)}.portal-card .empty-state{background-color:var(--surface-bar);margin:0}.placeholder-hero{text-align:center;padding:48px 32px 32px}.placeholder-hero__icon{font-size:48px;line-height:1;margin-bottom:16px;opacity:.7}.placeholder-hero__title{font-size:var(--text-card-title);font-weight:600;color:var(--text-primary);margin:0 0 8px}.placeholder-hero__body{font-size:var(--text-body);color:var(--text-secondary);margin:0 auto 24px;max-width:420px}.placeholder-hero__cta{display:inline-flex;align-items:center;gap:8px}.dashboard-welcome{margin-bottom:var(--space-section)}.dashboard-welcome__title{font-size:var(--text-portal-title);font-weight:700;color:var(--text-hero);margin:0 0 8px}.dashboard-welcome__subtitle{font-size:var(--text-body);color:var(--text-secondary);margin:0}.dashboard-metrics{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--space-card-gap);margin-bottom:var(--space-section)}.metric-card{background-color:var(--surface-card);border:1px solid var(--border-light);border-radius:var(--radius-card);padding:20px;box-shadow:0 1px 3px #0000000a;display:flex;flex-direction:column;gap:4px}.metric-card__value{font-size:22px;font-weight:700;color:var(--text-primary)}.metric-card__label{font-size:var(--text-small);color:var(--text-secondary)}.metric-card--progress .metric-card__bar{margin-top:8px;height:6px;background-color:var(--border-light);border-radius:3px;overflow:hidden}.metric-card__bar-fill{height:100%;background-color:var(--accent);border-radius:3px;transition:width .2s ease}.dashboard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-card-gap)}@media (max-width: 900px){.dashboard-grid{grid-template-columns:1fr}}.dashboard-card .portal-card__header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.dashboard-card .portal-card__title{margin:0}.dashboard-card__link{font-size:var(--text-small);color:var(--accent)}.dashboard-card__link:hover{color:var(--accent-hover);text-decoration:underline}.dashboard-card__meta{font-size:var(--text-small);color:var(--text-secondary);margin:12px 0 8px}.dashboard-card__empty{font-size:var(--text-body);color:var(--text-secondary);margin:0}.schedule-list{list-style:none;padding:0;margin:0}.schedule-list__item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--border-light)}.schedule-list__item:last-child{border-bottom:none}.schedule-list__accent{width:4px;border-radius:2px;flex-shrink:0}.schedule-list__item>div{display:flex;flex-direction:column;gap:2px}.schedule-list__time{font-size:var(--text-small);color:var(--text-secondary)}.schedule-list__title{font-size:var(--text-body);font-weight:600;color:var(--text-primary)}.schedule-list__context{font-size:var(--text-small);color:var(--text-secondary)}.quick-actions{list-style:none;padding:0;margin:0}.quick-actions li{margin-bottom:4px}.quick-actions__link{display:flex;align-items:center;gap:10px;padding:10px 0;color:var(--text-primary);text-decoration:none;font-size:var(--text-body);border-radius:var(--radius);transition:background-color .15s ease}.quick-actions__link:hover{background-color:var(--surface-bar);color:var(--accent)}.quick-actions__icon{font-size:18px;opacity:.9}.pending-list{list-style:none;padding:0;margin:0}.pending-list__item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border-light)}.pending-list__item:last-child{border-bottom:none}.pending-list__status{width:12px;height:12px;border-radius:50%;flex-shrink:0}.pending-list__status--pending{background-color:#eab308}.pending-list__status--done{background-color:var(--accent-hr)}.pending-list__body{flex:1;display:flex;flex-direction:column;gap:2px}.pending-list__title{font-size:var(--text-body);font-weight:500;color:var(--text-primary)}.pending-list__due{font-size:var(--text-small);color:var(--text-secondary)}.btn--sm{padding:4px 10px;min-height:28px;font-size:var(--text-small)}.performance-bars{display:flex;flex-direction:column;gap:12px}.performance-bars__row{display:grid;grid-template-columns:140px 1fr 40px;align-items:center;gap:12px}.performance-bars__label{font-size:var(--text-body);color:var(--text-secondary)}.performance-bars__track{height:8px;background-color:var(--border-light);border-radius:4px;overflow:hidden}.performance-bars__fill{height:100%;background-color:var(--accent);border-radius:4px;transition:width .2s ease}.performance-bars__pct{font-size:var(--text-small);font-weight:600;color:var(--text-primary);text-align:right}.performance-page{display:flex;flex-direction:column;gap:1.25rem}.performance-page__header{margin-bottom:.25rem}.performance-page__hint,.performance-page__footer-link{margin:.75rem 0 0;font-size:var(--text-small);color:var(--text-secondary)}.performance-page__footer-link a{font-weight:500}.performance-summary-card .performance-page__hint{margin-top:.5rem}.performance-empty p{margin:0 0 .5rem;color:var(--text-primary)}.performance-empty__hint{font-size:var(--text-small);color:var(--text-secondary);margin:0}.performance-goal-list,.performance-review-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}.performance-goal-card,.performance-review-card{padding:.875rem 1rem;border:1px solid var(--border-light);border-radius:var(--radius);background:var(--surface-secondary, #fafafa)}.performance-goal-card__head,.performance-review-card__head{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}.performance-goal-card__title{font-size:var(--text-body)}.performance-goal-card__meta,.performance-review-card__date,.performance-review-card__rating{margin:.35rem 0 0;font-size:var(--text-small);color:var(--text-secondary)}.performance-bars--compact .performance-bars__row{grid-template-columns:72px 1fr 40px}.performance-self-form{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-light);display:flex;flex-direction:column;gap:.75rem}.performance-self-form__lead{margin:0;font-size:var(--text-small);color:var(--text-secondary)}.performance-self-form__field{display:flex;flex-direction:column;gap:.25rem;font-size:var(--text-small)}.performance-self-form__field select,.performance-self-form__field textarea{font:inherit;padding:.5rem;border:1px solid var(--border-light);border-radius:var(--radius)}@media (max-width: 640px){.performance-bars__row{grid-template-columns:1fr;gap:.35rem}.performance-bars__pct{text-align:left}.performance-goal-card__head,.performance-review-card__head{flex-direction:column}}.portal-topbar__icons{display:flex;align-items:center;gap:4px;margin-right:16px}.portal-topbar__icon-btn{background:transparent;border:none;color:#fff;width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);cursor:pointer;transition:background-color .15s ease}.portal-topbar__icon-btn:hover{background-color:#fff3}.portal-topbar__icon-btn:focus-visible{outline:none;box-shadow:0 0 0 2px #ffffff80}.portal-topbar__icon-btn[aria-label]:focus-visible{outline:none}.portal-topbar__icon-badge{position:relative}.portal-topbar__icon-badge:after{content:"";position:absolute;top:6px;right:6px;width:8px;height:8px;background-color:#ef4444;border-radius:50%;border:2px solid var(--topbar-end)}.portal-table{width:100%;border-collapse:collapse;font-size:var(--text-body)}.portal-table th{text-align:left;font-weight:600;color:var(--text-secondary);font-size:var(--text-small);text-transform:uppercase;letter-spacing:.04em;padding:8px 12px;border-bottom:2px solid var(--border)}.portal-table td{padding:10px 12px;border-bottom:1px solid var(--border-light);color:var(--text-primary)}.portal-table tbody tr:last-child td{border-bottom:none}.portal-table tbody tr:hover{background-color:var(--surface-bar)}.portal-table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.portal-table-wrap .portal-table{min-width:560px}.portal-card__subtitle{font-size:var(--text-body);font-weight:600;color:var(--text-secondary);margin:0 0 8px}.status-badge{display:inline-block;font-size:var(--text-small);font-weight:600;padding:2px 10px;border-radius:12px;text-transform:capitalize}.status-badge--pending{background-color:#fef3c7;color:#92400e}.status-badge--approved{background-color:#d1fae5;color:#065f46}.status-badge--rejected{background-color:#fee2e2;color:#991b1b}.status-badge--applied{background-color:#dbeafe;color:#1e40af}.status-badge--in-review{background-color:#ede9fe;color:#5b21b6}.status-badge--accepted-change{background-color:#ecfdf5;color:#047857}.status-badge--rejected-change{background-color:#fef2f2;color:#b91c1c}.status-badge--pending-change{background-color:#fff7ed;color:#c2410c}.status-badge--neutral{background-color:var(--surface-bar);color:var(--text-secondary)}.alert--success{background-color:#d1fae5;color:#065f46;border:1px solid #a7f3d0;border-radius:var(--radius);padding:10px 16px;font-size:var(--text-body)}.ta-clock{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px 0}.ta-clock__status{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:600;color:var(--text-primary)}.ta-clock__indicator{width:14px;height:14px;border-radius:50%;background-color:var(--border);flex-shrink:0}.ta-clock__indicator--active{background-color:#22c55e;box-shadow:0 0 0 4px #22c55e33;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{box-shadow:0 0 0 4px #22c55e33}50%{box-shadow:0 0 0 8px #22c55e1a}}.ta-clock__elapsed{font-size:48px;font-weight:300;font-variant-numeric:tabular-nums;color:var(--text-hero);letter-spacing:2px;line-height:1}.ta-clock__since{font-size:var(--text-small);color:var(--text-secondary);margin:0}.ta-clock__actions{margin-top:8px}.btn--lg{padding:14px 40px;font-size:16px;font-weight:600;border-radius:6px}.ta-clock__location{font-size:var(--text-small);color:var(--text-secondary);margin:8px 0 0}.ta-clock__geofence{color:var(--accent-hr)}.status-badge--draft{background-color:var(--surface-bar);color:var(--text-secondary)}.status-badge--submitted{background-color:#dbeafe;color:#1e40af}.status-badge--cancelled{background-color:var(--surface-bar);color:var(--text-disabled)}.login-card__admin-cog{position:absolute;bottom:16px;right:16px;background:none;border:none;color:var(--text-disabled);cursor:pointer;padding:6px;border-radius:50%;transition:color .2s ease,background-color .2s ease;line-height:0}.login-card__admin-cog:hover{color:var(--text-secondary);background-color:var(--surface-bar)}.login-card{position:relative}.admin-overlay,.admin-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.admin-modal.leave-detail-modal,.admin-modal.leave-decide-modal{max-width:560px;max-height:min(90vh,720px);overflow-y:auto}.admin-modal{background:var(--surface-card);border-radius:var(--radius-card);padding:32px;max-width:420px;width:100%;box-shadow:0 12px 40px #0003}.admin-modal__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.admin-modal__title{font-size:var(--text-card-title);font-weight:700;color:var(--text-hero);margin:0}.admin-modal__close{background:none;border:none;font-size:24px;color:var(--text-secondary);cursor:pointer;padding:0 4px;line-height:1}.admin-modal__close:hover{color:var(--text-primary)}.admin-modal__desc{font-size:var(--text-body);color:var(--text-secondary);margin:0 0 20px;line-height:1.5}.settings-layout{min-height:100vh;display:flex;flex-direction:column;background-color:var(--surface-page)}.settings-topbar{background:linear-gradient(180deg,var(--topbar-start) 0%,var(--topbar-end) 100%);padding:12px 32px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.settings-topbar__brand{display:flex;align-items:center;gap:16px}.settings-topbar__logo{height:28px;width:auto;background:#fff;padding:4px 8px;border-radius:6px}.settings-topbar__title{color:#fff;font-size:var(--text-card-title);font-weight:600}.settings-topbar__actions{display:flex;gap:8px}.settings-topbar__actions .btn{color:#fff;border-color:#ffffff4d;background:#ffffff1a}.settings-topbar__actions .btn:hover{background:#fff3}.settings-main{flex:1;padding:40px 48px;overflow:auto}.settings-list{display:flex;flex-direction:column}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border-light);gap:24px}.settings-row:last-child{border-bottom:none}.settings-row__info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.settings-row__name{font-size:var(--text-body);font-weight:600;color:var(--text-primary)}.settings-row__desc{font-size:var(--text-small);color:var(--text-secondary);line-height:1.4}.settings-row__control{display:flex;align-items:center;gap:8px;flex-shrink:0}.settings-row__saving{font-size:var(--text-small);color:var(--text-secondary)}.settings-row__saved{font-size:var(--text-small);color:#059669;font-weight:600}.toggle{position:relative;display:inline-block;cursor:pointer}.toggle input{position:absolute;opacity:0;width:0;height:0}.toggle__track{display:block;width:44px;height:24px;background-color:var(--border);border-radius:12px;transition:background-color .2s ease;position:relative}.toggle__track:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background-color:#fff;border-radius:50%;box-shadow:0 1px 3px #0003;transition:transform .2s ease}.toggle input:checked+.toggle__track{background-color:var(--accent-hr)}.toggle input:checked+.toggle__track:after{transform:translate(20px)}.toggle input:focus-visible+.toggle__track{box-shadow:0 0 0 3px #0e7c6b4d}.toggle input:disabled+.toggle__track{opacity:.5;cursor:not-allowed}.toggle--compact .toggle__track{width:36px;height:20px}.toggle--compact .toggle__track:after{width:16px;height:16px;top:2px;left:2px}.toggle--compact input:checked+.toggle__track:after{transform:translate(16px)}.admin-tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:1px solid var(--border-light);padding-bottom:0}.admin-tabs__btn{padding:10px 18px;font-size:var(--text-body);font-weight:600;color:var(--text-secondary);background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer}.admin-tabs__btn:hover{color:var(--text-primary)}.admin-tabs__btn--active{color:var(--accent);border-bottom-color:var(--accent)}.settings-row__key{font-size:var(--text-small);font-family:ui-monospace,monospace;color:var(--text-secondary)}.settings-catalog__scroll{overflow-x:auto;margin-top:12px;-webkit-overflow-scrolling:touch}.settings-catalog__table{min-width:960px;font-size:var(--text-small)}.settings-catalog__code{font-size:11px;word-break:break-all}.notifications-page__header{display:flex;flex-wrap:wrap;align-items:flex-end;gap:12px 24px;margin-bottom:24px}.notifications-page__title{font-size:var(--text-portal-title);font-weight:700;margin:0;flex:1 1 100%}.notifications-page__subtitle{margin:0;color:var(--text-secondary);font-size:var(--text-body);flex:1 1 240px}.notifications-page__empty{color:var(--text-secondary);padding:24px 0}.notifications-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.notifications-list__card{position:relative;width:100%;text-align:left;padding:16px 18px 16px 20px;border:1px solid var(--border-light);border-radius:12px;background:var(--surface-card, #fff);cursor:pointer;font:inherit;color:inherit;box-shadow:0 1px 2px #0f172a0f}.notifications-list__card:hover{border-color:#0e7c6b59}.notifications-list__card--read{opacity:.92}.notifications-list__meta{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:8px}.notifications-list__title{font-weight:600;font-size:var(--text-card-title)}.notifications-list__time{font-size:var(--text-small);color:var(--text-secondary);flex-shrink:0}.notifications-list__body{margin:0;font-size:var(--text-body);line-height:1.5;white-space:pre-wrap}.notifications-list__dot{position:absolute;top:14px;right:14px;width:8px;height:8px;border-radius:50%;background:#2563eb}.portal-sidebar__notif-link{display:flex;align-items:center;gap:8px;width:100%}.portal-sidebar__notif-badge{min-width:1.25rem;padding:0 6px;font-size:11px;font-weight:700;line-height:1.25rem;text-align:center;border-radius:999px;background:#ef4444;color:#fff}.notification-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;display:flex;align-items:center;justify-content:center;padding:24px;background:#0f172a73}.notification-dialog-backdrop--strong{background:#0f172a9e}.notification-dialog{width:min(520px,100%);max-height:min(80vh,640px);overflow:auto;border-radius:14px;background:var(--surface-card, #fff);border:1px solid var(--border-light);box-shadow:0 18px 48px #0f172a2e}.notification-dialog__header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 18px 0 20px}.notification-dialog__title{margin:0;font-size:1.15rem;font-weight:700}.notification-dialog__close{border:none;background:transparent;font-size:1.5rem;line-height:1;cursor:pointer;color:var(--text-secondary);padding:0 4px}.notification-dialog__time{margin:0 20px 12px;font-size:var(--text-small);color:var(--text-secondary)}.notification-dialog__body{margin:0 20px 16px;font-size:var(--text-body);line-height:1.55;white-space:pre-wrap}.notification-dialog__action{margin:0 20px 16px;font-size:var(--text-small)}.notification-dialog__footer{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;padding:12px 20px 18px;border-top:1px solid var(--border-light)}.ta-pending-empty{color:var(--text-secondary);padding:12px 0}.ta-pending-list{display:flex;flex-direction:column;gap:20px}.ta-pending-card{border:1px solid var(--border-light);border-radius:12px;padding:16px 18px;background:var(--surface-card, #fff)}.ta-pending-card__meta{display:flex;flex-wrap:wrap;justify-content:space-between;gap:8px 16px;margin-bottom:10px;font-size:var(--text-small);color:var(--text-secondary)}.ta-pending-card__notes{margin:0 0 12px;font-size:var(--text-body);line-height:1.45}.ta-pending-table code{font-size:12px}.leave-approvals-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;margin-left:8px;padding:0 6px;border-radius:999px;background:var(--accent);color:#fff;font-size:12px;font-weight:600;vertical-align:middle}.leave-approvals-cards{display:flex;flex-direction:column;gap:14px;margin-bottom:20px}.leave-approval-card{border:1px solid var(--border-light);border-radius:12px;background:var(--surface-card, #fff);overflow:hidden}.leave-approval-card__main{display:block;width:100%;padding:14px 16px;border:none;background:transparent;text-align:left;cursor:pointer;font:inherit;color:inherit}.leave-approval-card__main:hover{background:#f7f9fb}.leave-approval-card__head{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}.leave-approval-card__type{margin:0 0 4px;color:var(--text-secondary);font-size:var(--text-body)}.leave-approval-card__dates{margin:0;font-size:var(--text-body)}.leave-approval-card__days{margin-left:8px;color:var(--text-secondary)}.leave-approval-card__hint{margin:8px 0 0;font-size:var(--text-small);color:var(--text-secondary)}.leave-approval-card__actions{display:flex;flex-wrap:wrap;gap:8px;padding:0 16px 14px}.leave-approvals-table-wrap{display:none}.leave-approvals-table__row{cursor:pointer}.leave-approvals-table__actions{white-space:nowrap}.leave-approvals-table__actions .btn{margin-right:6px}.leave-detail-dl{display:grid;gap:10px 16px;margin:0 0 16px}.leave-detail-dl div{display:grid;grid-template-columns:100px 1fr;gap:8px;align-items:start}.leave-detail-dl dt{margin:0;font-size:var(--text-small);font-weight:600;color:var(--text-secondary)}.leave-detail-dl dd{margin:0;font-size:var(--text-body)}.leave-detail-trail-title{margin:0 0 10px;font-size:var(--text-section)}.leave-detail-trail{margin:0 0 16px;padding-left:20px;display:flex;flex-direction:column;gap:10px}.leave-detail-trail li{font-size:var(--text-body)}.leave-detail-trail p{margin:4px 0 0;color:var(--text-secondary)}.leave-detail-actions{margin-top:8px}.leave-detail-actions__group{display:inline-flex;gap:8px}@media (min-width: 768px){.leave-approvals-cards{display:none}.leave-approvals-table-wrap{display:block}}@media (max-width: 767px){.leave-approvals-table-wrap{display:none}}.hr-change-toolbar{display:flex;flex-wrap:wrap;align-items:flex-end;gap:12px 16px;margin-bottom:20px}.hr-change-toolbar__filter{display:flex;flex-direction:column;gap:4px}.hr-change-toolbar__filter-label{font-size:var(--text-small);color:var(--text-secondary)}.hr-change-queue{list-style:none;margin:0;padding:0}.hr-change-queue__item{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px 0;border-bottom:1px solid var(--border-light)}.hr-change-queue__item:last-child{border-bottom:none}.hr-change-queue__head{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.hr-change-queue__meta{margin:4px 0 0;font-size:var(--text-small);color:var(--text-secondary)}.hr-change-queue__actions{display:flex;flex-wrap:wrap;gap:8px}.admin-modal.hr-change-detail-modal{max-width:720px;width:calc(100% - 32px);max-height:90vh;overflow-y:auto}.hr-change-detail__meta{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px 16px;margin:0 0 20px}.hr-change-detail__meta dt{font-size:var(--text-small);color:var(--text-secondary);margin:0}.hr-change-detail__meta dd{margin:4px 0 0;font-weight:600}.hr-change-detail__section-title{font-size:var(--text-section);font-weight:600;margin:20px 0 8px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary)}.hr-change-detail__actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-light)}.hr-change-preview{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px 16px;margin:0}.hr-change-preview__field--wide{grid-column:1 / -1}.hr-change-preview__label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);margin:0}.hr-change-preview__value{margin:4px 0 0;font-size:var(--text-body)}.hr-change-preview__value--pre{white-space:pre-line}.hr-change-diff-table__row--changed{background:color-mix(in srgb,var(--accent) 8%,transparent)}.hr-change-diff-table__requested{color:var(--accent);font-weight:600}.hr-change-tech-details{margin-top:16px;border:1px solid var(--border-light);border-radius:var(--radius);background:var(--surface-bar)}.hr-change-tech-details__summary{padding:10px 12px;font-size:var(--text-small);font-weight:600;color:var(--text-secondary);cursor:pointer}.hr-change-tech-details__pre{margin:0;padding:12px;max-height:200px;overflow:auto;font-size:11px;font-family:ui-monospace,monospace;border-top:1px solid var(--border-light)}.pwa-install-banner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;margin:0 var(--space-page-h);padding:12px 16px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:var(--radius)}.pwa-install-banner__copy{display:flex;flex-direction:column;gap:2px;font-size:var(--text-small);color:var(--text-secondary)}.pwa-install-banner__copy strong{color:var(--text-primary);font-size:var(--text-body)}.pwa-install-banner__actions{display:flex;flex-wrap:wrap;gap:8px}.portal-offline-banner{margin:0;padding:10px var(--space-page-h);background:#fff7ed;border-bottom:1px solid #fed7aa;color:#9a3412;font-size:var(--text-small)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (max-width: 767px){.app-shell--sidebar{flex-direction:column}.portal-breadcrumb__menu-btn{display:inline-flex}.portal-sidebar{position:fixed;inset:0 auto 0 0;z-index:120;width:min(280px,86vw);min-width:0;transform:translate(-105%);transition:transform .2s ease;box-shadow:8px 0 24px #0f172a2e}.app-shell--sidebar-open .portal-sidebar{transform:translate(0)}.portal-sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:110;border:none;padding:0;background:#0f172a73;cursor:pointer}.portal-main{padding-top:16px}.pwa-install-banner{margin-top:12px}.ta-clock__elapsed{font-size:40px}.btn--lg{width:100%;max-width:320px}.leave-approvals-table-wrap .portal-table{min-width:640px}}@media (prefers-reduced-motion: reduce){.portal-card,.request-card,.btn,.input,.select,.portal-topbar__link,.portal-topbar__logout,.portal-sidebar__link,.portal-sidebar__icon-btn,.portal-sidebar__logout,.portal-sidebar,.login-card{transition:none}.loading-spinner{animation:none;border-top-color:transparent}}*{box-sizing:border-box}body{margin:0;font-family:var(--font-sans);font-size:var(--text-body);color:var(--text-primary);background-color:var(--surface-page);-webkit-font-smoothing:antialiased;line-height:1.5}#root{min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover);text-decoration:underline}
