.calendar-root[data-v-7625737c]{width:100%}.calendar-header[data-v-7625737c]{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.calendar-title[data-v-7625737c]{font-size:1.3rem;font-weight:700;color:#42b983}.calendar-nav[data-v-7625737c]{background:none;border:none;font-size:1.3rem;color:#42b983;cursor:pointer;padding:0 10px;transition:color .2s}.calendar-nav[data-v-7625737c]:hover{color:#2c8c6d}.calendar-grid[data-v-7625737c]{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-day[data-v-7625737c]{text-align:center;padding:8px 0;font-size:1.05rem;border-radius:6px;min-width:36px;min-height:36px;background:#f8fafc;color:#333}.calendar-day-label[data-v-7625737c]{font-weight:700;color:#42b983;background:#f0f9f5}.calendar-day.today[data-v-7625737c]{background:#42b983;color:#fff;font-weight:700}.staff-page-container[data-v-10bf08c3]{max-width:600px;margin:0 auto}.staff-page-title[data-v-10bf08c3]{font-size:2rem;color:#42b983;margin-bottom:24px;font-weight:700}.commute-actions[data-v-10bf08c3]{display:flex;gap:16px;margin-bottom:20px}.commute-info[data-v-10bf08c3]{margin-bottom:20px}.commute-list[data-v-10bf08c3]{background:#f8fafc;border-radius:8px;padding:20px;box-shadow:0 2px 8px rgba(0,0,0,.06)}.leave-info-section[data-v-4f28b27b]{width:100%;margin-top:24px;background:#f8fafc;border-radius:8px;padding:16px 10px 10px 10px;box-shadow:0 1px 4px rgba(66,185,131,.06)}.leave-info-title[data-v-4f28b27b]{font-size:1.1rem;color:#42b983;font-weight:700;margin-bottom:10px}.leave-info-list[data-v-4f28b27b]{list-style:none;padding:0;margin:0}.leave-info-list li[data-v-4f28b27b]{padding:6px 0;border-bottom:1px solid #e0e0e0;color:#444;font-size:.98rem;display:flex;flex-wrap:wrap;gap:8px;align-items:center}.leave-info-list li[data-v-4f28b27b]:last-child{border-bottom:none}.leave-name[data-v-4f28b27b]{font-weight:600;color:#2c8c6d}.leave-date[data-v-4f28b27b]{color:#666}.leave-type[data-v-4f28b27b]{color:#42b983;font-weight:500}.leave-reason[data-v-4f28b27b]{color:#888}.leave-none[data-v-4f28b27b]{color:#aaa;text-align:center;width:100%;padding:10px 0}.leave-info-section[data-v-4115d064]{width:100%;margin-top:24px;background:#f8fafc;border-radius:8px;padding:16px 10px 10px 10px;box-shadow:0 1px 4px rgba(66,185,131,.06)}.leave-info-title[data-v-4115d064]{font-size:1.1rem;color:#42b983;font-weight:700;margin-bottom:10px}.leave-info-list[data-v-4115d064]{list-style:none;padding:0;margin:0}.leave-info-list li[data-v-4115d064]{padding:6px 0;border-bottom:1px solid #e0e0e0;color:#444;font-size:.98rem;display:flex;flex-wrap:wrap;gap:8px;align-items:center}.leave-info-list li[data-v-4115d064]:last-child{border-bottom:none}.leave-name[data-v-4115d064]{font-weight:600;color:#2c8c6d}.leave-date[data-v-4115d064]{color:#666}.leave-type[data-v-4115d064]{color:#42b983;font-weight:500}.leave-reason[data-v-4115d064]{color:#888}.leave-none[data-v-4115d064]{color:#aaa;text-align:center;width:100%;padding:10px 0}body[data-v-21c4ebee]{background:linear-gradient(120deg,#f8fafc,#e6f0ec)}.private-content-container[data-v-21c4ebee]{max-width:1200px;margin:40px auto;padding:32px 24px;border-radius:24px;background:hsla(0,0%,100%,.95);box-shadow:0 8px 32px rgba(66,185,131,.1)}.private-content-flex[data-v-21c4ebee]{display:flex;gap:32px;align-items:flex-start;flex-wrap:wrap}.content-card[data-v-21c4ebee]{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px rgba(0,0,0,.1);padding:25px;margin-bottom:20px;flex:1 1 340px;min-width:0}h3[data-v-21c4ebee]{color:#42b983;margin-top:0;margin:40px 0 0}.private-data[data-v-21c4ebee]{margin-top:20px;padding:16px 18px;border-radius:10px;background:linear-gradient(90deg,#f0f9f5,#e6f0ec);box-shadow:0 1px 6px rgba(66,185,131,.07);display:flex;align-items:center;gap:12px;font-size:1.08rem}.login-icon[data-v-21c4ebee]{font-size:1.3rem;color:#42b983;margin-right:4px}.login-label[data-v-21c4ebee]{color:#2c8c6d;font-weight:600;margin-right:6px}.login-time[data-v-21c4ebee]{color:#444;font-family:JetBrains Mono,Fira Mono,Menlo,Consolas,"monospace";font-size:1.08rem;letter-spacing:.01em}h4[data-v-21c4ebee]{color:#555;margin-bottom:10px}p[data-v-21c4ebee]{margin:8px 0;color:#666}ul[data-v-21c4ebee]{list-style-type:none;padding:0}li[data-v-21c4ebee]{display:inline-block;margin:0 10px}a[data-v-21c4ebee]{color:#42b983}.api-test-section[data-v-21c4ebee]{margin:30px 0;padding:20px;background-color:#f5f5f5;border-radius:8px;text-align:left}.api-buttons[data-v-21c4ebee]{margin-bottom:20px}.api-button[data-v-21c4ebee]{background-color:#42b983;color:#fff;border:none;padding:10px 15px;margin-right:10px;border-radius:4px;cursor:pointer;font-weight:700}.api-button[data-v-21c4ebee]:hover{background-color:#3aa876}.loading[data-v-21c4ebee]{margin:10px 0;font-style:italic;color:#666}.error[data-v-21c4ebee]{margin:10px 0;padding:10px;background-color:#ffebee;border-left:4px solid #f44336;color:#d32f2f}.response-data[data-v-21c4ebee]{margin:10px 0;padding:15px;background-color:#e8f5e9;border-radius:4px;overflow-x:auto}.response-data pre[data-v-21c4ebee]{margin:0}.items-list[data-v-21c4ebee]{margin:10px 0}.items-list ul[data-v-21c4ebee]{list-style-type:disc;padding-left:20px}.items-list li[data-v-21c4ebee]{display:block;margin:5px 0}.quote-section[data-v-21c4ebee]{margin-bottom:24px;background:linear-gradient(120deg,#e0f7fa,#f8fafc);border-radius:14px;box-shadow:0 2px 12px rgba(66,185,131,.08);padding:24px 20px 18px 20px;display:flex;align-items:center;justify-content:center;min-height:70px;position:relative}.quote-text[data-v-21c4ebee]{font-size:1.25rem;color:#2c8c6d;font-weight:600;text-align:center;margin:0;line-height:1.7;letter-spacing:-.01em;display:flex;align-items:center;justify-content:center}.quote-icon[data-v-21c4ebee]{font-size:2.2rem;color:#42b983;margin:0 10px;font-family:serif;opacity:.25}.staff-features[data-v-21c4ebee]{margin-top:32px;padding:24px 0 0 0;border-top:1px solid #eee}.staff-title[data-v-21c4ebee]{font-size:1.2rem;font-weight:700;color:#42b983;margin-bottom:18px}.staff-tabs[data-v-21c4ebee]{display:flex;gap:.2rem;margin-bottom:1rem}.staff-tab[data-v-21c4ebee]{background:#f5f5f5;border:none;border-radius:6px 6px 0 0;padding:.5rem 1rem;font-size:1rem;color:#666;cursor:pointer;font-weight:500;transition:background .2s,color .2s}.staff-tab.active[data-v-21c4ebee]{background:#42b983;color:#fff;font-weight:700}.staff-tab-content[data-v-21c4ebee]{background:#fff;border-radius:0 0 8px 8px;box-shadow:0 2px 8px rgba(0,0,0,.04)}.calendar-card[data-v-21c4ebee]{min-width:340px;max-width:400px;flex:1 1 340px;background:#fff;border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,.08);padding:28px 18px 24px 18px;margin-top:0;display:flex;flex-direction:column;align-items:center;min-width:0}.calendar-root[data-v-21c4ebee]{width:100%}.calendar-header[data-v-21c4ebee]{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.calendar-title[data-v-21c4ebee]{font-size:1.3rem;font-weight:700;color:#42b983}.calendar-nav[data-v-21c4ebee]{background:none;border:none;font-size:1.3rem;color:#42b983;cursor:pointer;padding:0 10px;transition:color .2s}.calendar-nav[data-v-21c4ebee]:hover{color:#2c8c6d}.calendar-grid[data-v-21c4ebee]{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-day[data-v-21c4ebee]{text-align:center;padding:8px 0;font-size:1.05rem;border-radius:6px;min-width:36px;min-height:36px;background:#f8fafc;color:#333}.calendar-day-label[data-v-21c4ebee]{font-weight:700;color:#42b983;background:#f0f9f5}.calendar-day.today[data-v-21c4ebee]{background:#42b983;color:#fff;font-weight:700}.info-flex-row[data-v-21c4ebee]{display:flex;flex-direction:column;gap:16px;width:100%}.info-flex-row[data-v-21c4ebee]>*{width:100%;min-width:0}@media (max-width:900px){.private-content-flex[data-v-21c4ebee]{flex-direction:column;gap:18px}.calendar-card[data-v-21c4ebee],.content-card[data-v-21c4ebee]{max-width:100%;min-width:0;width:100%;box-sizing:border-box;margin-bottom:0}.calendar-card[data-v-21c4ebee]{padding:18px 6px 18px 6px}.info-flex-row[data-v-21c4ebee]{gap:12px}}@media (max-width:600px){.private-content-container[data-v-21c4ebee]{padding:8px}.calendar-card[data-v-21c4ebee],.content-card[data-v-21c4ebee]{padding:12px 4px}}.pointer-events-none{pointer-events:none}.user-info[data-v-397b0516]{border-radius:8px;padding:4px 8px;transition:all .2s ease;background-color:rgba(243,244,246,.5)}.dark .user-info[data-v-397b0516]{background-color:rgba(55,65,81,.5)}.profile-image[data-v-397b0516]{width:32px;height:32px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid #fff;box-shadow:0 1px 3px rgba(0,0,0,.1)}.dark .profile-image[data-v-397b0516]{border-color:#374151}.profile-placeholder[data-v-397b0516]{width:32px;height:32px;border-radius:50%;background-color:#e5e7eb;border:2px solid #fff;box-shadow:0 1px 3px rgba(0,0,0,.1)}.dark .profile-placeholder[data-v-397b0516]{background-color:#4b5563;border-color:#374151}.user-details h3[data-v-397b0516],.user-details p[data-v-397b0516]{margin:0;line-height:1.2}.logout-btn[data-v-397b0516]{background-color:#ef4444;color:#fff;border:none;border-radius:6px;padding:4px 8px;font-size:12px;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;justify-content:center}.logout-btn[data-v-397b0516]:hover{background-color:#dc2626}@media (max-width:640px){.logout-btn[data-v-397b0516]{padding:4px 6px}}.brand-name[data-v-397b0516]{font-weight:700;letter-spacing:-.5px;background:linear-gradient(45deg,#3498db,#8e44ad);-webkit-background-clip:text;background-clip:text;color:transparent;transition:transform .3s ease}.brand-name[data-v-397b0516]:hover{transform:scale(1.05)}@media (max-width:1154px){.brand-name[data-v-397b0516]{display:none!important}}.toast-container[data-v-07083f04]{position:fixed;top:1rem;right:1rem;z-index:9999;pointer-events:none}.toast[data-v-07083f04]{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;margin-bottom:.5rem;border-radius:.5rem;box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05);backdrop-filter:blur(8px);pointer-events:auto;max-width:24rem;min-width:16rem}.toast-success[data-v-07083f04]{background-color:rgba(16,185,129,.95);color:#fff;border-left:4px solid #059669}.toast-error[data-v-07083f04]{background-color:rgba(239,68,68,.95);color:#fff;border-left:4px solid #dc2626}.toast-warning[data-v-07083f04]{background-color:rgba(245,158,11,.95);color:#fff;border-left:4px solid #d97706}.toast-info[data-v-07083f04]{background-color:rgba(59,130,246,.95);color:#fff;border-left:4px solid #2563eb}.toast-icon[data-v-07083f04]{flex-shrink:0;margin-top:.125rem}.toast-content[data-v-07083f04]{flex:1;min-width:0}.toast-message[data-v-07083f04]{font-weight:500;font-size:.875rem;line-height:1.25rem}.toast-description[data-v-07083f04]{font-size:.75rem;line-height:1rem;margin-top:.25rem;opacity:.9}.toast-close[data-v-07083f04]{flex-shrink:0;padding:.25rem;border-radius:.25rem;background:transparent;border:none;color:currentColor;cursor:pointer;opacity:.7;transition:opacity .2s}.toast-close[data-v-07083f04]:hover{opacity:1}.toast-closable[data-v-07083f04]{cursor:pointer}.toast-enter-active[data-v-07083f04]{transition:all .3s ease-out}.toast-leave-active[data-v-07083f04]{transition:all .3s ease-in}.toast-enter-from[data-v-07083f04],.toast-leave-to[data-v-07083f04]{transform:translateX(100%);opacity:0}.toast-move[data-v-07083f04]{transition:transform .3s ease}@media (max-width:640px){.toast-container[data-v-07083f04]{top:.5rem;right:.5rem;left:.5rem}.toast[data-v-07083f04]{max-width:none;min-width:0}}.fade-enter-active,.fade-leave-active{transition:opacity .3s}.fade-enter-from,.fade-leave-to{opacity:0}.scroll-btn{outline:none;border:none;cursor:pointer;box-shadow:0 2px 8px rgba(60,80,120,.13);background:#42b983;color:#fff;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .3s ease-out,transform .2s ease-out;will-change:background-color,transform}.scroll-btn:hover{background:#2c8c6d;transform:scale(1.05)}.scroll-btn:active{transform:scale(.95)}.responsive-hide-desktop,.responsive-hide-mobile,.responsive-stack-mobile{@media (max-width:calc(var(--breakpoint-md ) - 1px)){flex-direction:column!important;gap:var(--spacing-2)!important}}:root{--color-primary-50:#eff6ff;--color-primary-100:#dbeafe;--color-primary-200:#bfdbfe;--color-primary-300:#93c5fd;--color-primary-400:#60a5fa;--color-primary-500:#3b82f6;--color-primary-600:#2563eb;--color-primary-700:#1d4ed8;--color-primary-800:#1e40af;--color-primary-900:#1e3a8a;--color-secondary-50:#f9fafb;--color-secondary-100:#f3f4f6;--color-secondary-200:#e5e7eb;--color-secondary-300:#d1d5db;--color-secondary-400:#9ca3af;--color-secondary-500:#6b7280;--color-secondary-600:#4b5563;--color-secondary-700:#374151;--color-secondary-800:#1f2937;--color-secondary-900:#111827;--color-success-50:#ecfdf5;--color-success-100:#d1fae5;--color-success-500:#10b981;--color-success-600:#059669;--color-success-700:#047857;--color-warning-50:#fffbeb;--color-warning-100:#fef3c7;--color-warning-500:#f59e0b;--color-warning-600:#d97706;--color-warning-700:#b45309;--color-error-50:#fef2f2;--color-error-100:#fee2e2;--color-error-500:#ef4444;--color-error-600:#dc2626;--color-error-700:#b91c1c;--color-info-50:#f0f9ff;--color-info-100:#e0f2fe;--color-info-500:#06b6d4;--color-info-600:#0891b2;--color-info-700:#0e7490;--bg-primary:var(--color-secondary-50);--bg-secondary:var(--color-secondary-100);--bg-tertiary:var(--color-secondary-200);--bg-muted:var(--color-secondary-300);--bg-inverse:var(--color-secondary-900);--bg-overlay:rgba(17,24,39,.5);--text-primary:var(--color-secondary-900);--text-secondary:var(--color-secondary-600);--text-muted:var(--color-secondary-400);--text-inverse:var(--color-secondary-50);--text-link:var(--color-primary-600);--text-link-hover:var(--color-primary-700);--border-subtle:var(--color-secondary-100);--border-default:var(--color-secondary-200);--border-medium:var(--color-secondary-300);--border-strong:var(--color-secondary-400);--border-inverse:var(--color-secondary-700);--surface-primary:#fff;--surface-secondary:var(--color-secondary-50);--surface-success:var(--color-success-50);--surface-warning:var(--color-warning-50);--surface-error:var(--color-error-50);--surface-info:var(--color-info-50);--spacing-0:0;--spacing-1:0.25rem;--spacing-2:0.5rem;--spacing-3:0.75rem;--spacing-4:1rem;--spacing-5:1.25rem;--spacing-6:1.5rem;--spacing-8:2rem;--spacing-10:2.5rem;--spacing-12:3rem;--spacing-16:4rem;--spacing-20:5rem;--spacing-24:6rem;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--line-height-tight:1.25;--line-height-normal:1.5;--line-height-relaxed:1.75;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--shadow-xs:0 1px 2px 0 rgba(0,0,0,.05);--shadow-sm:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px 0 rgba(0,0,0,.06);--shadow-md:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05);--shadow-xl:0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04);--shadow-2xl:0 25px 50px -12px rgba(0,0,0,.25);--shadow-inner:inset 0 2px 4px 0 rgba(0,0,0,.06);--shadow-top:0 -4px 6px -1px rgba(0,0,0,.1);--radius-none:0;--radius-sm:0.125rem;--radius-default:0.25rem;--radius-md:0.375rem;--radius-lg:0.5rem;--radius-xl:0.75rem;--radius-2xl:1rem;--radius-full:9999px;--component-height-xs:1.5rem;--component-height-sm:2rem;--component-height-md:2.5rem;--component-height-lg:3rem;--component-height-xl:3.5rem;--z-index-dropdown:10;--z-index-sticky:20;--z-index-fixed:30;--z-index-modal-backdrop:40;--z-index-modal:50;--z-index-popover:60;--z-index-tooltip:70;--z-index-toast:80;--duration-instant:0ms;--duration-fast:150ms;--duration-normal:300ms;--duration-slow:500ms;--duration-slower:750ms;--easing-linear:linear;--easing-ease:ease;--easing-ease-in:ease-in;--easing-ease-out:ease-out;--easing-ease-in-out:ease-in-out;--easing-bounce:cubic-bezier(0.68,-0.55,0.265,1.55);--breakpoint-sm:640px;--breakpoint-md:768px;--breakpoint-lg:1024px;--breakpoint-xl:1280px;--breakpoint-2xl:1536px}@media (prefers-color-scheme:dark){:root{--bg-primary:var(--color-secondary-900);--bg-secondary:var(--color-secondary-800);--bg-tertiary:var(--color-secondary-700);--bg-muted:var(--color-secondary-600);--bg-inverse:var(--color-secondary-50);--text-primary:var(--color-secondary-50);--text-secondary:var(--color-secondary-300);--text-muted:var(--color-secondary-500);--text-inverse:var(--color-secondary-900);--border-subtle:var(--color-secondary-800);--border-default:var(--color-secondary-700);--border-medium:var(--color-secondary-600);--border-strong:var(--color-secondary-500);--border-inverse:var(--color-secondary-300);--surface-primary:var(--color-secondary-900);--surface-secondary:var(--color-secondary-800)}}@media (prefers-contrast:high){:root{--border-default:var(--color-secondary-900);--border-medium:var(--color-secondary-900);--text-secondary:var(--color-secondary-800)}}.layout-container{width:100%;height:100%;min-height:0;box-sizing:border-box}.layout-flex{display:flex}.layout-flex-col{display:flex;flex-direction:column;min-height:0}.layout-flex-row{display:flex;flex-direction:row;min-width:0}.layout-centered{display:flex;align-items:center;justify-content:center}.layout-between{justify-content:space-between}.layout-around,.layout-between{display:flex;align-items:center}.layout-around{justify-content:space-around}.layout-evenly{display:flex;align-items:center;justify-content:space-evenly}.layout-start{display:flex;align-items:flex-start;justify-content:flex-start}.layout-end{display:flex;align-items:flex-end;justify-content:flex-end}.container-card{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.container-panel{background:var(--surface-secondary);border-radius:var(--radius-md);padding:var(--spacing-4)}.container-section{margin-bottom:var(--spacing-6)}.container-elevated{background:var(--surface-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:1px solid var(--border-subtle)}.text-display-lg{font-size:var(--font-size-4xl)}.text-display-lg,.text-display-md{font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);color:var(--text-primary)}.text-display-md{font-size:var(--font-size-3xl)}.text-heading-xl{font-size:var(--font-size-2xl);line-height:var(--line-height-tight)}.text-heading-lg,.text-heading-xl{font-weight:var(--font-weight-semibold);color:var(--text-primary)}.text-heading-lg{font-size:var(--font-size-xl);line-height:var(--line-height-normal)}.text-heading-md{font-size:var(--font-size-lg)}.text-heading-md,.text-heading-sm{font-weight:var(--font-weight-medium);line-height:var(--line-height-normal);color:var(--text-primary)}.text-heading-sm{font-size:var(--font-size-base)}.text-body-lg{font-size:var(--font-size-lg);font-weight:var(--font-weight-normal);line-height:var(--line-height-relaxed);color:var(--text-primary)}.text-body{font-size:var(--font-size-base)}.text-body,.text-body-sm{font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);color:var(--text-primary)}.text-body-sm{font-size:var(--font-size-sm)}.text-caption{font-weight:var(--font-weight-normal);color:var(--text-secondary)}.text-caption,.text-overline{font-size:var(--font-size-xs);line-height:var(--line-height-normal)}.text-overline{font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-inverse{color:var(--text-inverse)}.text-link{color:var(--text-link);text-decoration:underline;transition:color var(--duration-fast) var(--easing-ease-out)}.text-link:hover{color:var(--text-link-hover)}.status-success{background-color:var(--surface-success);color:var(--color-success-700);border-color:var(--color-success-200)}.status-warning{background-color:var(--surface-warning);color:var(--color-warning-700);border-color:var(--color-warning-200)}.status-error{background-color:var(--surface-error);color:var(--color-error-700);border-color:var(--color-error-200)}.status-info{background-color:var(--surface-info);color:var(--color-info-700);border-color:var(--color-info-200)}.interactive{cursor:pointer;transition:all var(--duration-fast) var(--easing-ease-out)}.interactive:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.interactive:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.focus-ring{outline:none;transition:box-shadow var(--duration-fast) var(--easing-ease-out)}.focus-ring:focus{box-shadow:0 0 0 3px var(--color-primary-200)}.focus-ring-inset{outline:none;transition:box-shadow var(--duration-fast) var(--easing-ease-out)}.focus-ring-inset:focus{box-shadow:inset 0 0 0 2px var(--color-primary-500)}.disabled{opacity:.5;cursor:not-allowed}.disabled,.loading{pointer-events:none}.loading{position:relative}.loading:after{content:"";position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border:2px solid var(--color-primary-200);border-top-color:var(--color-primary-600);border-radius:50%;animation:spin var(--duration-slow) linear infinite}.scrollbar-styled{scrollbar-width:thin;scrollbar-color:var(--border-medium) var(--border-subtle)}.scrollbar-styled::-webkit-scrollbar{width:8px;height:8px}.scrollbar-styled::-webkit-scrollbar-track{background:var(--border-subtle);border-radius:var(--radius-default)}.scrollbar-styled::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:var(--radius-default);border:2px solid var(--border-subtle)}.scrollbar-styled::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}.scrollbar-hidden{scrollbar-width:none;-ms-overflow-style:none}.scrollbar-hidden::-webkit-scrollbar{display:none}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:fadeIn var(--duration-normal) var(--easing-ease-out)}.animate-slide-down{animation:slideDown var(--duration-normal) var(--easing-ease-out)}.animate-slide-up{animation:slideUp var(--duration-normal) var(--easing-ease-out)}.animate-scale-in{animation:scaleIn var(--duration-fast) var(--easing-ease-out)}.responsive-hide-desktop,.responsive-hide-mobile,.responsive-stack-mobile{@media (max-width:calc(var(--breakpoint-md ) - 1px)){flex-direction:column!important;gap:var(--spacing-2)!important}}@media print{.print-hidden{display:none!important}.container-card,.container-elevated{box-shadow:none!important;border:1px solid var(--border-default)!important}}.btn-base{display:inline-flex;align-items:center;justify-content:center;font-weight:var(--font-weight-medium);border-radius:var(--radius-md);border:1px solid transparent;transition:all var(--duration-fast) var(--easing-ease-out);cursor:pointer;text-decoration:none;white-space:nowrap}.btn-base:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-xs{height:var(--component-height-xs);padding:0 var(--spacing-2);font-size:var(--font-size-xs);gap:var(--spacing-1)}.btn-sm{gap:var(--spacing-1)}.btn-md,.btn-sm{height:var(--component-height-sm);padding:0 var(--spacing-3);font-size:var(--font-size-sm)}.btn-lg,.btn-md{gap:var(--spacing-2)}.btn-lg{height:var(--component-height-lg);padding:0 var(--spacing-6);font-size:var(--font-size-lg)}.btn-primary{background-color:var(--color-primary-600);color:#fff;border-color:var(--color-primary-600)}.btn-primary:hover{background-color:var(--color-primary-700);color:#fff;border-color:var(--color-primary-700)}.btn-secondary{background-color:var(--color-secondary-600);color:#fff;border-color:var(--color-secondary-600)}.btn-secondary:hover{background-color:var(--color-secondary-700);color:#fff;border-color:var(--color-secondary-700)}.btn-success{background-color:var(--color-success-600);color:#fff;border-color:var(--color-success-600)}.btn-success:hover{background-color:var(--color-success-700);color:#fff;border-color:var(--color-success-700)}.btn-warning{background-color:var(--color-warning-600);color:#fff;border-color:var(--color-warning-600)}.btn-warning:hover{background-color:var(--color-warning-700);color:#fff;border-color:var(--color-warning-700)}.btn-error{background-color:var(--color-error-600);color:#fff;border-color:var(--color-error-600)}.btn-error:hover{background-color:var(--color-error-700);color:#fff;border-color:var(--color-error-700)}.btn-outline{background-color:transparent;border-color:var(--border-default);color:var(--text-primary)}.btn-outline:hover{background-color:var(--bg-secondary);border-color:var(--border-medium)}.btn-ghost{background-color:transparent;border-color:transparent;color:var(--text-primary)}.btn-ghost:hover{background-color:var(--bg-secondary)}.input-base{width:100%;height:var(--component-height-sm);padding:0 var(--spacing-2);font-size:var(--font-size-sm);border:1px solid var(--border-default);border-radius:var(--radius-md);background-color:var(--surface-primary);color:var(--text-primary);transition:all var(--duration-fast) var(--easing-ease-out)}.input-base::-moz-placeholder{color:var(--text-muted)}.input-base::placeholder{color:var(--text-muted)}.input-base:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-200)}.input-sm{height:var(--component-height-sm);padding:0 var(--spacing-2);font-size:var(--font-size-sm)}.input-lg{height:var(--component-height-lg);padding:0 var(--spacing-4);font-size:var(--font-size-lg)}.input-error,.input-error:focus{border-color:var(--color-error-500)}.input-error:focus{box-shadow:0 0 0 3px var(--color-error-200)}.badge-base{display:inline-flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:var(--radius-full);padding:var(--spacing-1) var(--spacing-2);border:1px solid transparent}.badge-primary{background-color:var(--color-primary-100);color:var(--color-primary-800);border-color:var(--color-primary-200)}.badge-success{background-color:var(--color-success-100);color:var(--color-success-800);border-color:var(--color-success-200)}.badge-warning{background-color:var(--color-warning-100);color:var(--color-warning-800);border-color:var(--color-warning-200)}.badge-error{background-color:var(--color-error-100);color:var(--color-error-800);border-color:var(--color-error-200)}.badge-neutral{background-color:var(--color-secondary-100);color:var(--color-secondary-800);border-color:var(--color-secondary-200)}.card-base{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.card-elevated{box-shadow:var(--shadow-md)}.card-interactive{cursor:pointer;transition:all var(--duration-fast) var(--easing-ease-out)}.card-interactive:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.card-header{padding:var(--spacing-4) var(--spacing-4) var(--spacing-3);border-bottom:1px solid var(--border-default)}.card-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin:0}.card-body{padding:var(--spacing-4)}.card-footer{padding:var(--spacing-3) var(--spacing-4) var(--spacing-4);border-top:1px solid var(--border-default);background-color:var(--bg-secondary)}.table-base{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden;background:var(--surface-primary)}.table-header{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-default)}.table-header th{padding:var(--spacing-3) var(--spacing-4);text-align:left;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.table-row{transition:background-color var(--duration-fast) var(--easing-ease-out)}.table-row:hover{background-color:var(--bg-secondary)}.table-row.selected{background-color:var(--color-primary-50)}.table-cell{padding:var(--spacing-3) var(--spacing-4);border-bottom:1px solid var(--border-subtle);font-size:var(--font-size-sm);color:var(--text-primary)}.tab-list{display:flex;border-bottom:1px solid var(--border-default);background-color:var(--bg-secondary)}.tab-button{padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary);border:none;background:transparent;cursor:pointer;position:relative;transition:all var(--duration-fast) var(--easing-ease-out)}.tab-button:hover{color:var(--text-primary);background-color:var(--bg-primary)}.tab-button.active{color:var(--color-primary-600);background-color:var(--surface-primary)}.tab-button.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background-color:var(--color-primary-600)}.tab-panel{background-color:var(--surface-primary);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.dropdown-base{position:relative;display:inline-block}.dropdown-menu{position:absolute;top:100%;left:0;z-index:var(--z-index-dropdown);min-width:12rem;margin-top:var(--spacing-1);background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(-4px);transition:all var(--duration-fast) var(--easing-ease-out)}.dropdown-base.open .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-item{display:block;width:100%;padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-sm);color:var(--text-primary);text-decoration:none;border:none;background:transparent;cursor:pointer;transition:background-color var(--duration-fast) var(--easing-ease-out)}.dropdown-item:hover{background-color:var(--bg-secondary)}.dropdown-divider{height:1px;margin:var(--spacing-1) 0;background-color:var(--border-default)}.modal-backdrop{position:fixed;inset:0;z-index:var(--z-index-modal-backdrop);background-color:var(--bg-overlay);opacity:0;transition:opacity var(--duration-normal) var(--easing-ease-out)}.modal-backdrop.open{opacity:1}.modal-container{position:fixed;inset:0;z-index:var(--z-index-modal);display:flex;align-items:center;justify-content:center;padding:var(--spacing-4)}.modal-content{background:var(--surface-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);max-width:90vw;max-height:90vh;width:100%;overflow:hidden;transform:scale(.9);transition:transform var(--duration-normal) var(--easing-ease-out)}.modal-backdrop.open .modal-content{transform:scale(1)}.toast-container{position:fixed;top:var(--spacing-6);right:var(--spacing-6);z-index:var(--z-index-toast);display:flex;flex-direction:column;gap:var(--spacing-2)}.toast-base{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:300px;transform:translateX(100%);transition:transform var(--duration-normal) var(--easing-ease-out)}.toast-base.show{transform:translateX(0)}.toast-success{border-left:4px solid var(--color-success-500)}.toast-warning{border-left:4px solid var(--color-warning-500)}.toast-error{border-left:4px solid var(--color-error-500)}.toast-info{border-left:4px solid var(--color-info-500)}.spinner-base{display:inline-block;width:20px;height:20px;border:2px solid var(--border-subtle);border-top-color:var(--color-primary-600);border-radius:50%;animation:spin var(--duration-slow) linear infinite}.spinner-sm{width:16px;height:16px}.spinner-lg{width:24px;height:24px;border-width:3px}.progress-base{width:100%;height:8px;background-color:var(--bg-tertiary);overflow:hidden}.progress-bar,.progress-base{border-radius:var(--radius-full)}.progress-bar{height:100%;background-color:var(--color-primary-600);transition:width var(--duration-normal) var(--easing-ease-out)}.progress-sm{height:4px}.progress-lg{height:12px}