@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";.app-shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border-light);z-index:var(--z-sticky);transition:transform var(--transition-slow);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{padding:var(--space-lg) var(--space-lg) var(--space-md);justify-content:space-between;align-items:center;display:flex}.sidebar-logo{letter-spacing:.08em;background:linear-gradient(135deg, var(--color-primary), #bc63e9);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.25rem;font-weight:800}.sidebar-user{align-items:center;gap:var(--space-sm);margin:0 var(--space-md) var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-lg);display:flex}.sidebar-user:hover{transform:none}.sidebar-avatar{border-radius:var(--radius-full);background:var(--color-primary-soft);width:38px;height:38px;color:var(--color-primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-user-info{flex-direction:column;display:flex;overflow:hidden}.sidebar-username{white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:600;overflow:hidden}.sidebar-email{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar-nav{padding:0 var(--space-sm);flex-direction:column;flex:1;gap:2px;display:flex}.sidebar-link{align-items:center;gap:var(--space-sm);padding:10px var(--space-md);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);text-align:left;background:0 0;border:none;width:100%;font-size:.875rem;font-weight:500;text-decoration:none;display:flex}.sidebar-link:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.sidebar-link.active{background:var(--color-primary-soft);color:var(--color-primary);font-weight:600}.sidebar-link-danger:hover{background:var(--color-danger-soft);color:var(--color-danger)}.sidebar-footer{padding:var(--space-sm);border-top:1px solid var(--color-border-light);flex-direction:column;gap:2px;display:flex}.sidebar-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:calc(var(--z-sticky) - 1);animation:fade-in var(--transition-fast) forwards;background:#0006;position:fixed;inset:0}.main-wrapper{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.topbar{height:var(--topbar-height);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--glass-border);padding:0 var(--space-xl);z-index:var(--z-base);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:var(--space-md);display:flex}.topbar-greeting{color:var(--color-text-secondary);font-size:1.125rem;font-weight:400}.topbar-username{color:var(--color-text-primary);font-weight:600}.topbar-right{align-items:center;gap:var(--space-sm);display:flex}.notification-btn{position:relative}.notification-badge{color:#fff;background:var(--color-danger);border-radius:100px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:.625rem;font-weight:700;line-height:1;display:flex;position:absolute;top:2px;right:2px}.idle-warning{background:var(--color-warning-soft);border-bottom:1px solid var(--color-warning);padding:var(--space-sm) var(--space-xl);text-align:center;animation:fade-in var(--transition-base) forwards}.idle-warning p{color:var(--color-warning);font-size:.8125rem;font-weight:500}.main-content{padding:var(--space-xl);flex:1;width:100%;max-width:1200px;margin:0 auto}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.sidebar-open{box-shadow:var(--shadow-xl);transform:translate(0)}.main-wrapper{margin-left:0}.topbar{padding:0 var(--space-md)}.main-content{padding:var(--space-md)}}.onboarding{background:var(--color-bg-primary);min-height:100vh;padding:var(--space-lg);justify-content:center;align-items:center;display:flex}.onboarding-container{flex-direction:column;align-items:center;width:100%;max-width:520px;display:flex;position:relative}.onboarding-skip{color:var(--color-text-tertiary);position:absolute;top:0;right:0}@keyframes slide-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.onboarding-slide{text-align:center;animation:slide-in var(--transition-slow) forwards;padding:var(--space-2xl) 0;flex-direction:column;align-items:center;display:flex}.onboarding-icon-wrapper{border-radius:var(--radius-2xl);background:var(--color-primary-soft);width:100px;height:100px;margin-bottom:var(--space-xl);justify-content:center;align-items:center;display:flex}.onboarding-icon{font-size:2.5rem}.onboarding-title{margin-bottom:var(--space-sm);color:var(--color-text-primary);font-size:1.75rem;font-weight:700}.onboarding-subtitle{color:var(--color-text-secondary);max-width:400px;margin-bottom:var(--space-xl);font-size:.9375rem;line-height:1.6}.onboarding-highlights{gap:var(--space-sm);flex-direction:column;width:100%;max-width:340px;display:flex}.onboarding-highlight{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-lg);font-size:.875rem;font-weight:500;display:flex}.onboarding-highlight:hover{transform:none}.onboarding-highlight-icon{border-radius:var(--radius-full);background:var(--color-success-soft);flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.onboarding-dots{gap:var(--space-sm);margin:var(--space-lg) 0;display:flex}.onboarding-dot{border-radius:var(--radius-full);background:var(--color-border);cursor:pointer;width:10px;height:10px;transition:all var(--transition-base);border:none}.onboarding-dot.active{background:var(--color-primary);border-radius:100px;width:28px}.onboarding-nav{align-items:center;gap:var(--space-md);width:100%;padding-top:var(--space-md);display:flex}.auth-page{background:var(--color-bg-primary);min-height:100vh;padding:var(--space-lg);justify-content:center;align-items:center;display:flex}.auth-container{flex-direction:column;align-items:center;width:100%;max-width:520px;display:flex}.auth-header{text-align:center;margin-bottom:var(--space-xl)}.auth-logo{letter-spacing:.08em;background:linear-gradient(135deg, var(--color-primary), #bc63e9);-webkit-text-fill-color:transparent;margin-bottom:var(--space-xs);-webkit-background-clip:text;background-clip:text;font-size:2rem;font-weight:800}.auth-subtitle{color:var(--color-text-secondary);font-size:.9375rem}.auth-form{gap:var(--space-md);width:100%;padding:var(--space-xl);flex-direction:column;display:flex}.auth-form:hover{transform:none}.auth-form-grid{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}@media (width<=520px){.auth-form-grid{grid-template-columns:1fr}}.auth-error-banner{background:var(--color-danger-soft);border:1px solid var(--color-danger);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);color:var(--color-danger);font-size:.8125rem;line-height:1.5}.auth-error-banner p{margin-bottom:2px}.auth-error-banner p:last-child{margin-bottom:0}.auth-footer-text{margin-top:var(--space-lg);color:var(--color-text-secondary);font-size:.875rem}.auth-link{color:var(--color-primary);font-weight:600}.auth-link:hover{text-decoration:underline}.home-page{min-height:calc(100vh - var(--topbar-height) - var(--space-xl) * 2);position:relative}.home-header{margin-bottom:var(--space-xl);justify-content:space-between;align-items:flex-start;gap:var(--space-md);display:flex}.home-stats{gap:var(--space-md);margin-bottom:var(--space-xl);grid-template-columns:repeat(4,1fr);display:grid}.stat-card{gap:var(--space-xs);padding:var(--space-lg);border-radius:var(--radius-xl);flex-direction:column;display:flex}.stat-card:hover{transform:none}.stat-label{color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;font-weight:500}.stat-value{color:var(--color-text-primary);font-size:1.375rem;font-weight:700}.stat-success{color:var(--color-success)}.stat-warning{color:var(--color-warning)}.home-project-list{gap:var(--space-md);flex-direction:column;display:flex}.project-card{cursor:pointer;transition:all var(--transition-base)}.project-card:hover{border-color:var(--color-primary-muted);transform:translateY(-2px)}.project-card-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:flex-start;gap:var(--space-md);display:flex}.project-card-title{margin-bottom:var(--space-xs);font-size:1rem;font-weight:600}.project-card-components{gap:var(--space-xs);flex-wrap:wrap;display:flex}.project-card-progress{margin-bottom:var(--space-md)}.project-card-progress-info{margin-bottom:var(--space-xs);justify-content:space-between;display:flex}.project-card-footer{padding-top:var(--space-sm);border-top:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.chat-fab{bottom:var(--space-xl);right:var(--space-xl);border-radius:var(--radius-full);width:56px;height:56px;box-shadow:var(--shadow-lg), 0 4px 20px #6b4de659;z-index:var(--z-base);transition:transform var(--transition-spring), box-shadow var(--transition-base);justify-content:center;align-items:center;display:flex;position:fixed}.chat-fab:hover{box-shadow:var(--shadow-xl), 0 6px 28px #6b4de673;transform:scale(1.08)}.chat-fab:active{transform:scale(.95)}@media (width<=768px){.home-header{flex-direction:column}.home-header .btn{width:100%}.home-stats{grid-template-columns:repeat(2,1fr)}.chat-fab{bottom:var(--space-lg);right:var(--space-lg)}}@media (width<=480px){.home-stats{grid-template-columns:1fr}}.new-project-page{flex-direction:column;max-width:640px;margin:0 auto;display:flex}.component-selection{margin-bottom:var(--space-xl)}.component-selection-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.component-cards{gap:var(--space-sm);flex-direction:column;display:flex}.component-card{align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);cursor:pointer;transition:all var(--transition-base);border:2px solid #0000;display:flex}.component-card:hover{border-color:var(--color-border);transform:none}.component-card.selected{border-color:var(--color-primary);background:var(--color-primary-soft)}.component-card-check{border-radius:var(--radius-sm);border:2px solid var(--color-border);width:24px;height:24px;transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.component-card.selected .component-card-check{background:var(--color-primary);border-color:var(--color-primary)}.component-card-info{flex-direction:column;flex:1;gap:2px;display:flex}.component-card-label{font-size:.9375rem;font-weight:600}.component-card-desc{line-height:1.4}.component-card-price{color:var(--color-primary);white-space:nowrap;font-size:.9375rem;font-weight:700}.price-summary{padding:var(--space-lg);margin-bottom:var(--space-lg);border-radius:var(--radius-xl)}.price-summary:hover{transform:none}.price-summary-row{justify-content:space-between;align-items:center;display:flex}.price-summary-total{color:var(--color-text-primary);font-size:1.5rem;font-weight:800}.price-summary-bonus{align-items:center;gap:var(--space-xs);margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--color-border-light);color:var(--color-success);font-size:.8125rem;font-weight:500;display:flex}.project-detail-page{gap:var(--space-lg);flex-direction:column;max-width:780px;margin:0 auto;display:flex}.pd-header-top{justify-content:space-between;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-md);display:flex}.pd-components{gap:var(--space-xs);margin-bottom:var(--space-lg);flex-wrap:wrap;display:flex}.pd-progress{margin-bottom:var(--space-md)}.pd-progress-info{margin-bottom:var(--space-xs);justify-content:space-between;font-size:.875rem;font-weight:500;display:flex}.pd-bonus{background:var(--color-success-soft);color:var(--color-success);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-md);font-size:.8125rem;font-weight:500}.pd-actions{gap:var(--space-sm);flex-wrap:wrap;display:flex}.pd-pay-form h4{margin-bottom:var(--space-sm)}.pd-table-wrapper{overflow-x:auto}.pd-table{border-collapse:collapse;width:100%;font-size:.875rem}.pd-table th{text-align:left;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.04em;padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border-light);font-size:.75rem;font-weight:500}.pd-table td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border-light);vertical-align:middle}.pd-table tbody tr{transition:background var(--transition-fast)}.pd-table tbody tr:hover{background:var(--color-surface-hover)}.pd-table-amount{font-weight:600}@media (width<=600px){.pd-actions{flex-direction:column}.pd-actions .btn{width:100%}}.chat-page{height:calc(100vh - var(--topbar-height) - var(--space-xl) * 2);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);background:var(--color-surface);flex-direction:column;max-width:780px;margin:0 auto;display:flex;overflow:hidden}.chat-header{align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border-light);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);display:flex}.chat-header-info h4{font-size:.9375rem;font-weight:600}.chat-messages{padding:var(--space-md) var(--space-lg);gap:var(--space-xs);flex-direction:column;flex:1;display:flex;overflow-y:auto}.chat-empty{flex:1;justify-content:center;align-items:center;display:flex}.chat-date-divider{margin:var(--space-md) 0;justify-content:center;align-items:center;display:flex}.chat-date-divider span{color:var(--color-text-tertiary);background:var(--color-bg-secondary);border-radius:100px;padding:2px 12px;font-size:.6875rem}.chat-bubble-wrapper{display:flex}.chat-bubble-wrapper.own{justify-content:flex-end}.chat-bubble-wrapper.other{justify-content:flex-start}.chat-bubble{max-width:75%;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-lg);animation:bubble-in var(--transition-base) forwards;position:relative}@keyframes bubble-in{0%{opacity:0;transform:scale(.95)translateY(4px)}to{opacity:1;transform:scale(1)translateY(0)}}.chat-bubble.own{background:var(--color-primary);color:#fff;border-bottom-right-radius:var(--radius-sm)}.chat-bubble.other{background:var(--color-bg-secondary);color:var(--color-text-primary);border-bottom-left-radius:var(--radius-sm)}.chat-bubble.pending{opacity:.7}.chat-bubble-text{word-break:break-word;font-size:.875rem;line-height:1.5}.chat-bubble-time{text-align:right;opacity:.7;margin-top:4px;font-size:.625rem;display:block}.chat-input-bar{align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border-light);background:var(--color-surface);display:flex}.chat-input{border-radius:100px;flex:1}@media (width<=768px){.chat-page{height:calc(100vh - var(--topbar-height) - var(--space-md) * 2);border-radius:var(--radius-lg)}.chat-messages,.chat-input-bar{padding:var(--space-sm) var(--space-md)}}.notifications-page{max-width:640px;margin:0 auto}.notif-list{gap:var(--space-sm);flex-direction:column;display:flex}.notif-item{align-items:flex-start;gap:var(--space-md);cursor:pointer;padding:var(--space-md) var(--space-lg);transition:all var(--transition-fast);display:flex}.notif-item:hover{border-color:var(--color-primary-muted)}.notif-item.unread{background:var(--color-primary-soft);border-color:var(--color-primary-muted)}.notif-dot{border-radius:var(--radius-full);flex-shrink:0;width:8px;height:8px;margin-top:6px}.notif-content{flex:1;min-width:0}.notif-top{justify-content:space-between;align-items:center;margin-bottom:2px;display:flex}.notif-type{text-transform:uppercase;letter-spacing:.04em;font-size:.6875rem;font-weight:700}.notif-title{margin-bottom:2px;font-size:.875rem;font-weight:600}.notif-body{line-height:1.4}.settings-page{max-width:640px;margin:0 auto}.settings-section{margin-bottom:var(--space-lg)}.settings-section-title{color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--space-lg);font-size:.875rem;font-weight:600}.settings-profile{align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);padding-bottom:var(--space-lg);border-bottom:1px solid var(--color-border-light);display:flex}.settings-avatar{border-radius:var(--radius-full);background:var(--color-primary-soft);width:56px;height:56px;color:var(--color-primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.settings-profile-info h3{font-size:1.125rem;font-weight:600}.settings-fields{gap:var(--space-md);flex-direction:column;display:flex}.settings-field{padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.settings-field:last-child{border-bottom:none;padding-bottom:0}.settings-field-label{color:var(--color-text-secondary);font-size:.8125rem}.settings-field-value{font-size:.875rem;font-weight:500}.theme-options{gap:var(--space-sm);display:flex}.theme-option{justify-content:center;align-items:center;gap:var(--space-xs);padding:var(--space-md);border-radius:var(--radius-lg);border:2px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base);flex:1;font-size:.875rem;font-weight:500;display:flex}.theme-option:hover{border-color:var(--color-primary-muted);color:var(--color-text-primary)}.theme-option.active{border-color:var(--color-primary);background:var(--color-primary-soft);color:var(--color-primary)}.info-page{gap:var(--space-lg);flex-direction:column;max-width:640px;margin:0 auto;display:flex}.info-hero{text-align:center;padding:var(--space-2xl) var(--space-xl);border-radius:var(--radius-xl);flex-direction:column;align-items:center;display:flex}.info-hero:hover{transform:none}.info-logo-wrapper{border-radius:var(--radius-xl);background:linear-gradient(135deg, var(--color-primary), #bc63e9);width:72px;height:72px;margin-bottom:var(--space-md);justify-content:center;align-items:center;display:flex}.info-logo{color:#fff;font-size:2rem;font-weight:800}.info-title{margin-bottom:var(--space-xs);font-size:1.5rem;font-weight:700}.info-section h4{color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--space-md);font-size:.875rem;font-weight:600}.info-features{gap:var(--space-sm);flex-direction:column;display:flex}.info-feature{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:var(--color-bg-secondary);font-size:.875rem;line-height:1.5;display:flex}.info-feature-badge{background:var(--color-primary);color:#fff;white-space:nowrap;border-radius:100px;flex-shrink:0;padding:2px 8px;font-size:.6875rem;font-weight:700}.info-feature-dot{border-radius:var(--radius-full);flex-shrink:0;width:8px;height:8px}.info-footer{padding:var(--space-lg) 0}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--font-primary:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:20px;--radius-full:50%;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.2s cubic-bezier(.4, 0, .2, 1);--transition-slow:.3s cubic-bezier(.4, 0, .2, 1);--transition-spring:.4s cubic-bezier(.34, 1.56, .64, 1);--z-base:1;--z-dropdown:100;--z-sticky:200;--z-overlay:300;--z-modal:400;--z-toast:500;--sidebar-width:260px;--topbar-height:64px}[data-theme=light],:root{--color-primary:#fd356e;--color-primary-hover:#fd0d51;--color-primary-soft:#ffe6ed;--color-primary-muted:#d49bab;--color-success:#2bab6f;--color-success-soft:#e7f9f0;--color-warning:#f59f0a;--color-warning-soft:#fef3e2;--color-danger:#e03e3e;--color-danger-soft:#fbe9e9;--color-info:#308ce8;--color-info-soft:#e3f0fc;--color-bg-primary:#f9f9fb;--color-bg-secondary:#f0f0f4;--color-bg-tertiary:#e9e9ed;--color-surface:#fff;--color-surface-hover:#f6f6f8;--color-surface-active:#ededf2;--color-border:#e3e3e8;--color-border-light:#eeeef1;--color-text-primary:#181825;--color-text-secondary:#5c5c70;--color-text-tertiary:#868698;--color-text-inverse:#fff;--color-text-link:var(--color-primary);--color-input-bg:#fff;--color-input-border:#d5d5dd;--color-input-focus:var(--color-primary);--glass-bg:#ffffffa6;--glass-border:#ffffff73;--glass-blur:blur(16px);--glass-shadow:0 4px 24px #0000000f, 0 1px 2px #0000000a;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 12px #00000014, 0 1px 3px #0000000a;--shadow-lg:0 8px 32px #0000001a, 0 2px 8px #0000000a;--shadow-xl:0 16px 48px #0000001f, 0 4px 12px #0000000f;--scrollbar-track:#eeeef1;--scrollbar-thumb:#c7c7d1}[data-theme=dark]{--color-primary:#fd497c;--color-primary-hover:#fe7299;--color-primary-soft:#401c26;--color-primary-muted:#955064;--color-success:#39c684;--color-success-soft:#153225;--color-warning:#eea62b;--color-warning-soft:#362812;--color-danger:#dd5f5f;--color-danger-soft:#391818;--color-info:#4d99e6;--color-info-soft:#182939;--color-bg-primary:#111117;--color-bg-secondary:#19191f;--color-bg-tertiary:#202027;--color-surface:#1d1d25;--color-surface-hover:#24242e;--color-surface-active:#2b2b36;--color-border:#2e2e38;--color-border-light:#25252d;--color-text-primary:#eaeaf0;--color-text-secondary:#9696a6;--color-text-tertiary:#6e6e7c;--color-text-inverse:#181825;--color-text-link:var(--color-primary);--color-input-bg:#1f1f28;--color-input-border:#32323e;--color-input-focus:var(--color-primary);--glass-bg:#14141ea6;--glass-border:#ffffff14;--glass-blur:blur(16px);--glass-shadow:0 4px 24px #00000040, 0 1px 2px #00000026;--shadow-xs:0 1px 2px #00000026;--shadow-sm:0 1px 3px #0003, 0 1px 2px #0000001f;--shadow-md:0 4px 12px #0000004d, 0 1px 3px #00000026;--shadow-lg:0 8px 32px #00000059, 0 2px 8px #0003;--shadow-xl:0 16px 48px #0006, 0 4px 12px #0003;--scrollbar-track:#1c1c22;--scrollbar-thumb:#393946}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}body{font-family:var(--font-primary);color:var(--color-text-primary);background-color:var(--color-bg-primary);transition:background-color var(--transition-slow), color var(--transition-slow);font-weight:400;line-height:1.6;overflow-x:hidden}a{color:var(--color-text-link);transition:color var(--transition-fast);text-decoration:none}a:hover{opacity:.85}img{max-width:100%;display:block}button{cursor:pointer;background:0 0;border:none;outline:none;font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--scrollbar-track)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}h1{letter-spacing:-.02em;font-size:1.875rem;font-weight:700;line-height:1.2}h2{letter-spacing:-.015em;font-size:1.5rem;font-weight:600;line-height:1.3}h3{font-size:1.25rem;font-weight:600;line-height:1.4}h4{font-size:1.125rem;font-weight:500;line-height:1.4}h5{font-size:1rem;font-weight:500;line-height:1.5}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-lg{font-size:1.125rem}.text-muted{color:var(--color-text-secondary)}.text-faint{color:var(--color-text-tertiary)}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:var(--glass-shadow);transition:transform var(--transition-base), box-shadow var(--transition-base)}.glass-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}.card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-lg);transition:transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base)}.card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border)}.btn{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);transition:all var(--transition-base);-webkit-user-select:none;user-select:none;padding:10px 20px;font-size:.875rem;font-weight:500;line-height:1.4;display:inline-flex;position:relative;overflow:hidden}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--color-primary);color:var(--color-text-inverse);box-shadow:0 2px 8px #fd356e4d}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:0 4px 16px #fd356e66}.btn-secondary{background:var(--color-bg-secondary);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-bg-tertiary);border-color:var(--color-primary-muted)}.btn-ghost{color:var(--color-text-secondary);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--color-bg-secondary);color:var(--color-text-primary)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){filter:brightness(1.1)}.btn-sm{padding:6px 12px;font-size:.8125rem}.btn-lg{border-radius:var(--radius-lg);padding:14px 28px;font-size:1rem}.btn-icon{border-radius:var(--radius-full);width:40px;height:40px;padding:0}.input-group{flex-direction:column;gap:6px;display:flex}.input-group label{color:var(--color-text-secondary);font-size:.8125rem;font-weight:500}.input{width:100%;color:var(--color-text-primary);background:var(--color-input-bg);border:1.5px solid var(--color-input-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:10px 14px;font-size:.9375rem}.input::placeholder{color:var(--color-text-tertiary)}.input:focus{border-color:var(--color-input-focus);box-shadow:0 0 0 3px #fd356e26}.input.error{border-color:var(--color-danger);box-shadow:0 0 0 3px #e03e3e1a}.input-error-text{color:var(--color-danger);margin-top:2px;font-size:.75rem}.password-wrapper{align-items:center;display:flex;position:relative}.password-toggle-btn{cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex;position:absolute;right:12px}.password-toggle-btn:hover{color:var(--color-text-primary)}.checkbox-wrapper{align-items:center;gap:var(--space-sm);cursor:pointer;-webkit-user-select:none;user-select:none;display:flex}.checkbox-wrapper input[type=checkbox]{width:20px;height:20px;accent-color:var(--color-primary);border-radius:var(--radius-sm);cursor:pointer}.badge{text-transform:uppercase;letter-spacing:.04em;border-radius:100px;align-items:center;padding:3px 10px;font-size:.6875rem;font-weight:600;display:inline-flex}.badge-pending{background:var(--color-warning-soft);color:var(--color-warning)}.badge-confirmed,.badge-completed{background:var(--color-success-soft);color:var(--color-success)}.badge-rejected{background:var(--color-danger-soft);color:var(--color-danger)}.badge-in_progress{background:var(--color-info-soft);color:var(--color-info)}.badge-review{background:var(--color-primary-soft);color:var(--color-primary)}.progress-bar{background:var(--color-bg-tertiary);border-radius:100px;width:100%;height:8px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--color-primary), #bc63e9);height:100%;transition:width var(--transition-slow);border-radius:100px;min-width:0}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg, var(--color-bg-secondary) 25%, var(--color-bg-tertiary) 50%, var(--color-bg-secondary) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}.skeleton-text{border-radius:4px;height:14px;margin-bottom:8px}.skeleton-text:last-child{width:60%}.skeleton-title{width:50%;height:22px;margin-bottom:12px}.skeleton-avatar{border-radius:var(--radius-full);width:44px;height:44px}.skeleton-card{border-radius:var(--radius-lg);height:120px}.skeleton-btn{border-radius:var(--radius-md);width:120px;height:40px}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:2.5px solid var(--color-border);border-top-color:var(--color-primary);border-radius:var(--radius-full);width:20px;height:20px;animation:.7s linear infinite spin}.spinner-lg{border-width:3px;width:36px;height:36px}.spinner-sm{border-width:2px;width:14px;height:14px}.toast-container{top:var(--space-lg);right:var(--space-lg);z-index:var(--z-toast);gap:var(--space-sm);pointer-events:none;flex-direction:column;display:flex;position:fixed}@keyframes toast-in{0%{opacity:0;transform:translate(100%)scale(.95)}to{opacity:1;transform:translate(0)scale(1)}}@keyframes toast-out{0%{opacity:1;transform:translate(0)scale(1)}to{opacity:0;transform:translate(100%)scale(.95)}}.toast{pointer-events:auto;align-items:flex-start;gap:var(--space-sm);padding:var(--space-md);border-radius:var(--radius-lg);background:var(--color-surface);border:1px solid var(--color-border);min-width:320px;max-width:420px;box-shadow:var(--shadow-lg);animation:toast-in var(--transition-spring) forwards;display:flex}.toast.exiting{animation:toast-out var(--transition-base) forwards}.toast-success{border-left:3px solid var(--color-success)}.toast-error{border-left:3px solid var(--color-danger)}.toast-info{border-left:3px solid var(--color-info)}.empty-state{text-align:center;padding:var(--space-3xl) var(--space-xl);justify-content:center;align-items:center;gap:var(--space-md);flex-direction:column;display:flex}.empty-state-icon{background:var(--color-primary-soft);border-radius:var(--radius-full);width:100px;height:100px;color:var(--color-primary);margin-bottom:var(--space-sm);justify-content:center;align-items:center;font-size:2.5rem;display:flex}.empty-state h3{color:var(--color-text-primary)}.empty-state p{color:var(--color-text-secondary);max-width:360px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-overlay);padding:var(--space-lg);animation:fade-in var(--transition-base) forwards;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:480px;max-height:90vh;animation:modal-in var(--transition-spring) forwards;overflow-y:auto}@keyframes modal-in{0%{opacity:0;transform:scale(.95)translateY(12px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{padding:var(--space-lg);border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.modal-body{padding:var(--space-lg)}.modal-footer{justify-content:flex-end;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border-light);display:flex}.hide-mobile{display:block}.show-mobile{display:none}@media (width<=768px){.hide-mobile{display:none!important}.show-mobile{display:block!important}h1{font-size:1.5rem}h2{font-size:1.25rem}.card{padding:var(--space-md)}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.gap-xl{gap:var(--space-xl)}.w-full{width:100%}.text-center{text-align:center}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}
