.app-header{position:sticky;top:0;z-index:var(--z-index-sticky);display:flex;align-items:center;padding:.7rem .9rem;border-bottom:1px solid var(--color-border-light);background:#ffffffeb;color:var(--color-text-primary);box-shadow:0 18px 34px -30px #003b732e;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px)}.header-content{display:flex;justify-content:space-between;align-items:center;width:100%;gap:1rem}.header-content--mobile{justify-content:space-between}.app-header__brand{display:flex;align-items:center;min-width:0;flex:1}.app-header__page-copy{display:flex;min-width:0;flex-direction:column;gap:.1rem}.app-title{margin:0;font-size:clamp(1.45rem,2.4vw,2.2rem);font-weight:var(--font-weight-semibold);color:var(--color-primary);letter-spacing:-.03em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-header__description{margin:0;color:var(--color-text-secondary);font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-menu-btn{display:inline-flex;align-items:center;justify-content:center;width:2.35rem;height:2.35rem;flex-shrink:0;border:1px solid var(--color-border-light);border-radius:.9rem;background:#fffffff5;color:var(--color-primary);box-shadow:0 14px 30px -26px #003b7333}.mobile-menu-btn:hover{border-color:var(--color-border-hover);background:var(--color-primary-light)}.app-header__actions{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;flex-wrap:wrap;min-width:0;position:relative}.app-header__page-actions{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;flex-wrap:wrap}.app-header__account{position:relative;max-width:100%}.app-header__account-trigger{display:flex;align-items:center;gap:.7rem;min-width:16rem;max-width:100%;padding:.4rem .7rem .4rem .45rem;border:1px solid var(--color-border-light);border-radius:999px;background:#fffffff5;color:var(--color-text-primary);text-align:left;transition:background-color var(--transition-fast),border-color var(--transition-fast)}.app-header__account-trigger:hover{border-color:var(--color-border-hover);background:var(--color-bg-hover)}.app-header__avatar{display:flex;width:2rem;height:2rem;align-items:center;justify-content:center;flex-shrink:0;border:1px solid rgba(0,59,115,.12);border-radius:999px;background:linear-gradient(145deg,#003b731f,#69be2833);color:var(--color-primary);font-size:.78rem;font-weight:var(--font-weight-semibold)}.app-header__user-copy{min-width:0;flex:1}.app-header__user-name{display:block;color:var(--color-text-primary);font-size:.9rem;font-weight:var(--font-weight-semibold);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-header__user-email{display:block;margin-top:.1rem;color:var(--color-text-muted);font-size:.78rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-header__chevron{color:var(--color-text-muted);flex-shrink:0;transition:transform var(--transition-fast)}.app-header__chevron.is-open{transform:rotate(180deg)}.app-header__account-menu{position:absolute;top:calc(100% + .55rem);right:0;z-index:20;width:min(18rem,92vw);padding:.6rem;border:1px solid var(--color-border-light);border-radius:1rem;background:#fffffffa;box-shadow:0 24px 54px -34px #003b7342;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px)}.app-header__account-meta{padding:.8rem .85rem;border:1px solid var(--color-border-light);border-radius:.9rem;background:var(--color-bg-surface)}.app-header__account-role{color:var(--color-primary);font-size:.82rem;font-weight:var(--font-weight-semibold)}.app-header__account-tenant{margin-top:.2rem;color:var(--color-text-secondary);font-size:.76rem}.app-header__logout{display:flex;align-items:center;justify-content:flex-start;gap:.5rem;width:100%;min-height:2.5rem;margin-top:.55rem;padding:.65rem .9rem;border:1px solid rgba(239,68,68,.16);border-radius:1rem;background:#fffffff0;color:var(--color-danger-text);transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.app-header__logout:hover{background:var(--color-danger-bg);border-color:#ef444438;color:var(--color-danger-text)}@media (max-width: 767px){.app-header{padding:.7rem .75rem}.header-content{flex-wrap:wrap}.app-header__brand{order:1;flex:1;min-width:0}.mobile-menu-btn{order:0}.app-header__actions{order:2;width:100%}.app-header__page-actions{width:100%}.app-header__account{flex:1}.app-header__account-trigger{min-width:0;width:100%}}.badge{display:inline-flex;align-items:center;padding:.35rem .65rem;border-radius:var(--radius-full);font-size:.64rem;font-weight:var(--font-weight-bold);line-height:1;letter-spacing:.14em;text-transform:uppercase;white-space:nowrap;border:1px solid transparent}.badge--default{background-color:#003b7314;color:var(--color-primary);border-color:#003b731a}.badge--primary{background-color:var(--color-primary-light);color:var(--color-primary);border-color:#003b731a}.badge--secondary{background-color:#94a3b824;color:#475569;border-color:#94a3b82e}.badge--success{background-color:var(--color-success-bg);color:var(--color-success-text);border-color:#69be2829}.badge--warning{background-color:var(--color-warning-bg);color:var(--color-warning-text);border-color:#f59e0b29}.badge--danger{background-color:var(--color-danger-bg);color:var(--color-danger-text);border-color:#ef444429}.badge--info{background-color:var(--color-info-bg);color:var(--color-info-text);border-color:#3b82f629}.app-sidebar{position:relative;display:flex;min-width:88px;flex-direction:column;flex-shrink:0;overflow:hidden;border-right:1px solid var(--color-border-light);background:linear-gradient(180deg,#fffffffa,#f4f8fbf5);color:var(--color-text-primary);box-shadow:24px 0 52px -42px #003b7347;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);transition:width .32s cubic-bezier(.22,1,.36,1);will-change:width;z-index:var(--z-index-sticky)}.sidebar-content{flex:1;min-height:0;overflow-y:auto;padding:.9rem .7rem .85rem;overscroll-behavior:contain;scrollbar-width:none;-ms-overflow-style:none}.sidebar-content::-webkit-scrollbar{display:none}.sidebar-brand{display:flex;align-items:flex-start;gap:.95rem;margin:0 .35rem .8rem;padding:0 0 .95rem;border-bottom:1px solid var(--color-border-light)}.sidebar-brand__trigger{display:inline-flex;align-items:center;justify-content:center;padding:0;border:0;background:transparent;cursor:default}.sidebar-brand__trigger.is-compact{cursor:pointer}.sidebar-brand__mark{display:flex;height:3.2rem;width:3.2rem;align-items:center;justify-content:center;padding:.05rem;border-radius:1.15rem;background:transparent;color:#fff;box-shadow:0 18px 34px -24px #003b7366}.sidebar-brand__logo{display:block;width:100%;height:100%;object-fit:contain}.sidebar-brand__copy{min-width:0;flex:1 1 auto;max-height:3rem;max-width:100%;overflow:hidden;transform-origin:left center;transition:opacity .14s ease,transform .22s cubic-bezier(.22,1,.36,1),max-height .22s ease,max-width .32s cubic-bezier(.22,1,.36,1)}.sidebar-brand__wordmark{display:block;width:auto;max-width:100%;height:1.35rem;object-fit:contain}.sidebar-brand__title{margin:.18rem 0 0;color:var(--color-primary);font-size:1.08rem;font-weight:var(--font-weight-semibold);letter-spacing:-.04em}.sidebar-brand__subtitle{margin:.35rem 0 0;color:var(--color-text-secondary);font-size:.86rem;line-height:1.5}.nav-section{margin-bottom:.85rem;padding:0 .35rem}.nav-section:last-child{margin-bottom:0}.nav-section-title{margin-bottom:.4rem;padding:0 .6rem;color:var(--color-text-muted);font-size:.68rem;font-weight:var(--font-weight-semibold);letter-spacing:.24em;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-height:1rem;transform-origin:left center;transition:opacity .12s ease,transform .22s cubic-bezier(.22,1,.36,1),max-height .22s ease,margin-bottom .22s ease,padding-top .22s ease,padding-bottom .22s ease}.nav-link{display:flex;align-items:center;gap:.65rem;margin-bottom:.22rem;padding:.62rem .72rem;border:1px solid transparent;border-radius:1.15rem;color:var(--color-text-secondary);font-size:.88rem;font-weight:var(--font-weight-medium);text-decoration:none;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),transform var(--transition-fast);white-space:nowrap;overflow:hidden}.nav-link__icon{display:flex;height:2rem;width:2rem;flex-shrink:0;align-items:center;justify-content:center;border:1px solid var(--color-border-light);border-radius:.85rem;background:#ffffffeb;color:var(--color-text-secondary);transition:inherit}.nav-link__icon svg{width:1.05rem;height:1.05rem}.nav-link__label{flex:1 1 auto;min-width:0;max-width:100%;overflow:hidden;text-overflow:ellipsis;transform-origin:left center;transition:opacity .14s ease,transform .22s cubic-bezier(.22,1,.36,1),max-width .32s cubic-bezier(.22,1,.36,1)}.nav-link__meta{display:flex;min-width:0;flex:1;max-width:100%;align-items:center;justify-content:space-between;gap:.5rem;overflow:hidden;transform-origin:left center;transition:opacity .14s ease,transform .22s cubic-bezier(.22,1,.36,1),max-width .32s cubic-bezier(.22,1,.36,1)}.nav-link:hover{background:var(--color-bg-hover);border-color:var(--color-border-hover);color:var(--color-primary-dark);transform:translateY(-1px)}.nav-link.active{background:#003b7314;border-color:#003b732e;color:var(--color-primary-dark);font-weight:var(--font-weight-semibold);box-shadow:0 18px 36px -30px #003b7352}.nav-link.active .nav-link__icon{border-color:#003b732e;background:#fffffff5;color:var(--color-primary)}.nav-badge{display:flex;min-width:1.15rem;height:1.15rem;align-items:center;justify-content:center;padding:.2rem .42rem;font-size:.58rem;font-weight:var(--font-weight-bold)}.sidebar-toggle{position:absolute;top:1rem;right:1rem;display:flex;width:2rem;height:2rem;align-items:center;justify-content:center;border:1px solid var(--color-border-light);border-radius:.8rem;background:#ffffffeb;color:var(--color-primary);box-shadow:0 14px 28px -24px #003b7352;cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),opacity .14s ease,transform .22s cubic-bezier(.22,1,.36,1);z-index:10}.sidebar-toggle:hover{background:var(--color-primary-light);border-color:var(--color-border-hover);color:var(--color-primary-dark)}.sidebar-resizer{position:absolute;top:0;right:0;width:4px;height:100%;background:transparent;cursor:col-resize;transition:background var(--transition-fast);z-index:20}.sidebar-resizer:hover,.sidebar-resizer:active{background:#69be2899}.app-sidebar.collapsed{width:92px!important}.app-sidebar.collapsed .sidebar-brand__copy,.app-sidebar.collapsed .sidebar-user-copy,.app-sidebar.collapsed .nav-link__meta,.app-sidebar.collapsed .nav-link__label{max-height:0;max-width:0;opacity:0;transform:translate(-10px);pointer-events:none}.app-sidebar.collapsed .sidebar-content{padding-top:.85rem}.app-sidebar.collapsed .sidebar-brand{justify-content:center;margin-top:.1rem;padding-bottom:.95rem;gap:0}.app-sidebar.collapsed .sidebar-toggle{opacity:0;transform:translate(.35rem);pointer-events:none}.app-sidebar.collapsed .nav-section-title{max-height:0;margin-bottom:0;padding-top:0;padding-bottom:0;opacity:0;transform:translate(-10px);pointer-events:none}.app-sidebar.collapsed .nav-link{justify-content:center;padding:.52rem;gap:0}.app-sidebar.collapsed .nav-link__icon{width:2.45rem;height:2.45rem;border-radius:1rem}.app-sidebar.collapsed .nav-link__icon svg{width:1.28rem;height:1.28rem}@media (max-width: 767px){.app-sidebar{height:100vh}.sidebar-toggle,.sidebar-resizer{display:none}}.app-container{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-body{display:flex;flex:1;width:100%;min-height:0;overflow:hidden}.app-content{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0}.app-main{flex:1;display:flex;flex-direction:column;gap:var(--spacing-lg);min-width:0;min-height:0;padding:1rem;overflow-y:auto;overflow-x:hidden}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;background:#0206178c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.sidebar-drawer{position:fixed;inset:0 auto 0 0;z-index:40;display:flex;transform:translate(-100%);transition:transform var(--transition-normal) ease}.sidebar-drawer.open{transform:translate(0)}@media (min-width: 768px){.app-main{padding:1.5rem 1.75rem}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;min-height:2.75rem;padding:.7rem 1.1rem;font-family:var(--font-family);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);line-height:1;border-radius:1rem;border:1px solid transparent;cursor:pointer;transition:background-color var(--transition-fast) ease,border-color var(--transition-fast) ease,color var(--transition-fast) ease,box-shadow var(--transition-fast) ease,transform var(--transition-fast) ease;text-decoration:none;white-space:nowrap;position:relative;isolation:isolate;box-shadow:0 18px 38px -24px #003b734d}.btn--primary{background:linear-gradient(180deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-text-inverse);border-color:#003b732e}.btn--primary:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:var(--color-primary-hover);opacity:0;z-index:-1;transition:opacity var(--transition-fast) ease;pointer-events:none}.btn--primary:hover:not(:disabled){border-color:#002a5238;transform:translateY(-1px);box-shadow:0 22px 42px -24px #003b7373}.btn--primary:hover:not(:disabled):before{opacity:1}.btn--secondary{background:#ffffffe6;color:var(--color-text-primary);border-color:#94a3b861;box-shadow:0 16px 30px -24px #0f172a3d}.btn--secondary:hover:not(:disabled){background:var(--color-primary-light);border-color:#003b732e;color:var(--color-primary);transform:translateY(-1px)}.btn--danger{background:linear-gradient(180deg,var(--color-danger) 0%,#dc2626 100%);color:var(--color-text-inverse);border-color:#dc262633}.btn--danger:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:#dc2626;opacity:0;z-index:-1;transition:opacity var(--transition-fast) ease;pointer-events:none}.btn--danger:hover:not(:disabled){border-color:#dc262640;transform:translateY(-1px)}.btn--danger:hover:not(:disabled):before{opacity:1}.btn--success{background:linear-gradient(180deg,var(--color-success) 0%,var(--color-success-text) 100%);color:var(--color-text-inverse);border-color:#69be2833}.btn--success:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:var(--color-success-text);opacity:0;z-index:-1;transition:opacity var(--transition-fast) ease;pointer-events:none}.btn--success:hover:not(:disabled){border-color:#4c891d3d;transform:translateY(-1px)}.btn--success:hover:not(:disabled):before{opacity:1}.btn--warning{background:linear-gradient(180deg,var(--color-warning) 0%,#d97706 100%);color:var(--color-text-inverse);border-color:#d977062e}.btn--warning:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:#d97706;opacity:0;z-index:-1;transition:opacity var(--transition-fast) ease;pointer-events:none}.btn--warning:hover:not(:disabled){border-color:#d977063d;transform:translateY(-1px)}.btn--warning:hover:not(:disabled):before{opacity:1}.btn--ghost{background-color:transparent;color:var(--color-text-secondary);border-color:transparent;box-shadow:none}.btn--ghost:hover:not(:disabled){background:#ffffffa8;color:var(--color-primary)}.btn--sm{min-height:2.25rem;padding:.5rem .85rem;border-radius:.85rem;font-size:var(--font-size-xs)}.btn--lg{min-height:3rem;padding:.9rem 1.35rem;border-radius:1.15rem;font-size:var(--font-size-base)}.btn--block{display:flex;width:100%}.btn:disabled,.btn--disabled{opacity:.6;cursor:not-allowed;pointer-events:none;background-color:var(--color-bg-disabled);color:var(--color-text-disabled);border-color:var(--color-border)}.btn:focus-visible{outline:none;box-shadow:0 0 0 4px var(--color-primary-ring),0 18px 38px -24px #003b734d}.btn--loading{color:transparent!important;pointer-events:none;position:relative}.btn--loading:after{content:"";position:absolute;width:1em;height:1em;top:50%;left:50%;margin-top:-.5em;margin-left:-.5em;border:2px solid currentColor;border-radius:50%;border-right-color:transparent;animation:spin .75s linear infinite;color:var(--color-text-secondary)}.btn--primary.btn--loading:after,.btn--danger.btn--loading:after,.btn--success.btn--loading:after,.btn--warning.btn--loading:after{color:var(--color-text-inverse)}.input-wrapper{display:flex;flex-direction:column;gap:.45rem;margin-bottom:var(--spacing-md);width:100%}.input-label{display:flex;justify-content:space-between;font-size:.8rem;font-weight:var(--font-weight-semibold);color:var(--color-text-secondary)}.input-label-optional{color:var(--color-text-muted);font-weight:var(--font-weight-normal);font-size:var(--font-size-xs)}.input-container{position:relative;display:flex;align-items:center}.input-field{width:100%;min-height:2.75rem;padding:.75rem 1rem;font-size:var(--font-size-base);font-family:var(--font-family);color:var(--color-text-primary);background:#ffffffeb;border:1px solid rgba(148,163,184,.34);border-radius:1rem;box-shadow:inset 0 1px #ffffffd1;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast)}.input-field:hover:not(:disabled){border-color:#003b7338}.input-field:focus{outline:none;border-color:#003b734d;box-shadow:0 0 0 4px var(--color-primary-ring)}.input-field:disabled{background-color:var(--color-bg-disabled);color:var(--color-text-disabled);cursor:not-allowed}.input-field::placeholder{color:var(--color-text-muted)}.input-field.has-error{border-color:var(--color-danger)}.input-field.has-error:focus{box-shadow:0 0 0 4px #ef444424}.input-error-message{font-size:var(--font-size-xs);color:var(--color-danger);margin-top:var(--spacing-2xs)}.input-icon-left{position:absolute;left:.85rem;color:var(--color-text-muted);pointer-events:none;display:flex;align-items:center}.input-icon-right{position:absolute;right:.85rem;color:var(--color-text-muted);display:flex;align-items:center;cursor:pointer}.input-field--with-icon-left{padding-left:2.75rem}.input-field--with-icon-right{padding-right:2.75rem}.card{display:flex;flex-direction:column;overflow:hidden;background:#ffffffe0;border:1px solid rgba(255,255,255,.72);border-radius:1.5rem;box-shadow:0 30px 80px -44px #003b7361;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast)}.card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:1.5rem 1.75rem;border-bottom:1px solid var(--color-border-light)}.card-header h2,.card-header h3{margin:0;font-size:1.25rem;font-weight:var(--font-weight-semibold);letter-spacing:-.03em}.card-body{flex:1;padding:1.5rem 1.75rem}.card-footer{padding:1.25rem 1.75rem;border-top:1px solid var(--color-border-light);background:#f8fafcb8}.card--hoverable:hover{transform:translateY(-2px);box-shadow:0 36px 88px -46px #003b736b;border-color:#003b7324}.alert{display:flex;gap:.9rem;align-items:flex-start;padding:1rem 1.1rem;margin-bottom:var(--spacing-lg);font-size:var(--font-size-sm);border:1px solid transparent;border-radius:1.2rem;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.alert--info{background:#dbeafeb3;color:var(--color-info-text);border-color:#3b82f624}.alert--success{background:#edf7e5d1;color:var(--color-success-text);border-color:#69be282e}.alert--warning{background:#fef3c7d1;color:var(--color-warning-text);border-color:#f59e0b2e}.alert--error{background:#fee2e2d1;color:var(--color-danger-text);border-color:#ef44442e}.alert-icon{display:flex;width:2.25rem;height:2.25rem;flex-shrink:0;align-items:center;justify-content:center;margin-top:.1rem;border-radius:.9rem;background:#fff9}.alert-content{flex:1}.alert-title{display:block;margin-bottom:var(--spacing-xs);font-weight:var(--font-weight-semibold)}.login-page{position:relative;display:flex;min-height:100vh;align-items:center;justify-content:center;overflow:hidden;padding:1.25rem}.login-page:before,.login-page:after{content:"";position:absolute;border-radius:999px;filter:blur(80px)}.login-page:before{top:-10%;left:-8%;width:18rem;height:18rem;background:#69be2829}.login-page:after{right:-8%;bottom:-12%;width:22rem;height:22rem;background:#003b7326}.login-shell{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;width:100%;max-width:480px;overflow:hidden;border:1px solid rgba(255,255,255,.72);border-radius:2rem;background:#ffffffb8;box-shadow:var(--shadow-xl);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px)}.login-showcase{display:none;flex-direction:column;justify-content:space-between;gap:2.5rem;min-height:100%;padding:2.25rem;background:#020617f5;color:#fff}.login-brand,.login-mobile-brand{display:flex;align-items:center;gap:1rem}.login-brand__mark{display:flex;height:3.2rem;width:3.2rem;align-items:center;justify-content:center;border-radius:1.2rem;background:linear-gradient(145deg,#69be28,#003b73);color:#fff;font-size:.82rem;font-weight:var(--font-weight-bold);letter-spacing:.18em}.login-brand__eyebrow,.login-copy__eyebrow,.login-header__eyebrow{margin:0;font-size:.7rem;font-weight:var(--font-weight-semibold);letter-spacing:.28em;text-transform:uppercase}.login-brand__eyebrow{color:#cbd5e1b8}.login-brand__title,.login-mobile-brand__title{margin:.15rem 0 0;font-size:1.9rem;font-weight:var(--font-weight-semibold);letter-spacing:-.04em}.login-copy{max-width:28rem}.login-copy__eyebrow{color:#8fd45c}.login-title{margin:.75rem 0 0;font-size:clamp(2.35rem,5vw,3.8rem);font-weight:var(--font-weight-semibold);line-height:1.05;letter-spacing:-.05em}.login-copy__text{margin:1rem 0 0;color:#cbd5e1c2;line-height:1.8}.login-showcase__card{max-width:25rem;padding:1.4rem;border:1px solid rgba(255,255,255,.1);border-radius:1.5rem;background:#ffffff0f}.login-showcase__label{margin:0;color:#fff;font-weight:var(--font-weight-semibold)}.login-showcase__text{margin:.55rem 0 0;color:#cbd5e1bd;line-height:1.6}.login-logo{width:320px;margin:2rem auto .5rem;display:block}.login-panel{display:flex;flex-direction:column;align-items:center;width:100%;padding:1.25rem}.login-card{width:100%;background:#ffffffe6;box-shadow:none}.login-card__body{padding:1.5rem}.login-header{margin-bottom:var(--spacing-xl)}.login-header__eyebrow{color:var(--color-primary)}.login-card__title{margin:.45rem 0 .35rem;font-size:2rem;font-weight:var(--font-weight-semibold);letter-spacing:-.04em}.login-footer{margin-top:var(--spacing-lg);color:var(--color-text-muted);font-size:.82rem;text-align:center}@media (min-width: 900px){.login-panel{padding:2rem}.login-card__body{padding:1.75rem}}.page-header{display:flex;flex-direction:column;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);margin-bottom:var(--spacing-sm)}.page-header h1{margin:0;font-size:clamp(2rem,3vw,2.7rem);letter-spacing:-.04em}.page-header__content{display:flex;flex-direction:column;gap:.35rem;min-width:0}.page-header__eyebrow{margin:0;color:var(--color-primary);font-size:.7rem;font-weight:var(--font-weight-semibold);letter-spacing:.28em;text-transform:uppercase}.page-header__description{max-width:52rem;margin:0;color:var(--color-text-secondary);line-height:1.7}.page-header__action{flex-shrink:0;display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}@media (min-width: 960px){.page-header{flex-direction:row;align-items:flex-end;gap:var(--spacing-lg)}}.dashboard-page .loading-container{text-align:center;padding:3rem}.dashboard-page .stats-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.dashboard-page .stats-card-label{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500}.dashboard-page .stats-card-value{font-size:var(--font-size-3xl);font-weight:700;margin-bottom:var(--spacing-md);line-height:1.2}.dashboard-page .stats-card-value.success{color:var(--color-success)}.dashboard-page .stats-card-value.danger{color:var(--color-danger)}.dashboard-page .stats-card-unit{font-size:var(--font-size-lg);font-weight:400;color:var(--color-text-secondary);margin-left:var(--spacing-xs)}.dashboard-page .stats-card-note{color:var(--color-text-muted);font-size:var(--font-size-xs);margin-bottom:var(--spacing-sm)}.dashboard-page .dashboard-link{text-decoration:none;display:block;height:100%}.dashboard-page .quick-action-icon{color:var(--color-primary);margin-bottom:var(--spacing-md)}.dashboard-page .section{margin-bottom:var(--spacing-xl)}.dashboard-page .section h2{margin-bottom:var(--spacing-md);font-size:var(--font-size-xl)}.table-container{width:100%;overflow-x:auto;background:#ffffffd6;border:1px solid rgba(255,255,255,.72);border-radius:1.4rem;box-shadow:0 26px 64px -44px #003b7366;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.table{width:100%;border-collapse:separate;border-spacing:0;font-size:var(--font-size-sm);text-align:left}.table thead{background:#e7f0f894}.table th{padding:.95rem 1.25rem;font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.16em;font-size:.68rem;white-space:nowrap}.table tbody tr td{border-top:1px solid var(--color-border-light);transition:background-color var(--transition-fast)}.table tbody tr:first-child td{border-top:none}.table tbody tr:hover{background:#e7f0f87a}.table td{padding:1rem 1.25rem;color:var(--color-text-primary);vertical-align:middle}.table th.table-col-balance-prev{color:var(--color-warning-text)}.table th.table-col-balance-new{color:var(--color-success-text)}.table td.table-col-balance-prev{background:#f59e0b0f}.table td.table-col-balance-new{background:#69be280f}.table tbody tr:hover td.table-col-balance-prev{background:#f59e0b1a}.table tbody tr:hover td.table-col-balance-new{background:#69be281a}.table th.table-cell-nowrap,.table td.table-cell-nowrap{white-space:nowrap}.table-row-clickable{cursor:pointer}.table-row-selected,.table-row-selected:hover{background:#e7f0f8cc}.table-empty{padding:var(--spacing-xl);text-align:center;color:var(--color-text-muted)}.table-balance-chip{display:inline-flex;align-items:center;justify-content:center;min-width:7.25rem;padding:.42rem .72rem;border-radius:999px;border:1px solid transparent;font-weight:var(--font-weight-semibold);line-height:1;color:var(--color-text-primary);box-shadow:inset 0 1px #ffffffb3}.table-balance-chip--prev{background:linear-gradient(180deg,#f59e0b2e,#fffffff5);border-color:#f59e0b47}.table-balance-chip--new{background:linear-gradient(180deg,#69be282e,#fffffff5);border-color:#69be2847}.table-balance-chip--negative,.table-balance-value--negative{color:var(--color-danger-text)}.table-balance-value{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;z-index:var(--z-index-modal-backdrop);background:#0206178c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn var(--transition-fast) ease-out}.modal{width:100%;max-width:500px;max-height:calc(100vh - 3rem);display:flex;flex-direction:column;margin:var(--spacing-md);background:#ffffffe6;border:1px solid rgba(255,255,255,.72);border-radius:1.5rem;box-shadow:var(--shadow-xl);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);z-index:var(--z-index-modal);animation:slideIn var(--transition-fast) ease-out}.modal--lg{max-width:800px}.modal--xl{max-width:1280px}.modal--xxl{max-width:1600px}.modal--sm{max-width:400px}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:1.4rem 1.5rem;border-bottom:1px solid var(--color-border-light)}.modal-title{margin:0;font-size:1.2rem;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);letter-spacing:-.03em}.modal-close{display:flex;align-items:center;justify-content:center;padding:.45rem;border:1px solid rgba(148,163,184,.16);border-radius:.8rem;background:#ffffffb8;color:var(--color-text-secondary);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.modal-close:hover{background-color:var(--color-primary-light);color:var(--color-primary);border-color:#003b7324}.modal-body{flex:1;padding:1.5rem;overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding:1.25rem 1.5rem;border-top:1px solid var(--color-border-light);background:#f8fafcb8;border-bottom-left-radius:1.5rem;border-bottom-right-radius:1.5rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.record-details-modal{display:flex;flex-direction:column;gap:var(--spacing-lg)}.record-details-modal-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.record-details-section{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-base);overflow:hidden}.record-details-section-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border-light);background:var(--color-bg-surface)}.record-details-section-header h3{margin:0;font-size:var(--font-size-lg)}.record-details-section-header p{margin:.35rem 0 0;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.record-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--spacing-md);padding:var(--spacing-lg)}.record-details-item{display:flex;flex-direction:column;gap:.35rem;min-width:0}.record-details-item.full-width{grid-column:1 / -1}.record-details-label{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.record-details-value{color:var(--color-text-primary);font-weight:var(--font-weight-medium);word-break:break-word}.record-details-value--preformatted{white-space:pre-wrap;font-family:var(--font-family-mono, monospace);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm)}.col-filter-header{display:inline-flex;align-items:center;gap:4px;white-space:nowrap}.col-filter-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border:1px solid transparent;background:transparent;cursor:pointer;border-radius:999px;color:var(--color-text-secondary);padding:0;flex-shrink:0;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.col-filter-btn:hover{background:#003b7314;color:var(--color-primary)}.col-filter-btn.active{background:var(--color-primary-light, #e8f0fe);color:var(--color-primary);border-color:#003b731f}.col-filter-popup{position:absolute;z-index:9999;min-width:220px;display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);background:#fffffff5;border:1px solid rgba(255,255,255,.74);border-radius:1rem;box-shadow:0 24px 52px -30px #003b7347;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.col-filter-popup label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);margin-bottom:2px}.col-filter-popup input,.col-filter-popup select{box-sizing:border-box;width:100%;min-height:2.45rem;padding:.6rem .8rem;font-size:var(--font-size-sm);color:var(--color-text-primary);background:#ffffffeb;border:1px solid rgba(148,163,184,.3);border-radius:.85rem}.col-filter-popup input:focus,.col-filter-popup select:focus{outline:none;border-color:#003b7342;box-shadow:0 0 0 4px var(--color-primary-ring)}.col-filter-popup-row{display:flex;flex-direction:column;gap:3px}.col-filter-clear{font-size:var(--font-size-xs);color:var(--color-primary);background:none;border:none;cursor:pointer;padding:0;align-self:flex-end;text-decoration:underline}.col-filter-clear:hover{color:var(--color-primary-dark, #1a56db)}.time-tracking-page .loading-container{text-align:center;padding:var(--spacing-xl)}.time-tracking-page .time-tracking-tabs{display:inline-flex;gap:var(--spacing-xs);padding:.35rem;width:fit-content;background:linear-gradient(180deg,#f0f4f7fa,#e7edf2f5);border:1px solid var(--color-border);border-radius:999px;margin-bottom:var(--spacing-lg)}.time-tracking-page .time-tracking-tab{border:0;background:transparent;color:var(--color-text-secondary);padding:.7rem 1.15rem;border-radius:999px;font:inherit;font-weight:var(--font-weight-semibold);cursor:pointer;transition:background-color .2s ease,color .2s ease,box-shadow .2s ease}.time-tracking-page .time-tracking-tab:hover{color:var(--color-text-primary)}.time-tracking-page .time-tracking-tab.active{color:var(--color-text-primary);background:var(--color-bg-surface);box-shadow:0 8px 20px #14213d14}.time-tracking-page .live-session-card{border-color:var(--color-primary)}.time-tracking-page .status-indicator{width:12px;height:12px;border-radius:50%;background-color:var(--color-success);box-shadow:0 0 0 4px var(--color-success-bg);display:inline-block}.time-tracking-page .status-indicator.pulsing{animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 0 0 var(--color-success-bg)}70%{box-shadow:0 0 0 10px #0000}to{box-shadow:0 0 #0000}}.time-tracking-page .live-duration-label{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.time-tracking-page .live-duration-value{font-size:var(--font-size-2xl);font-weight:700}.time-tracking-page .session-details{background-color:var(--color-bg-surface);padding:var(--spacing-md);border-radius:var(--border-radius-md);margin-bottom:var(--spacing-lg)}.time-tracking-page .detail-label{color:var(--color-text-secondary);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em}.time-tracking-page .detail-value,.time-tracking-page .cost-center-code{font-weight:500}.time-tracking-page .cost-center-name{font-size:.8em;color:var(--color-text-secondary)}.time-tracking-page .duration-highlight{color:var(--color-primary);font-weight:700}@media (max-width: 768px){.time-tracking-page .time-tracking-tabs{width:100%;display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.time-tracking-page .time-tracking-tab{text-align:center}}.absences-page .loading-container{text-align:center;padding:var(--spacing-xl)}.absences-page .info-card{padding:var(--spacing-lg);background-color:var(--color-bg-surface);border-radius:var(--border-radius-md);text-align:center;color:var(--color-text-secondary)}.absences-page .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.absences-page .description-text{max-width:300px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:inline-block}.absences-page .no-padding{padding:0}.overtime-payout-page .section{margin-bottom:var(--spacing-2xl)}.overtime-payout-page .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.overtime-payout-page .section-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.overtime-payout-page .balance-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:0 1px 3px #0000000d;margin-bottom:var(--spacing-xl)}.overtime-payout-page .balance-card-content{display:flex;align-items:center;gap:var(--spacing-lg)}.overtime-payout-page .balance-icon{width:48px;height:48px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.overtime-payout-page .balance-info{flex:1}.overtime-payout-page .balance-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.overtime-payout-page .balance-value{font-size:2rem;font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1}.overtime-payout-page .loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);gap:var(--spacing-md);color:var(--color-text-secondary)}.overtime-payout-page .form-grid{display:flex;flex-direction:column;gap:var(--spacing-lg)}.overtime-payout-page .form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.overtime-payout-page .form-group label{font-weight:var(--font-weight-medium);color:var(--color-text-primary);font-size:var(--font-size-md)}.overtime-payout-page .form-group input,.overtime-payout-page .form-group textarea{padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:var(--font-size-md);transition:border-color .15s ease;font-family:inherit}.overtime-payout-page .form-group input:focus,.overtime-payout-page .form-group textarea:focus{outline:none;border-color:var(--color-primary)}.overtime-payout-page .form-group input:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.overtime-payout-page .form-group small{font-size:var(--font-size-sm);color:#666}.overtime-payout-page .balance-info-box{padding:var(--spacing-md);background:#f8f9fa;border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.overtime-payout-page .balance-info-label{font-size:var(--font-size-sm);color:#666;margin-bottom:var(--spacing-xs)}.overtime-payout-page .balance-info-value{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.overtime-payout-page .modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.overtime-payout-page .text-success{color:var(--color-success);font-weight:var(--font-weight-bold)}.overtime-payout-page .text-danger{color:var(--color-danger);font-weight:var(--font-weight-bold)}.select-wrapper{display:flex;flex-direction:column;gap:.45rem;margin-bottom:var(--spacing-md);width:100%}.select-label{display:flex;justify-content:space-between;font-size:.8rem;font-weight:var(--font-weight-semibold);color:var(--color-text-secondary)}.select-label-optional{color:var(--color-text-muted);font-weight:var(--font-weight-normal);font-size:var(--font-size-xs)}.select-container{position:relative;display:flex;align-items:center}.select-field{width:100%;min-height:2.75rem;padding:.75rem 2.85rem .75rem 1rem;font-size:var(--font-size-base);font-family:var(--font-family);color:var(--color-text-primary);background:#ffffffeb;border:1px solid rgba(148,163,184,.34);border-radius:1rem;box-shadow:inset 0 1px #ffffffd1;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer}.select-field:hover:not(:disabled){border-color:#003b7338}.select-field:focus{outline:none;border-color:#003b734d;box-shadow:0 0 0 4px var(--color-primary-ring)}.select-field:disabled{background-color:var(--color-bg-disabled);color:var(--color-text-disabled);cursor:not-allowed}.select-field.has-error{border-color:var(--color-danger)}.select-field.has-error:focus{box-shadow:0 0 0 4px #ef444424}.select-error-message{font-size:var(--font-size-xs);color:var(--color-danger);margin-top:var(--spacing-2xs)}.select-icon-left{position:absolute;left:.85rem;color:var(--color-text-muted);pointer-events:none;display:flex;align-items:center}.select-chevron{position:absolute;right:.85rem;color:var(--color-text-muted);pointer-events:none;display:flex;align-items:center}.select-field--with-icon-left{padding-left:2.75rem}.absence-controlling{display:flex;flex-direction:column;gap:var(--spacing-lg)}.absence-controlling-header-card{overflow:hidden;background:radial-gradient(circle at top right,rgba(59,130,246,.12),transparent 34%),linear-gradient(180deg,#f8fafcfa,#f1f5f9fa)}.absence-controlling-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-lg)}.absence-controlling-kicker{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);letter-spacing:.08em;text-transform:uppercase;color:var(--color-primary);margin-bottom:var(--spacing-xs)}.absence-control-tabs{display:inline-flex;gap:var(--spacing-xs);padding:.35rem;width:fit-content;background:linear-gradient(180deg,#f0f4f7fa,#e7edf2f5);border:1px solid var(--color-border);border-radius:999px}.absence-control-tab{border:0;background:transparent;color:var(--color-text-secondary);padding:.7rem 1.15rem;border-radius:999px;font:inherit;font-weight:var(--font-weight-semibold);cursor:pointer;transition:background-color .2s ease,color .2s ease,box-shadow .2s ease}.absence-control-tab:hover{color:var(--color-text-primary)}.absence-control-tab.active{color:var(--color-text-primary);background:var(--color-bg-surface);box-shadow:0 8px 20px #14213d14}.absence-controlling-header h2,.absence-controlling-section-header h3{margin:0 0 var(--spacing-xs)}.absence-controlling-header p,.absence-controlling-section-header p{margin:0}.absence-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.absence-kpi-card{overflow:hidden}.absence-kpi-card .card-body{display:grid;gap:var(--spacing-xs)}.absence-kpi-card.is-neutral{background:linear-gradient(180deg,#fffffffa,#f8fafcfa)}.absence-kpi-card.is-primary{background:linear-gradient(180deg,#e8f4fffa,#eff6fffa)}.absence-kpi-card.is-accent{background:linear-gradient(180deg,#ecfdf5fa,#f0fdfafa)}.absence-kpi-card.is-warning{background:linear-gradient(180deg,#fff7edfa,#fffbebfa)}.absence-kpi-card.is-success{background:linear-gradient(180deg,#ecfdf5fa,#f0fdf4fa)}.absence-kpi-card.is-danger-soft,.absence-health-kpi.is-danger-soft{background:linear-gradient(180deg,#fef2f2fa,#fff7f7fa)}.absence-kpi-card.is-danger-strong,.absence-health-kpi.is-danger-strong{background:linear-gradient(180deg,#fee2e2fa,#fef2f2fa)}.absence-kpi-icon{width:2.25rem;height:2.25rem;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:#ffffffb3;color:var(--color-text-primary);box-shadow:inset 0 0 0 1px #94a3b829}.absence-kpi-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.absence-kpi-value{font-size:clamp(1.85rem,2.8vw,2.35rem);font-weight:var(--font-weight-bold);line-height:1;color:var(--color-text-primary)}.absence-kpi-detail{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.absence-controlling-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--spacing-lg)}.absence-controlling-section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.absence-stat-stack{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-lg)}.absence-stat-row{display:grid;gap:var(--spacing-xs)}.absence-stat-row-header,.absence-stat-row-meta{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm)}.absence-stat-row-meta{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.absence-progress{width:100%;height:.5rem;border-radius:999px;background:#94a3b829;overflow:hidden}.absence-progress span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#3b82f6e6,#10b981e6)}.absence-status-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--spacing-md);padding:var(--spacing-lg)}.absence-status-card{display:grid;gap:var(--spacing-sm);padding:var(--spacing-md);border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-base)}.absence-status-value{font-size:1.8rem;font-weight:var(--font-weight-bold);line-height:1}.absence-status-detail{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.absence-employee-health-card{overflow:hidden}.absence-employee-health-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.absence-employee-health-header h3,.absence-case-list-header h4{margin:0 0 var(--spacing-xs)}.absence-employee-health-header p{margin:0}.absence-employee-search{display:inline-flex;align-items:center;gap:var(--spacing-sm);min-width:min(20rem,100%);padding:.8rem .95rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-base);color:var(--color-text-secondary)}.absence-employee-search input{width:100%;border:0;outline:0;background:transparent;color:var(--color-text-primary);font:inherit}.absence-health-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.absence-health-kpi{display:grid;gap:var(--spacing-xs);padding:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.absence-comparison-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.absence-trend-visual{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:var(--spacing-md);align-items:end;min-height:16rem;padding:var(--spacing-lg)}.absence-trend-column{display:grid;gap:var(--spacing-xs);justify-items:center}.absence-trend-meta{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary)}.absence-trend-bar-track{width:100%;max-width:3.5rem;height:10rem;display:flex;align-items:flex-end;justify-content:center;padding:.35rem;border-radius:999px;background:linear-gradient(180deg,#f8fafceb,#e2e8f0eb)}.absence-trend-bar{width:100%;border-radius:999px;background:linear-gradient(180deg,#f87171e6,#f43f5ef2);box-shadow:0 10px 18px #f43f5e2e}.absence-trend-bar.is-current{background:linear-gradient(180deg,#3b82f6f2,#0ea5e9eb);box-shadow:0 12px 22px #0ea5e938}.absence-trend-label{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);text-transform:capitalize}.absence-trend-sub{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.absence-comparison-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--spacing-md);padding:0 var(--spacing-lg) var(--spacing-lg)}.absence-comparison-pill{display:grid;gap:.25rem;padding:var(--spacing-md);border-radius:var(--radius-md);background:#f8fafceb;border:1px solid rgba(148,163,184,.18)}.absence-comparison-pill span{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.absence-comparison-pill strong{font-size:1.15rem;line-height:1}.absence-employee-bars{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-lg)}.absence-employee-bar-row{border:1px solid rgba(148,163,184,.2);border-radius:var(--radius-md);background:#ffffffe6;padding:var(--spacing-md);display:grid;gap:var(--spacing-xs);text-align:left;cursor:pointer}.absence-employee-bar-head,.absence-employee-bar-meta{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md)}.absence-employee-bar-meta{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.absence-employee-bar-track{width:100%;height:.9rem;border-radius:999px;background:#e2e8f0d9;overflow:hidden}.absence-employee-bar-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#f87171f0,#3b82f6eb)}.absence-employee-analysis-grid{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(320px,.95fr);gap:var(--spacing-lg)}.absence-table-row-selected{background:#3b82f614}.absence-selected-employee-card{height:100%;background:radial-gradient(circle at top right,rgba(248,113,113,.08),transparent 34%),linear-gradient(180deg,#fffffffa,#f8fafcfa)}.absence-selected-employee-card .card-body{display:flex;flex-direction:column;gap:var(--spacing-lg);height:100%}.absence-selected-employee-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-md)}.absence-selected-employee-header h3{margin:0}.absence-selected-employee-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--spacing-md)}.absence-selected-metric{display:grid;gap:.2rem;padding:var(--spacing-md);border-radius:var(--radius-md);background:#ffffffc7;border:1px solid rgba(148,163,184,.22)}.absence-selected-metric strong{font-size:1.35rem;line-height:1}.absence-selected-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.absence-selected-employee-summary{display:grid;gap:var(--spacing-sm)}.absence-summary-row{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid rgba(148,163,184,.18)}.absence-summary-row:last-child{padding-bottom:0;border-bottom:0}.absence-summary-row span{color:var(--color-text-secondary)}.absence-case-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.absence-case-list-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md)}.absence-case-item{border:1px solid rgba(148,163,184,.2);border-radius:var(--radius-md);background:#ffffffd1;padding:var(--spacing-sm) var(--spacing-md);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);text-align:left;cursor:pointer;transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease}.absence-case-item:hover{transform:translateY(-1px);border-color:#3b82f652;box-shadow:0 8px 18px #0f172a14}.absence-case-period{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.absence-case-days{font-size:var(--font-size-sm);color:var(--color-text-secondary)}@media (max-width: 960px){.absence-controlling-header,.absence-controlling-grid{flex-direction:column;grid-template-columns:1fr}.absence-status-grid,.absence-health-kpi-grid,.absence-employee-analysis-grid,.absence-comparison-grid,.absence-comparison-summary{grid-template-columns:1fr}.absence-employee-health-header{flex-direction:column}}@media (max-width: 720px){.absence-control-tabs{width:100%;display:grid;grid-template-columns:1fr}.absence-kpi-grid{grid-template-columns:1fr}.absence-stat-row-header,.absence-stat-row-meta,.absence-selected-employee-header,.absence-summary-row,.absence-case-list-header,.absence-case-item,.absence-employee-bar-head,.absence-employee-bar-meta{flex-direction:column;align-items:flex-start}.absence-selected-employee-metrics,.absence-health-kpi-grid{grid-template-columns:1fr}.absence-trend-visual{grid-template-columns:repeat(3,minmax(0,1fr))}}.absence-approval-page{display:flex;flex-direction:column;gap:var(--spacing-lg)}.absence-tabs{display:inline-flex;gap:var(--spacing-xs);padding:.35rem;width:fit-content;background:linear-gradient(180deg,#f0f4f7fa,#e7edf2f5);border:1px solid var(--color-border);border-radius:999px}.absence-tab{border:0;background:transparent;color:var(--color-text-secondary);padding:.7rem 1.15rem;border-radius:999px;font:inherit;font-weight:var(--font-weight-semibold);cursor:pointer;transition:background-color .2s ease,color .2s ease,box-shadow .2s ease}.absence-tab:hover{color:var(--color-text-primary)}.absence-tab.active{color:var(--color-text-primary);background:var(--color-bg-surface);box-shadow:0 8px 20px #14213d14}.absence-filter-bar{display:flex;align-items:center;gap:var(--spacing-md);background:var(--color-bg-surface);padding:var(--spacing-md);border-radius:var(--radius-md);border:1px solid var(--color-border)}.absence-actions{display:flex;gap:var(--spacing-sm)}.absence-entry-card{overflow:hidden}.absence-entry-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.absence-entry-header h2{margin:0 0 var(--spacing-xs)}.absence-entry-header p{margin:0}.absence-entry-form{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,.8fr) minmax(0,.75fr) minmax(0,.75fr);gap:var(--spacing-md);align-items:end}.absence-entry-employee-column{display:flex;flex-direction:column;gap:var(--spacing-sm)}.employee-vacation-info{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background:linear-gradient(135deg,#71dda41f,#71dda40f);border:1px solid rgba(113,221,164,.3);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.vacation-info-item{display:flex;align-items:center;gap:var(--spacing-xs);white-space:nowrap}.vacation-info-icon{color:var(--color-success)}.vacation-info-value{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.vacation-info-label{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.vacation-info-divider{width:1px;height:16px;background:var(--color-border)}.vacation-info-loading{color:var(--color-text-secondary);font-size:var(--font-size-xs);font-style:italic}.vacation-info-unavailable{color:var(--color-text-muted);font-size:var(--font-size-xs);font-style:italic}.selected-employee-calendar{border:2px solid var(--color-primary)!important;box-shadow:0 4px 12px #14213d1a}.selected-employee-calendar .calendar-container{max-height:120px;overflow-x:auto}.selected-employee-row{background-color:#6366f10a}.selected-employee-row td{border-top:2px solid var(--color-primary);border-bottom:2px solid var(--color-primary)}.selected-employee-row .employee-column{background-color:#6366f114!important;border-left:2px solid var(--color-primary)}.absence-entry-notes{grid-column:1 / -1}.absence-entry-textarea{width:100%;min-height:8rem;resize:vertical}.absence-entry-actions{grid-column:1 / -1;display:flex;justify-content:flex-end}.absence-calendar-nav{display:flex;align-items:center;gap:var(--spacing-md)}.calendar-header{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.employee-column{text-align:left!important;min-width:220px;position:sticky;left:0;background:var(--color-bg-surface)!important;z-index:2;font-weight:var(--font-weight-medium);border-right:2px solid var(--color-border)!important}.day-column{min-width:42px}.day-number{font-weight:var(--font-weight-bold);font-size:1.05em}.calendar-cell{height:42px;vertical-align:middle;padding:2px!important}.absence-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.5rem;min-height:1.5rem;font-size:.72rem;padding:2px 4px;border-radius:999px;white-space:nowrap;font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.absence-cell-button{border:0;background:transparent;padding:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.absence-cell-button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:999px}@media (max-width: 960px){.absence-entry-form{grid-template-columns:repeat(2,minmax(0,1fr))}.absence-entry-employee-column,.absence-entry-notes,.absence-entry-actions{grid-column:1 / -1}.calendar-header{flex-direction:column;align-items:stretch}.absence-calendar-nav{justify-content:space-between}}@media (max-width: 720px){.absence-tabs{width:100%;display:grid;grid-template-columns:1fr 1fr}.absence-entry-header,.absence-filter-bar,.absence-calendar-nav{flex-direction:column;align-items:stretch}.absence-entry-form{grid-template-columns:1fr}.absence-entry-employee-column{grid-column:1 / -1}.employee-vacation-info{flex-wrap:wrap}.absence-actions{flex-direction:column}.employee-column{min-width:180px}}.time-approval-page .section{margin-bottom:var(--spacing-2xl)}.time-approval-page .loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);gap:var(--spacing-md);color:var(--color-text-secondary)}.time-approval-page .filter-buttons{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.time-approval-page .form-group{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg)}.time-approval-page .form-group label{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.time-approval-page .form-group textarea{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-md);transition:border-color var(--transition-fast);font-family:inherit}.time-approval-page .form-group textarea:focus{outline:none;border-color:var(--color-primary)}.time-approval-page .modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.month-close-page{display:flex;flex-direction:column;gap:var(--spacing-lg)}.month-close-tabs{display:inline-flex;gap:var(--spacing-xs);padding:.35rem;width:fit-content;background:linear-gradient(180deg,#f0f4f7fa,#e7edf2f5);border:1px solid var(--color-border);border-radius:999px}.month-close-tab{display:inline-flex;align-items:center;gap:var(--spacing-xs);border:0;background:transparent;color:var(--color-text-secondary);padding:.7rem 1.15rem;border-radius:999px;font:inherit;font-weight:var(--font-weight-semibold);cursor:pointer;transition:background-color .2s ease,color .2s ease,box-shadow .2s ease}.month-close-tab:hover{color:var(--color-text-primary)}.month-close-tab.active{color:var(--color-text-primary);background:var(--color-bg-surface);box-shadow:0 8px 20px #14213d14}@media (max-width: 720px){.month-close-tabs{width:100%;display:grid;grid-template-columns:1fr 1fr}}.month-close-card{overflow:visible}.month-close-card-body{padding-top:calc(var(--spacing-xl) * 1.2);padding-bottom:calc(var(--spacing-xl) * 1.2);display:flex;flex-direction:column;gap:var(--spacing-lg)}.month-close-controls{display:flex;align-items:flex-end;gap:var(--spacing-lg);flex-wrap:wrap;width:100%}.month-close-control-field{flex:1;min-width:220px}.month-close-control-field .input-wrapper,.month-close-control-field .select-wrapper{margin-bottom:0}.month-close-control-action{display:flex;align-items:flex-end}.month-close-control-action .btn{min-width:220px;min-height:48px}@media (max-width: 900px){.month-close-controls{flex-direction:column;align-items:stretch}.month-close-control-action .btn{width:100%}}.month-close-employee-select{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-lg);border-radius:var(--radius-md);border:1px dashed var(--color-border);background:var(--color-bg-surface)}.month-close-employee-select-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);flex-wrap:wrap}.month-close-employee-dropdown{position:relative;width:100%}.month-close-employee-dropdown-menu{position:absolute;top:calc(100% + var(--spacing-sm));left:0;width:100%;max-height:360px;background:var(--color-bg-base);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:var(--spacing-lg);z-index:var(--z-index-dropdown, 50);display:flex;flex-direction:column;gap:var(--spacing-md)}.month-close-employee-dropdown-search .input-wrapper{margin-bottom:0}.month-close-employee-options{max-height:220px;overflow:auto;display:flex;flex-direction:column;gap:var(--spacing-sm);padding-right:var(--spacing-sm)}.month-close-employee-option{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast)}.month-close-employee-option input{margin:0}.month-close-employee-option .option-label{font-weight:var(--font-weight-semibold)}.month-close-employee-option .option-subtitle{display:block;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.month-close-employee-option.selected{border-color:var(--color-primary);background:#3b82f614}.month-close-employee-dropdown-actions{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);flex-wrap:wrap}.month-close-employee-select-loading,.month-close-employee-select-empty{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.month-close-info-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.month-close-info-list li{position:relative;padding-left:var(--spacing-lg);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.month-close-info-list li:before{content:"•";position:absolute;left:var(--spacing-xs);color:var(--color-primary);font-weight:700}.month-close-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-md)}.month-close-stat-card{background:var(--color-bg-surface);padding:var(--spacing-md);border-radius:var(--radius-md);border:1px solid var(--color-border);display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--spacing-xs)}.month-close-stat-card.success{border-color:var(--color-success);background:#10b9810d}.month-close-stat-card.warning{border-color:var(--color-warning);background:#f59e0b0d}.month-close-stat-card.error{border-color:var(--color-danger);background:#ef44440d}.month-close-stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.month-close-stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.month-close-stat-card.success .month-close-stat-value{color:var(--color-success)}.month-close-stat-card.warning .month-close-stat-value{color:var(--color-warning)}.month-close-stat-card.error .month-close-stat-value{color:var(--color-danger)}.month-close-detail-content{display:flex;flex-direction:column;gap:var(--spacing-xl)}.month-close-detail-overview{display:flex;flex-direction:column;gap:var(--spacing-lg)}.month-close-detail-meta{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.month-close-detail-meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--spacing-lg)}.month-close-detail-meta-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.month-close-detail-meta-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.month-close-detail-meta-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.month-close-detail-meta-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.month-close-detail-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--spacing-md)}.month-close-detail-table{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.month-close-detail-table-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-md)}.month-close-detail-table-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.month-close-detail-results-table .table th.month-close-detail-col-metric,.month-close-detail-results-table .table th.month-close-detail-col-status,.month-close-detail-results-table .table th.month-close-detail-col-actions,.month-close-detail-results-table .table td.month-close-detail-col-status,.month-close-detail-results-table .table td.month-close-detail-col-actions{width:1%}.month-close-detail-results-table .table th.month-close-detail-col-employee,.month-close-detail-results-table .table td.month-close-detail-col-employee{min-width:5.5rem}.month-close-detail-results-table .table td.month-close-detail-col-metric,.month-close-detail-results-table .table td.month-close-detail-col-status,.month-close-detail-results-table .table td.month-close-detail-col-actions{white-space:nowrap}.month-close-detail-results-table .table td.month-close-detail-col-metric{min-width:4.25rem}.month-close-detail-results-table .table th.month-close-detail-col-note,.month-close-detail-results-table .table td.month-close-detail-col-note{min-width:10rem}.month-close-detail-header-break{display:inline-flex;flex-direction:column;gap:.1rem;line-height:1.1;white-space:normal}.month-close-timeentries-modal{display:flex;flex-direction:column;gap:var(--spacing-lg)}.month-close-timeentries-summary{display:grid;grid-template-columns:minmax(220px,320px) 1fr;gap:var(--spacing-lg);align-items:stretch}@media (max-width: 960px){.month-close-timeentries-summary{grid-template-columns:1fr}}.month-close-timeentries-hours-stack{display:grid;gap:var(--spacing-md)}.month-close-timeentries-hours{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-md)}.month-close-timeentries-hours--balances{grid-template-columns:repeat(4,minmax(0,1fr))}.month-close-timeentries-hours--metrics{grid-template-columns:repeat(3,minmax(0,1fr))}.month-close-timeentries-hours-card{--metric-bg: var(--color-bg-surface);--metric-border: var(--color-border);--metric-accent: var(--color-primary);--metric-value: var(--color-text-primary);background:var(--metric-bg);border:1px solid var(--metric-border);border-radius:var(--radius-lg);padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-xs);position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}.month-close-timeentries-hours-card:before{content:"";position:absolute;inset:0 auto 0 0;width:5px;background:linear-gradient(180deg,var(--metric-accent) 0%,rgba(255,255,255,.18) 100%)}.month-close-timeentries-hours-card--neutral{--metric-bg: linear-gradient(180deg, rgba(0, 59, 115, .05) 0%, rgba(255, 255, 255, .98) 100%);--metric-border: rgba(0, 59, 115, .16);--metric-accent: var(--color-primary)}.month-close-timeentries-hours-card--info{--metric-bg: linear-gradient(180deg, rgba(59, 130, 246, .08) 0%, rgba(255, 255, 255, .98) 100%);--metric-border: rgba(59, 130, 246, .18);--metric-accent: var(--color-info)}.month-close-timeentries-hours-card--success,.month-close-timeentries-hours-card--vacation-new{--metric-bg: linear-gradient(180deg, rgba(105, 190, 40, .1) 0%, rgba(255, 255, 255, .98) 100%);--metric-border: rgba(105, 190, 40, .2);--metric-accent: var(--color-success)}.month-close-timeentries-hours-card--danger{--metric-bg: linear-gradient(180deg, rgba(239, 68, 68, .09) 0%, rgba(255, 255, 255, .98) 100%);--metric-border: rgba(239, 68, 68, .2);--metric-accent: var(--color-danger)}.month-close-timeentries-hours-card--overtime-prev{--metric-bg: linear-gradient(180deg, rgba(245, 158, 11, .14) 0%, rgba(255, 255, 255, .98) 100%);--metric-border: rgba(245, 158, 11, .24);--metric-accent: var(--color-warning)}.month-close-timeentries-hours-card--vacation-prev{--metric-bg: linear-gradient(180deg, rgba(245, 158, 11, .12) 0%, rgba(255, 255, 255, .98) 100%);--metric-border: rgba(245, 158, 11, .22);--metric-accent: var(--color-warning)}.month-close-timeentries-hours-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);font-weight:var(--font-weight-semibold)}.month-close-timeentries-hours-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--metric-value, var(--color-text-primary))}.month-close-timeentries-hours-value.positive{color:var(--color-text-primary)}.month-close-timeentries-hours-value.negative{color:var(--color-danger)}.month-close-timeentries-hours-subtitle{font-size:var(--font-size-xs);color:var(--color-text-secondary)}@media (max-width: 1280px){.month-close-timeentries-hours--balances,.month-close-timeentries-hours--metrics{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}}.month-close-timeentries-meta{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.month-close-timeentries-meta .meta-row{display:flex;flex-direction:column;gap:var(--spacing-xs)}.month-close-timeentries-meta .meta-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);font-weight:var(--font-weight-semibold)}.month-close-timeentries-meta .meta-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}.month-close-timeentries-banner{border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;gap:var(--spacing-md);align-items:flex-start;border:1px solid transparent}.month-close-timeentries-banner.warning{background:#f59e0b1f;border-color:#f59e0b66;color:var(--color-text-primary)}.month-close-timeentries-banner.success{background:#10b9811f;border-color:#10b98166;color:var(--color-text-primary)}.month-close-timeentries-banner .banner-icon{display:flex;align-items:center;justify-content:center;color:inherit}.month-close-timeentries-banner.warning .banner-icon{color:var(--color-warning)}.month-close-timeentries-banner.success .banner-icon{color:var(--color-success)}.month-close-timeentries-banner .banner-text{display:flex;flex-direction:column;gap:var(--spacing-xs);font-size:var(--font-size-sm);line-height:1.4}.month-close-timeentries-banner .banner-text strong{font-size:var(--font-size-base)}.month-close-timeentries-table-card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.month-close-timeentries-table-loading{display:flex;flex-direction:column;gap:var(--spacing-sm);align-items:center;justify-content:center;padding:var(--spacing-2xl);color:var(--color-text-secondary)}.month-close-special-hours{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.month-close-special-hours-title{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0;padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.month-close-special-hours-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--spacing-md)}.month-close-special-hours-item{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-md);background:linear-gradient(135deg,#3b82f60d,#8b5cf60d);border:1px solid rgba(59,130,246,.15);border-radius:var(--radius-md);transition:all var(--transition-fast)}.month-close-special-hours-item:hover{border-color:#3b82f64d;box-shadow:0 2px 8px #3b82f61a}.month-close-special-hours-item .special-hours-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);font-weight:var(--font-weight-semibold)}.month-close-special-hours-item .special-hours-value{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-primary)}.month-close-special-hours-item .special-hours-subtitle{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-style:italic}@media (max-width: 768px){.month-close-special-hours-grid{grid-template-columns:1fr}}.reports-page{display:flex;flex-direction:column;gap:var(--spacing-lg)}.reports-tabs{display:inline-flex;gap:var(--spacing-xs);padding:.35rem;width:fit-content;background:linear-gradient(180deg,#f0f4f7fa,#e7edf2f5);border:1px solid var(--color-border);border-radius:999px}.reports-tab{border:0;background:transparent;color:var(--color-text-secondary);padding:.7rem 1.15rem;border-radius:999px;font:inherit;font-weight:var(--font-weight-semibold);cursor:pointer;transition:background-color .2s ease,color .2s ease,box-shadow .2s ease}.reports-tab:hover{color:var(--color-text-primary)}.reports-tab.active{color:var(--color-text-primary);background:var(--color-bg-surface);box-shadow:0 8px 20px #14213d14}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.reports-table-header-break{display:inline-flex;flex-direction:column;gap:.12rem;line-height:1.2}.reports-monthly-closes-table .table th{padding:.82rem .72rem;font-size:.64rem;letter-spacing:.12em;white-space:normal}.reports-monthly-closes-table .table td{padding:.9rem .72rem}.reports-monthly-closes-table .table .table-balance-chip{min-width:5.9rem;padding:.34rem .56rem;font-size:.78rem}.reports-monthly-closes-table .table .table-balance-value{font-size:.9rem}.calendar-container{overflow-x:auto;background:var(--color-bg-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);margin-bottom:var(--spacing-lg)}.calendar-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.calendar-table th,.calendar-table td{border:1px solid var(--color-border);padding:var(--spacing-xs);text-align:center}.calendar-table th{background:var(--color-bg-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.employee-column{text-align:left!important;min-width:180px;position:sticky;left:0;background:var(--color-bg-surface)!important;z-index:2;font-weight:var(--font-weight-medium);border-right:2px solid var(--color-border)!important}.day-column{min-width:40px}.day-header{display:flex;flex-direction:column;align-items:center;gap:2px}.day-number{font-weight:700;font-size:1.1em}.day-name{font-size:.8em;color:var(--color-text-secondary);text-transform:uppercase}.weekend{background-color:var(--color-bg-base)}.calendar-cell{height:40px;vertical-align:middle;padding:2px!important}.absence-badge{font-size:.75em;padding:2px 4px;border-radius:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.calendar-legend{display:flex;flex-direction:column;gap:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.reports-action-button{transform:none;transition:background-color var(--transition-fast) ease,border-color var(--transition-fast) ease,color var(--transition-fast) ease}.reports-action-button.btn--primary:hover:not(:disabled),.reports-action-button.btn--primary:focus-visible{transform:none;box-shadow:0 18px 38px -24px #003b734d}.legend-title{font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.legend-items{display:flex;gap:var(--spacing-lg);flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm)}.legend-color{width:12px;height:12px;border-radius:2px}@media (max-width: 720px){.reports-tabs{width:100%;display:grid;grid-template-columns:1fr 1fr}}.audit-log-page{display:flex;flex-direction:column;gap:var(--spacing-lg);flex:1 1 0!important;min-height:0!important;overflow:hidden}.audit-log-card{margin-bottom:var(--spacing-md)}.audit-log-filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--spacing-md)}.audit-log-search-field{grid-column:span 2}@media (max-width: 900px){.audit-log-search-field{grid-column:span 1}}.audit-log-content{display:grid;grid-template-columns:minmax(0,1.7fr) minmax(0,1fr);gap:var(--spacing-lg);flex:1;min-height:0;overflow:hidden}@media (max-width: 1200px){.audit-log-content{grid-template-columns:1fr}}.audit-log-table-card,.audit-log-detail-card{display:flex;flex-direction:column;min-height:0;overflow:hidden}.audit-log-table-card>.card-body,.audit-log-detail-card>.card-body{flex:1;overflow-y:auto;min-height:0}.audit-log-table-header{justify-content:space-between;align-items:flex-start;gap:var(--spacing-md)}.audit-log-meta{font-size:var(--font-size-sm)}.audit-log-loading{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xl);color:var(--color-text-secondary)}.audit-log-monospace{font-family:JetBrains Mono,Fira Code,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.85rem;word-break:break-all}.audit-log-table-name{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.audit-log-detail-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.audit-log-label{display:block;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin-bottom:var(--spacing-xs)}.audit-log-changes{margin-bottom:var(--spacing-lg)}.audit-log-field-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-top:var(--spacing-sm)}.audit-log-field-tag{background-color:var(--color-secondary-light);color:var(--color-secondary);font-size:var(--font-size-xs);padding:.15rem .5rem;border-radius:var(--radius-full)}.audit-log-json-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--spacing-md)}.audit-log-json-grid h4{margin-bottom:var(--spacing-sm)}.audit-log-json{background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);max-height:320px;overflow:auto;font-family:JetBrains Mono,Fira Code,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.85rem;line-height:1.45;white-space:pre-wrap;word-break:break-word}.employees-page{display:flex;flex-direction:column;gap:var(--spacing-lg);flex:1 1 0!important;min-height:0!important;overflow:hidden}.employees-list-panel{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--color-bg-base);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden}.employees-list-header{padding:var(--spacing-md);border-bottom:1px solid var(--color-border);background:var(--color-bg-base);display:flex;flex-direction:column;gap:var(--spacing-sm)}.employees-search-field{margin:0}.employees-list{flex:1;overflow-y:auto;padding:var(--spacing-xs)}.employees-list-empty{padding:var(--spacing-lg);color:var(--color-text-secondary);text-align:center}.employee-list-item{padding:var(--spacing-md);border-radius:var(--radius-md);cursor:pointer;transition:background-color .2s;margin-bottom:var(--spacing-xs);border:1px solid transparent}.employee-list-item:hover{background-color:var(--color-bg-hover)}.employee-list-item.active{background-color:var(--color-primary-light);background-color:#eff6ff;border-color:var(--color-primary)}.employee-list-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs)}.employee-name{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.employee-meta{font-size:var(--font-size-sm);color:var(--color-text-secondary);display:flex;flex-direction:column;gap:2px}.employee-detail-panel{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--color-bg-base);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden}.employee-detail-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);background:var(--color-bg-base);display:flex;justify-content:space-between;align-items:center}@media (max-width: 768px){.employee-detail-header{flex-direction:column;align-items:stretch;gap:var(--spacing-md)}.current-balances{justify-content:flex-start;flex-wrap:wrap}.employee-tabs{margin-left:0;justify-content:flex-start}.detail-section-header{align-items:stretch}.detail-section-header-actions{width:100%;justify-content:flex-start}}.employee-tabs{display:inline-flex;gap:var(--spacing-xs);padding:.35rem;width:fit-content;background:linear-gradient(180deg,#f0f4f7fa,#e7edf2f5);border:1px solid var(--color-border);border-radius:999px}.current-balances{display:flex;gap:var(--spacing-md);align-items:center;flex-wrap:wrap;justify-content:flex-end}.balance-edit-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;flex-shrink:0;transition:background .15s,color .15s,border-color .15s}.balance-edit-btn:hover{background:var(--color-primary-light, #e8f0fe);color:var(--color-primary);border-color:var(--color-primary)}.balance-card{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-base);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-fast);position:relative;overflow:hidden;min-height:88px}.balance-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--color-primary),var(--color-info))}.balance-card-overtime:before{background:linear-gradient(90deg,var(--color-success),var(--color-success-hover))}.balance-card-vacation:before{background:linear-gradient(90deg,var(--color-primary),var(--color-info))}.balance-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);border-color:var(--color-border-hover)}.balance-card-overtime:hover{box-shadow:var(--shadow-md),0 0 0 1px #10b9811a}.balance-card-vacation:hover{box-shadow:var(--shadow-md),0 0 0 1px #2563eb1a}.balance-card-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);background:var(--color-bg-surface);color:var(--color-text-secondary);flex-shrink:0}.balance-card-overtime .balance-card-icon{background:var(--color-success-bg);color:var(--color-success)}.balance-card-vacation .balance-card-icon{background:var(--color-primary-light);color:var(--color-primary)}.balance-card-content{display:flex;flex-direction:column;gap:2px;min-width:0}.balance-card-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.025em}.balance-card-value{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-text-primary);display:flex;align-items:center;gap:var(--spacing-2xs);transition:color var(--transition-fast)}.balance-card-value.positive{color:var(--color-success)}.balance-card-value.negative{color:var(--color-danger)}.balance-card-value.vacation{color:var(--color-primary)}.balance-card-meta{font-size:.6875rem;color:var(--color-text-secondary);line-height:1.2}.balance-card-subvalue{font-size:.75rem;color:var(--color-text-secondary);line-height:1.3;min-height:1.3em}.balance-card-subvalue-placeholder{visibility:hidden}.balance-trend-icon{display:flex;align-items:center;justify-content:center;opacity:.8;flex-shrink:0;transition:opacity var(--transition-fast)}.balance-card:hover .balance-trend-icon{opacity:1}@media (max-width: 1200px){.balance-card{padding:var(--spacing-xs) var(--spacing-sm)}.balance-card-content{gap:1px}.balance-card-label{font-size:.6875rem}.balance-card-value{font-size:.8125rem}.balance-card-meta,.balance-card-subvalue{font-size:.6875rem}}.employee-detail-content{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.detail-section-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);flex-wrap:wrap;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border-light)}.detail-section-header-actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-md);flex-wrap:wrap;margin-left:auto}.balance-adjustment-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.balance-adjustment-item{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-surface);padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm)}.balance-adjustment-head{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);flex-wrap:wrap}.balance-adjustment-title-row{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.balance-adjustment-title{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.balance-adjustment-time{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.balance-adjustment-values{display:flex;flex-direction:column;gap:4px;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.employee-tab{border:0;background:transparent;color:var(--color-text-secondary);padding:.7rem 1.15rem;border-radius:999px;font:inherit;font-weight:var(--font-weight-semibold);cursor:pointer;transition:background-color .2s ease,color .2s ease,box-shadow .2s ease}.employee-tab:hover{color:var(--color-text-primary)}.employee-tab.active{color:var(--color-text-primary);background:var(--color-bg-surface);box-shadow:0 8px 20px #14213d14}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.form-full-width{grid-column:1 / -1}.detail-section table thead th{white-space:normal!important;word-wrap:break-word;vertical-align:middle;min-width:80px;max-width:120px}.patients-page{display:flex;flex-direction:column;gap:var(--spacing-lg);flex:1 1 0!important;min-height:0!important;overflow:hidden}.patients-list-panel{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--color-bg-base);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden}.patients-list-header{padding:var(--spacing-md);border-bottom:1px solid var(--color-border);background:var(--color-bg-base);display:flex;flex-direction:column;gap:var(--spacing-sm)}.patients-search-field{margin:0}.patients-list{flex:1;overflow-y:auto;padding:var(--spacing-xs)}.patients-list-empty{padding:var(--spacing-lg);color:var(--color-text-secondary);text-align:center}.patient-list-item{padding:var(--spacing-md);border-radius:var(--radius-md);cursor:pointer;transition:background-color .2s;margin-bottom:var(--spacing-xs);border:1px solid transparent}.patient-list-item:hover{background-color:var(--color-bg-hover)}.patient-list-item.active{background-color:var(--color-primary-bg-light);background-color:#eff6ff;border-color:var(--color-primary)}.patient-list-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs)}.patient-name{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.patient-meta{font-size:var(--font-size-sm);color:var(--color-text-secondary);display:flex;flex-direction:column;gap:2px}.patient-detail-panel{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--color-bg-base);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden}.patient-detail-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);background:var(--color-bg-base);display:flex;justify-content:space-between;align-items:center}.patient-detail-content{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.document-groups{display:flex;flex-direction:column;gap:var(--spacing-lg)}.document-group{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-base);overflow:hidden}.document-group-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border-light);background:var(--color-bg-surface)}.document-group-count{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.document-group-list{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md)}.document-entry{flex-wrap:wrap;gap:var(--spacing-md)}.patient-tabs{display:inline-flex;gap:var(--spacing-xs);padding:.35rem;width:fit-content;background:linear-gradient(180deg,#f0f4f7fa,#e7edf2f5);border:1px solid var(--color-border);border-radius:999px}.patient-tab{border:0;background:transparent;color:var(--color-text-secondary);padding:.7rem 1.15rem;border-radius:999px;font:inherit;font-weight:var(--font-weight-semibold);cursor:pointer;transition:background-color .2s ease,color .2s ease,box-shadow .2s ease}.patient-tab:hover{color:var(--color-text-primary)}.patient-tab.active{color:var(--color-text-primary);background:var(--color-bg-surface);box-shadow:0 8px 20px #14213d14}.cost-centers-page{display:flex;flex-direction:column;gap:var(--spacing-lg);flex:1 1 0!important;min-height:0!important;overflow:hidden}.cost-centers-list-panel{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--color-bg-base);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden}.cost-centers-list-header{padding:var(--spacing-md);border-bottom:1px solid var(--color-border);background:var(--color-bg-base);display:flex;flex-direction:column;gap:var(--spacing-sm)}.cost-centers-search-field{margin:0}.cost-centers-list{flex:1;overflow-y:auto;padding:var(--spacing-xs)}.cost-centers-list-empty{padding:var(--spacing-lg);color:var(--color-text-secondary);text-align:center}.cost-center-list-item{padding:var(--spacing-md);border-radius:var(--radius-md);cursor:pointer;transition:background-color .2s;margin-bottom:var(--spacing-xs);border:1px solid transparent}.cost-center-list-item:hover{background-color:var(--color-bg-hover)}.cost-center-list-item.active{background-color:var(--color-primary-bg-light);background-color:#eff6ff;border-color:var(--color-primary)}.cost-center-list-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs)}.cost-center-name{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.cost-center-meta{font-size:var(--font-size-sm);color:var(--color-text-secondary);display:flex;flex-direction:column;gap:2px}.cost-center-detail-panel{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--color-bg-base);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden}.cost-center-detail-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);background:var(--color-bg-base);display:flex;justify-content:space-between;align-items:center}.cost-center-detail-content{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.detail-section{background:var(--color-bg-base);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);border:1px solid var(--color-border)}.detail-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border-light)}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--spacing-md)}.detail-item label{display:block;font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:4px}.detail-item span{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.detail-empty{display:flex;justify-content:center;align-items:center;height:100%;color:var(--color-text-secondary);text-align:center;padding:var(--spacing-xl)}.document-types-page{display:flex;flex-direction:column;gap:var(--spacing-lg);flex:1 1 0!important;min-height:0!important;overflow:hidden}.document-type-scope-switch{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.document-type-scope-button{border:1px solid var(--color-border);background:var(--color-bg-base);color:var(--color-text-secondary);border-radius:999px;padding:.65rem 1rem;font-weight:var(--font-weight-medium);cursor:pointer;transition:border-color .2s ease,background-color .2s ease,color .2s ease}.document-type-scope-button:hover{border-color:var(--color-primary);color:var(--color-text-primary)}.document-type-scope-button.active{background:#eff6ff;border-color:var(--color-primary);color:var(--color-primary)}.document-types-list-panel,.document-type-detail-panel{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--color-bg-base);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden}.document-types-list-header,.document-type-detail-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);background:var(--color-bg-base)}.document-types-list-header{padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm)}.document-types-search-field{margin:0}.document-type-detail-header{display:flex;justify-content:space-between;align-items:center}.document-types-list,.document-type-detail-content{flex:1;overflow-y:auto}.document-types-list{padding:var(--spacing-xs)}.document-types-list-empty{padding:var(--spacing-lg);color:var(--color-text-secondary);text-align:center}.document-type-detail-content{padding:var(--spacing-lg)}.document-type-list-item{padding:var(--spacing-md);border-radius:var(--radius-md);cursor:pointer;transition:background-color .2s;margin-bottom:var(--spacing-xs);border:1px solid transparent}.document-type-list-item:hover{background:var(--color-bg-hover)}.document-type-list-item.active{background:#eff6ff;border-color:var(--color-primary)}.document-type-list-item-header{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.document-type-name{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.document-type-meta{display:flex;flex-direction:column;gap:2px;font-size:var(--font-size-sm);color:var(--color-text-secondary)}@media (max-width: 960px){.document-types-layout{grid-template-columns:1fr}.document-types-page{height:auto;max-height:none;overflow:visible}.document-types-list-panel,.document-type-detail-panel{min-height:320px}.document-type-detail-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}}.time-tracking-settings-page{display:flex;flex-direction:column;gap:var(--spacing-lg)}.time-tracking-settings-tabs{display:inline-flex;gap:var(--spacing-xs);padding:.35rem;width:fit-content;background:linear-gradient(180deg,#f0f4f7fa,#e7edf2f5);border:1px solid var(--color-border);border-radius:999px}.time-tracking-settings-tab{display:inline-flex;align-items:center;gap:var(--spacing-xs);border:0;background:transparent;color:var(--color-text-secondary);padding:.7rem 1.15rem;border-radius:999px;font:inherit;font-weight:var(--font-weight-semibold);cursor:pointer;transition:background-color .2s ease,color .2s ease,box-shadow .2s ease}.time-tracking-settings-tab:hover{color:var(--color-text-primary)}.time-tracking-settings-tab.active{color:var(--color-text-primary);background:var(--color-bg-surface);box-shadow:0 8px 20px #14213d14}.time-tracking-settings-layout{display:grid;grid-template-columns:minmax(0,2fr) minmax(280px,1fr);gap:var(--spacing-lg)}.time-tracking-settings-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--spacing-xl)}.time-tracking-settings-card h2,.time-tracking-settings-card h3{margin:0 0 var(--spacing-sm)}.time-tracking-settings-muted{color:var(--color-text-secondary)}.time-tracking-settings-form{display:grid;gap:var(--spacing-lg)}.time-tracking-settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--spacing-md)}.time-tracking-settings-preview{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-lg);border-radius:var(--radius-md);background:linear-gradient(135deg,#0c1222f2,#1e3a8ae0);color:#f8fafc}.time-tracking-settings-preview-label{font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;opacity:.78}.time-tracking-settings-preview-value{font-size:1.9rem;font-weight:700;line-height:1.1}.time-tracking-settings-preview-value--compact{font-size:1.35rem}.time-tracking-settings-divider{height:1px;background:var(--color-border)}.time-tracking-settings-actions{display:flex;justify-content:flex-end}.time-tracking-settings-holiday-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.time-tracking-settings-custom-holiday-form{display:grid;grid-template-columns:minmax(180px,220px) minmax(0,1fr) auto;gap:var(--spacing-md);align-items:end}.time-tracking-settings-custom-holiday-action{display:flex;justify-content:flex-end}.time-tracking-settings-holiday-list-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-md);flex-wrap:wrap}.time-tracking-settings-holiday-list-header h3,.time-tracking-settings-holiday-list-header p{margin:0}.time-tracking-settings-holiday-count{display:inline-flex;align-items:center;padding:.45rem .75rem;border-radius:999px;background:#003b7314;color:var(--color-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.time-tracking-settings-holiday-empty{padding:var(--spacing-lg);border:1px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);text-align:center}.time-tracking-settings-list{margin:var(--spacing-md) 0 0;padding-left:1.2rem;color:var(--color-text-secondary)}.time-tracking-settings-list li+li{margin-top:var(--spacing-sm)}@media (max-width: 960px){.time-tracking-settings-layout{grid-template-columns:1fr}}@media (max-width: 640px){.time-tracking-settings-tabs{width:100%;display:grid;grid-template-columns:1fr 1fr}.time-tracking-settings-tab{justify-content:center}.time-tracking-settings-card{padding:var(--spacing-lg)}.time-tracking-settings-grid,.time-tracking-settings-custom-holiday-form{grid-template-columns:1fr}.time-tracking-settings-actions,.time-tracking-settings-custom-holiday-action{justify-content:stretch}}:root{--color-primary: #003b73;--color-primary-hover: #002a52;--color-primary-active: #001f3e;--color-primary-light: #e7f0f8;--color-primary-ring: rgba(0, 59, 115, .14);--color-secondary: #516277;--color-secondary-hover: #334155;--color-secondary-light: #edf3f8;--color-success: #69be28;--color-success-bg: #edf7e5;--color-success-text: #4c891d;--color-warning: #f59e0b;--color-warning-bg: #fef3c7;--color-warning-text: #92400e;--color-danger: #ef4444;--color-danger-bg: #fee2e2;--color-danger-text: #991b1b;--color-info: #3b82f6;--color-info-bg: #dbeafe;--color-info-text: #1e40af;--color-bg-base: rgba(255, 255, 255, .9);--color-bg-surface: #f4f8fb;--color-bg-hover: #eaf1f7;--color-bg-active: #dbe6f0;--color-bg-disabled: #eef3f7;--color-surface: var(--color-bg-base);--color-background: #ffffff;--color-border: rgba(148, 163, 184, .28);--color-border-light: rgba(148, 163, 184, .18);--color-border-hover: rgba(0, 59, 115, .22);--color-border-focus: rgba(0, 59, 115, .28);--color-primary-dark: var(--color-primary-hover);--color-text-primary: #122437;--color-text-secondary: #516277;--color-text-muted: #7d90a5;--color-text-inverse: #ffffff;--color-text-disabled: #a7b6c6;--font-family: "Space Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", sans-serif;--font-family-mono: "IBM Plex Mono", "Cascadia Code", "SFMono-Regular", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-weight-normal: 400;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--spacing-2xs: .125rem;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--shadow-sm: 0 14px 30px -26px rgba(15, 23, 42, .42);--shadow-md: 0 24px 52px -34px rgba(0, 59, 115, .28);--shadow-lg: 0 32px 72px -42px rgba(0, 59, 115, .35);--shadow-xl: 0 40px 96px -52px rgba(0, 59, 115, .42);--radius-sm: .75rem;--radius-md: 1rem;--radius-lg: 1.4rem;--radius-xl: 1.8rem;--border-radius-md: var(--radius-md);--radius-full: 9999px;--transition-fast: .18s;--transition-normal: .28s;--transition-slow: .42s;--z-index-dropdown: 1000;--z-index-sticky: 1020;--z-index-fixed: 1030;--z-index-modal-backdrop: 1040;--z-index-modal: 1050;--z-index-popover: 1060;--z-index-tooltip: 1070}*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html{-moz-text-size-adjust:none;-webkit-text-size-adjust:none;text-size-adjust:none;height:100%}body{min-height:100%;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}#root{isolation:isolate;height:100%}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text-primary);background:radial-gradient(circle at top left,rgba(105,190,40,.14),transparent 24%),radial-gradient(circle at top right,rgba(0,59,115,.12),transparent 32%),linear-gradient(180deg,#f8fbfd,#eef3f8)}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);line-height:var(--line-height-tight);margin-bottom:var(--spacing-md)}h1{font-size:var(--font-size-3xl);letter-spacing:-.025em}h2{font-size:var(--font-size-2xl);letter-spacing:-.025em}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}p{margin-bottom:var(--spacing-md);color:var(--color-text-secondary)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}small{font-size:var(--font-size-xs)}strong{font-weight:var(--font-weight-semibold)}:root{color-scheme:light}*{scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}*::-webkit-scrollbar{width:8px;height:8px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:var(--radius-full)}*::-webkit-scrollbar-thumb:hover{background-color:var(--color-text-muted)}::selection{background:#003b7329;color:#041f39}.text-center{text-align:center}.text-right{text-align:right}.d-flex{display:flex}.align-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.gap-xl{gap:var(--spacing-xl)}.mt-xs{margin-top:var(--spacing-xs)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}.mb-0{margin-bottom:0}.mb-xs{margin-bottom:var(--spacing-xs)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.w-full{width:100%}.h-full{height:100%}.block{display:block}.flex-column{flex-direction:column}.align-end{align-items:flex-end}.flex-wrap{flex-wrap:wrap}.overflow-hidden{overflow:hidden}.rounded{border-radius:var(--radius-md)}.border{border:1px solid var(--color-border)}.border-primary{border-color:#003b7342!important}.bg-surface{background:#ffffffb8;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.p-0{padding:0}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.p-xl{padding:var(--spacing-xl)}.mr-sm{margin-right:var(--spacing-sm)}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.text-success{color:var(--color-success-text)}.text-danger{color:var(--color-danger-text)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-md{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.no-padding{padding:0!important}.page-container{width:100%;display:flex;flex-direction:column;gap:var(--spacing-lg);flex:1 0 auto;min-height:100%}.info-card{padding:clamp(1.5rem,2vw,2rem);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#ffffffc7;box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.loading-container{display:flex;min-height:260px;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);color:var(--color-text-secondary)}.loading-spinner{width:2.75rem;height:2.75rem;border-radius:999px;border:3px solid rgba(0,59,115,.12);border-top-color:var(--color-primary);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.page-table-view{display:flex;flex-direction:column;flex:1;min-height:0;gap:var(--spacing-md);overflow:hidden}.page-table-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);flex-shrink:0}.page-table-toolbar h2{margin:0;white-space:nowrap}.page-table-search{max-width:22rem;width:100%;margin:0}.page-table-view .table-container{flex:1;min-height:0;overflow-y:auto;overflow-x:auto}.detail-close-btn{display:inline-flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;flex-shrink:0;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-base);color:var(--color-text-secondary);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.detail-close-btn:hover{background:var(--color-bg-hover);color:var(--color-text-primary);border-color:var(--color-border-hover)}
