@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";.back-to-top{position:fixed;bottom:24px;left:24px;z-index:999;width:48px;height:48px;border-radius:50%;border:none;background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;box-shadow:0 4px 14px #3b82f666;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s}.back-to-top:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f680}.back-to-top:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.offline-banner{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 16px;background:#fef3c7;color:#92400e;font-size:.9375rem;font-weight:500;border-bottom:1px solid #fcd34d}.offline-banner-icon{flex-shrink:0;color:#d97706}.app-layout{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary)}.skip-link{position:absolute;top:0;left:0;transform:translateY(-120%);padding:12px 16px;background:#fff;color:var(--text-primary);border:1px solid var(--border-color);border-radius:0 0 8px;z-index:100;text-decoration:none;transition:transform .2s ease}.skip-link:focus{transform:translateY(0);outline:2px solid var(--primary);outline-offset:2px}.app-header{position:sticky;top:0;z-index:100;background:#fffffff2;border-bottom:1px solid var(--border-color);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);transition:all .3s cubic-bezier(.4,0,.2,1)}.app-header.scrolled{box-shadow:0 4px 20px #00000014;background:#fffffffa}.app-header-container{max-width:var(--max-width-xl);margin:0 auto;padding:12px 24px;display:flex;align-items:center;justify-content:space-between;gap:32px}.app-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text-primary);font-weight:700;flex-shrink:0}.app-logo-mark{width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,#2563eb,#7c3aed);box-shadow:0 6px 20px #2563eb59;display:flex;align-items:center;justify-content:center;color:#fff;position:relative;overflow:hidden}.app-logo-mark:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.2) 50%,transparent 60%)}.app-logo-text{font-size:1.25rem;font-weight:700;letter-spacing:-.02em}.app-logo-ai{background:linear-gradient(135deg,var(--primary) 0%,#5a8bff 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-nav-desktop{display:flex;align-items:center;gap:8px;flex:1;justify-content:space-between}.app-nav-links{display:flex;align-items:center;gap:4px}.app-nav-actions{display:flex;align-items:center;gap:12px}.app-nav-link{color:var(--text-secondary);text-decoration:none;font-weight:500;font-size:.9rem;position:relative;padding:8px 14px;border-radius:8px;transition:all .2s ease;white-space:nowrap}.app-nav-link:hover{color:var(--primary);background:#1f6feb0f}.app-nav-link.active{color:var(--primary);font-weight:600;background:#1f6feb14;position:relative}.app-nav-link.active:after{content:"";position:absolute;bottom:-4px;left:50%;transform:translate(-50%);width:20px;height:3px;background:linear-gradient(90deg,#3b82f6,#7c3aed);border-radius:2px}.app-nav-icon-btn{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;color:var(--text-secondary);background:transparent;border:1px solid transparent;transition:all .2s ease}.app-nav-icon-btn:hover{color:var(--primary);background:#1f6feb0f;border-color:#1f6feb1a}.app-nav-user-dropdown{position:relative}.app-nav-user-trigger{display:flex;align-items:center;gap:8px;padding:6px 12px 6px 6px;border-radius:999px;background:#1f6feb0f;border:1px solid rgba(31,111,235,.1);cursor:pointer;transition:all .2s ease;font-family:inherit}.app-nav-user-trigger:hover{background:#1f6feb1a;border-color:#1f6feb33}.app-nav-user-trigger svg{transition:transform .2s ease;color:var(--text-muted)}.app-nav-user-trigger svg.rotated{transform:rotate(180deg)}.app-nav-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--primary) 0%,#5a8bff 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.85rem}.app-nav-avatar-lg{width:40px;height:40px;font-size:1rem}.app-nav-user-name{font-weight:500;font-size:.9rem;color:var(--text-primary);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-nav-dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:240px;background:#fff;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 40px #0000001f;padding:8px;animation:dropdownFadeIn .2s ease;z-index:200}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.app-nav-dropdown-header{display:flex;align-items:center;gap:12px;padding:12px}.app-nav-dropdown-name{font-weight:600;font-size:.95rem;color:var(--text-primary)}.app-nav-dropdown-email{font-size:.8rem;color:var(--text-muted);max-width:160px;overflow:hidden;text-overflow:ellipsis}.app-nav-dropdown-divider{height:1px;background:var(--border-color);margin:4px 0}.app-nav-dropdown-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;color:var(--text-secondary);font-size:.9rem;font-weight:500;text-decoration:none;transition:all .15s ease;width:100%;border:none;background:transparent;cursor:pointer;font-family:inherit;text-align:left}.app-nav-dropdown-item:hover{background:#1f6feb0f;color:var(--primary)}.app-nav-dropdown-logout{color:var(--danger)}.app-nav-dropdown-logout:hover{background:#ff3b3014;color:var(--danger)}.app-nav-cta-secondary{display:inline-flex;align-items:center;padding:10px 18px;border-radius:10px;font-weight:600;font-size:.9rem;color:#6366f1;background:linear-gradient(135deg,#6366f114,#a855f714);border:1px solid rgba(99,102,241,.15);text-decoration:none;transition:all .2s ease}.app-nav-cta-secondary:hover{background:linear-gradient(135deg,#6366f126,#a855f726);border-color:#6366f14d;transform:translateY(-1px)}.app-nav-cta{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border-radius:12px;font-weight:600;font-size:.9rem;color:#fff;background:linear-gradient(135deg,#2563eb,#7c3aed);text-decoration:none;position:relative;overflow:hidden;box-shadow:0 4px 14px #1f6feb59;transition:all .2s ease;white-space:nowrap}.app-nav-cta:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.app-nav-cta:hover{transform:translateY(-2px);box-shadow:0 10px 25px #2563eb73;color:#fff}.app-nav-cta:hover:before{left:100%}.app-nav-cta svg{flex-shrink:0;position:relative;z-index:1}.app-nav-mobile-toggle{display:none;align-items:center;justify-content:center;width:44px;height:44px;border-radius:10px;background:transparent;border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;transition:all .2s ease}.app-nav-mobile-toggle:hover{background:#1f6feb0f;border-color:#1f6feb33}.app-nav-mobile{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid var(--border-color);box-shadow:0 10px 40px #0000001a;padding:16px 24px 24px;transform:translateY(-10px);opacity:0;visibility:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.app-nav-mobile.open{transform:translateY(0);opacity:1;visibility:visible}.app-nav-mobile-links{display:flex;flex-direction:column;gap:4px}.app-nav-mobile-link{display:block;padding:12px 16px;border-radius:10px;color:var(--text-secondary);font-weight:500;font-size:1rem;text-decoration:none;transition:all .2s ease;border:none;background:transparent;cursor:pointer;font-family:inherit;text-align:left;width:100%}.app-nav-mobile-link:hover,.app-nav-mobile-link.active{background:#1f6feb14;color:var(--primary)}.app-nav-mobile-divider{height:1px;background:var(--border-color);margin:12px 0}.app-nav-mobile-user{display:flex;flex-direction:column;gap:8px}.app-nav-mobile-user-info{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#1f6feb0a;border-radius:12px;margin-bottom:8px}.app-nav-mobile-user-name{font-weight:600;color:var(--text-primary)}.app-nav-mobile-user-email{font-size:.85rem;color:var(--text-muted)}.app-nav-mobile-logout{color:var(--danger)}.app-nav-mobile-auth{display:flex;flex-direction:column;gap:10px}.app-nav-mobile-btn-secondary{display:block;padding:14px 20px;border-radius:10px;text-align:center;font-weight:600;color:var(--primary);background:#1f6feb14;text-decoration:none;transition:all .2s ease}.app-nav-mobile-btn-primary{display:block;padding:14px 20px;border-radius:10px;text-align:center;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--primary) 0%,#5a8bff 100%);text-decoration:none;box-shadow:0 4px 14px #1f6feb4d}.app-nav-mobile-cta{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:16px;padding:16px 24px;border-radius:12px;font-weight:600;font-size:1rem;color:#fff;background:linear-gradient(135deg,var(--primary) 0%,#5a8bff 100%);text-decoration:none;box-shadow:0 4px 14px #1f6feb59}@media (max-width: 1024px){.app-nav-desktop{display:none}.app-nav-mobile-toggle{display:flex}.app-nav-mobile{display:block}}@media (max-width: 480px){.app-header-container{padding:10px 16px}.app-logo-text{font-size:1.1rem}.app-nav-mobile{padding:12px 16px 20px}}.app-main{flex:1;background:var(--bg-secondary);padding:24px 0 48px}.app-main .page-container>section{padding:48px 0}.app-breadcrumbs{background:#fff;border-bottom:1px solid var(--border-color)}.app-breadcrumbs-container{max-width:var(--max-width-xl);margin:0 auto;padding:10px 24px;display:flex;flex-wrap:wrap;gap:6px;align-items:center;color:var(--text-secondary);font-size:.9rem}.app-breadcrumb-item a{color:var(--text-secondary);text-decoration:none}.app-breadcrumb-item a:hover{color:var(--primary)}.app-breadcrumb-current{color:var(--text-primary);font-weight:600}.app-breadcrumb-separator{margin:0 6px;color:var(--text-tertiary)}.app-footer{background:linear-gradient(180deg,var(--bg-secondary) 0%,#ffffff 100%)}.app-footer-newsletter{background:linear-gradient(135deg,var(--primary) 0%,#5a8bff 100%);padding:48px 24px}.app-footer-newsletter-content{max-width:var(--max-width-xl);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap}.app-footer-newsletter-text h3{color:#fff;font-size:1.5rem;font-weight:700;margin-bottom:8px}.app-footer-newsletter-text p{color:#ffffffd9;font-size:1rem;margin:0}.app-footer-newsletter-form{display:flex;gap:12px;flex:1;max-width:460px}.app-footer-newsletter-form input{flex:1;padding:14px 20px;border:none;border-radius:10px;font-size:.95rem;background:#fffffff2;color:var(--text-primary);min-width:200px}.app-footer-newsletter-form input::placeholder{color:var(--text-muted)}.app-footer-newsletter-form input:focus{outline:none;box-shadow:0 0 0 3px #ffffff4d}.app-footer-newsletter-form button{padding:14px 28px;border:none;border-radius:10px;font-size:.95rem;font-weight:600;background:var(--gray-900);color:#fff;cursor:pointer;transition:all .2s ease;white-space:nowrap}.app-footer-newsletter-form button:hover{background:var(--gray-800);transform:translateY(-1px)}.app-footer-main{padding:64px 24px 48px;background:#fff}.app-footer-container{max-width:var(--max-width-xl);margin:0 auto;display:grid;grid-template-columns:1.3fr 2fr;gap:64px}.app-footer-brand{max-width:320px}.app-footer-logo{display:inline-flex;align-items:center;gap:10px;text-decoration:none;margin-bottom:20px}.app-footer-logo-mark{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--primary) 0%,#5a8bff 100%);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px #1f6feb40}.app-footer-logo-text{font-size:1.25rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.app-footer-tagline{color:var(--text-secondary);font-size:.95rem;line-height:1.6;margin:0 0 24px}.app-footer-socials{display:flex;gap:10px}.app-footer-socials a{width:40px;height:40px;border-radius:10px;border:1px solid var(--border-color);display:inline-flex;align-items:center;justify-content:center;color:var(--text-secondary);background:#fff;transition:all .2s ease}.app-footer-socials a:hover{color:var(--primary);background:#1f6feb0f;border-color:#1f6feb4d;transform:translateY(-2px)}.app-footer-links{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}.app-footer-column h4{font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:20px}.app-footer-column a{display:block;color:var(--text-secondary);font-size:.9rem;font-weight:500;padding:6px 0;text-decoration:none;transition:all .15s ease}.app-footer-column a:hover{color:var(--primary);padding-left:4px}.app-footer-bottom{background:var(--gray-50);border-top:1px solid var(--border-color);padding:20px 24px}.app-footer-bottom-container{max-width:var(--max-width-xl);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}.api-status{margin-left:.5rem;font-size:.75rem;color:var(--text-muted);display:inline-flex;align-items:center;gap:.35rem}.api-status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.api-status-dot--up{background:var(--success, #22c55e)}.api-status-dot--down{background:var(--text-muted, #94a3b8)}.app-footer-copyright{color:var(--text-muted);font-size:.85rem;margin:0}.app-footer-version{opacity:.8;font-size:.8rem;margin-left:.25em}.app-footer-whats-new{color:var(--primary);text-decoration:none;font-size:.85rem}.app-footer-whats-new:hover{text-decoration:underline}.app-footer-disclaimer{display:flex;align-items:center;gap:6px;color:var(--text-muted);font-size:.85rem;margin:0;background:#1f6feb0f;padding:6px 12px;border-radius:6px}.app-footer-disclaimer-icon{font-size:.9rem}@media (max-width: 1024px){.app-footer-container{grid-template-columns:1fr;gap:48px}.app-footer-brand{max-width:100%;text-align:center}.app-footer-logo,.app-footer-socials{justify-content:center}.app-footer-links{grid-template-columns:repeat(4,1fr)}}@media (max-width: 768px){.app-footer-newsletter{padding:40px 20px}.app-footer-newsletter-content{flex-direction:column;text-align:center}.app-footer-newsletter-text h3{font-size:1.25rem}.app-footer-newsletter-form{width:100%;max-width:100%;flex-direction:column}.app-footer-newsletter-form input{min-width:100%}.app-footer-main{padding:48px 20px 40px}.app-footer-links{grid-template-columns:repeat(2,1fr);gap:32px 24px}.app-footer-bottom-container{flex-direction:column;text-align:center;gap:12px}}@media (max-width: 480px){.app-footer-newsletter{padding:32px 16px}.app-footer-main{padding:40px 16px 32px}.app-footer-links{grid-template-columns:1fr 1fr;gap:28px 20px}.app-footer-column h4{font-size:.75rem;margin-bottom:14px}.app-footer-column a{font-size:.85rem;padding:5px 0}.app-footer-bottom{padding:16px}.app-footer-disclaimer{font-size:.8rem;padding:5px 10px}}.app-layout .page-container,.app-layout .dashboard-page,.app-layout .profile-settings-page,.app-layout .routine-builder-page,.app-layout .myshelf-page,.app-layout .product-details-page,.app-layout .history-page,.app-layout .consent-page,.app-layout .onboarding-page,.app-layout .auth-page,.app-layout .contact-page,.app-layout .about-page,.app-layout .privacy-page,.app-layout .terms-page,.app-layout .sample-report-page,.app-layout .onskin-page{background:transparent;color:var(--text-primary)}.app-layout .page-container{max-width:var(--max-width-xl);margin:0 auto;padding:24px}.app-layout .page-header{margin-bottom:24px}.app-layout .page-header h1,.app-layout .page-header h2{color:var(--text-primary);letter-spacing:-.01em}.app-layout .page-header p,.app-layout .subtitle{color:var(--text-secondary)}.app-layout .page-header .page-subtitle{margin-top:6px;color:var(--text-secondary)}.app-layout .card,.app-layout .card-content{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.app-layout .card{padding:20px}.app-layout .card-header{border-bottom:1px solid var(--border-color);padding-bottom:12px;margin-bottom:16px;color:var(--text-primary)}.app-layout .btn,.app-layout .btn-primary,.app-layout .btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 22px;border-radius:999px;font-weight:600;text-decoration:none;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.app-layout .btn-primary{background:linear-gradient(135deg,var(--primary) 0%,#5a8bff 100%);color:#fff;box-shadow:var(--shadow-lg)}.app-layout .btn-secondary{background:#fff;color:var(--primary);border:1px solid rgba(31,111,235,.2);box-shadow:var(--shadow-sm)}.app-layout .btn-primary:hover,.app-layout .btn-secondary:hover{transform:translateY(-2px)}.app-layout .btn-icon{display:inline-flex;align-items:center;justify-content:center}.app-layout .empty-state{background:#fff;border:1px solid var(--border-color);border-radius:16px;padding:32px;text-align:center;box-shadow:var(--shadow-sm)}.app-layout .empty-state h2{margin-bottom:8px}.app-layout .empty-state p{max-width:480px;margin:0 auto}.app-layout .empty-state-actions{margin-top:20px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.dev-banner{position:fixed;bottom:20px;right:20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:12px 20px;border-radius:50px;box-shadow:0 4px 12px #667eea66;display:flex;align-items:center;gap:12px;font-size:.875rem;font-weight:500;z-index:9999;animation:slideInUp .4s ease-out}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.dev-badge{background:#ffffff40;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:700;letter-spacing:.5px}.dev-text{display:flex;align-items:center;gap:4px}.dev-text strong{font-weight:700}.dev-pulse{width:8px;height:8px;background:#4ade80;border-radius:50%;animation:pulse 2s ease-in-out infinite;box-shadow:0 0 #4ade80b3}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 0 #4ade80b3}50%{transform:scale(1.1);box-shadow:0 0 0 6px #4ade8000}}@media (max-width: 768px){.dev-banner{bottom:80px;right:16px;left:16px;font-size:.8rem;padding:10px 16px}.dev-text strong{display:block}}.loading-screen{display:flex;align-items:center;justify-content:center;background:var(--bg-secondary, #f3f7ff);z-index:9999}.loading-screen.fullscreen{position:fixed;top:0;left:0;right:0;bottom:0}.loading-screen.inline{position:relative;min-height:400px;width:100%;border-radius:12px}.loading-content{text-align:center;display:flex;flex-direction:column;align-items:center;gap:24px;animation:fadeInUp .4s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.loading-spinner-container{position:relative;width:56px;height:56px}.loading-spinner-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:3px solid var(--gray-200, #e3ecff);border-top-color:var(--primary, #1f6feb);animation:spin .8s linear infinite}.loading-spinner-ring:nth-child(2),.loading-spinner-ring:nth-child(3){display:none}.loading-logo{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--primary, #1f6feb) 0%,#5a8bff 100%);display:flex;align-items:center;justify-content:center;color:#fff;animation:logoPulse 1.5s ease-in-out infinite;box-shadow:0 4px 20px #1f6feb4d}@keyframes logoPulse{0%,to{transform:scale(1);box-shadow:0 4px 20px #1f6feb4d}50%{transform:scale(1.05);box-shadow:0 6px 28px #1f6feb66}}.loading-message{font-size:.95rem;font-weight:500;color:var(--text-secondary, #4b5b76);margin:0;letter-spacing:.01em}.loading-message:after{content:"";animation:loadingDots 1.5s infinite}@keyframes loadingDots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}to{content:""}}@media (max-width: 768px){.loading-screen.inline{min-height:300px}.loading-spinner-container{width:48px;height:48px}.loading-spinner-ring{border-width:2.5px}.loading-message{font-size:.9rem}}.toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:12px;max-width:360px;pointer-events:none}.toast-container>*{pointer-events:auto}.toast{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:12px;box-shadow:0 8px 24px #0000001f;border:1px solid rgba(255,255,255,.8);background:#fff;font-size:.9rem;animation:toastIn .25s ease-out}@keyframes toastIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.toast--success .toast-icon{color:#16a34a}.toast--error .toast-icon{color:#dc2626}.toast--info .toast-icon{color:#2563eb}.toast-message{flex:1;color:#1e293b}.toast-dismiss{display:flex;align-items:center;justify-content:center;padding:4px;border:none;background:transparent;color:#64748b;cursor:pointer;border-radius:6px}.toast-dismiss:hover{color:#1e293b;background:#f1f5f9}.error-boundary-page{min-height:60vh;display:flex;align-items:center;justify-content:center;padding:48px 24px;background:linear-gradient(180deg,#fef2f2,#faf5f5)}.error-boundary-icon{color:var(--danger, #ef4444);margin-bottom:16px;display:flex;justify-content:center}.error-boundary-content{text-align:center;max-width:420px}.error-boundary-title{font-size:1.75rem;font-weight:700;color:#1e293b;margin:0 0 12px}.error-boundary-message{font-size:1rem;color:#64748b;line-height:1.6;margin:0 0 32px}.error-boundary-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.error-boundary-actions .btn-primary,.error-boundary-actions .btn-secondary{display:inline-flex;align-items:center}:root{--ds-primary: #1f6feb;--ds-primary-hover: #1e4fd6;--ds-primary-light: #e6efff;--ds-primary-dark: #1a5bc7;--ds-secondary: #1f6feb;--ds-secondary-hover: #1e4fd6;--ds-secondary-light: #e6efff;--ds-accent: #a9c7ff;--ds-accent-hover: #8ab4ff;--ds-accent-light: #f1f5ff;--ds-success: #10b981;--ds-success-light: #d1fae5;--ds-success-dark: #059669;--ds-warning: #f59e0b;--ds-warning-light: #fef3c7;--ds-warning-dark: #d97706;--ds-error: #ef4444;--ds-error-light: #fee2e2;--ds-error-dark: #dc2626;--ds-info: #3b82f6;--ds-info-light: #dbeafe;--ds-white: #ffffff;--ds-gray-50: #f8fafc;--ds-gray-100: #f1f5f9;--ds-gray-200: #e2e8f0;--ds-gray-300: #cbd5e1;--ds-gray-400: #94a3b8;--ds-gray-500: #64748b;--ds-gray-600: #475569;--ds-gray-700: #334155;--ds-gray-800: #1e293b;--ds-gray-900: #0f172a;--ds-gradient-primary: linear-gradient(135deg, #1f6feb 0%, #5a8bff 100%);--ds-gradient-secondary: linear-gradient(135deg, #1f6feb 0%, #4a7eff 100%);--ds-gradient-success: linear-gradient(135deg, #34c759 0%, #28a745 100%);--ds-gradient-surface: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);--ds-gradient-page: linear-gradient(180deg, #ffffff 0%, #f3f7ff 100%);--ds-shadow-xs: 0 1px 2px rgba(31, 111, 235, .04);--ds-shadow-sm: 0 2px 4px rgba(31, 111, 235, .06);--ds-shadow-md: 0 4px 12px rgba(31, 111, 235, .08);--ds-shadow-lg: 0 12px 24px rgba(31, 111, 235, .12);--ds-shadow-xl: 0 20px 40px rgba(31, 111, 235, .15);--ds-shadow-2xl: 0 32px 64px rgba(31, 111, 235, .18);--ds-shadow-primary: 0 8px 24px rgba(31, 111, 235, .25);--ds-shadow-glow: 0 0 40px rgba(31, 111, 235, .15);--ds-radius-xs: 4px;--ds-radius-sm: 6px;--ds-radius-md: 8px;--ds-radius-lg: 12px;--ds-radius-xl: 16px;--ds-radius-2xl: 24px;--ds-radius-3xl: 32px;--ds-radius-full: 9999px;--ds-space-1: 4px;--ds-space-2: 8px;--ds-space-3: 12px;--ds-space-4: 16px;--ds-space-5: 20px;--ds-space-6: 24px;--ds-space-8: 32px;--ds-space-10: 40px;--ds-space-12: 48px;--ds-space-16: 64px;--ds-space-20: 80px;--ds-font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--ds-text-xs: .75rem;--ds-text-sm: .875rem;--ds-text-base: 1rem;--ds-text-lg: 1.125rem;--ds-text-xl: 1.25rem;--ds-text-2xl: 1.5rem;--ds-text-3xl: 2rem;--ds-text-4xl: 2.5rem;--ds-text-5xl: 3rem;--ds-transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--ds-transition-base: .2s cubic-bezier(.4, 0, .2, 1);--ds-transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--ds-transition-spring: .4s cubic-bezier(.34, 1.56, .64, 1);--ds-z-dropdown: 100;--ds-z-sticky: 200;--ds-z-modal: 300;--ds-z-toast: 400;--ds-z-tooltip: 500}.ds-page{min-height:100vh;background:var(--ds-gradient-page);padding:var(--ds-space-12) var(--ds-space-6)}.ds-page--centered{display:flex;align-items:center;justify-content:center}.ds-container{max-width:1280px;margin:0 auto;width:100%}.ds-container--sm{max-width:640px}.ds-container--md{max-width:768px}.ds-container--lg{max-width:1024px}.ds-container--xl{max-width:1280px}.ds-page-header{text-align:center;margin-bottom:var(--ds-space-12)}.ds-page-header__title{font-size:var(--ds-text-4xl);font-weight:800;color:var(--ds-gray-900);margin-bottom:var(--ds-space-4);letter-spacing:-.02em}.ds-page-header__subtitle{font-size:var(--ds-text-lg);color:var(--ds-gray-500);max-width:600px;margin:0 auto;line-height:1.6}.ds-card{background:var(--ds-white);border-radius:var(--ds-radius-2xl);padding:var(--ds-space-8);box-shadow:var(--ds-shadow-lg);border:1px solid var(--ds-gray-100);transition:all var(--ds-transition-base)}.ds-card:hover{box-shadow:var(--ds-shadow-xl);transform:translateY(-2px)}.ds-card--flat{box-shadow:none;border:1px solid var(--ds-gray-200)}.ds-card--elevated{box-shadow:var(--ds-shadow-2xl),var(--ds-shadow-glow)}.ds-card--interactive{cursor:pointer}.ds-card--interactive:hover{transform:translateY(-4px);box-shadow:var(--ds-shadow-xl)}.ds-card__header{margin-bottom:var(--ds-space-6);padding-bottom:var(--ds-space-6);border-bottom:1px solid var(--ds-gray-100)}.ds-card__title{font-size:var(--ds-text-xl);font-weight:700;color:var(--ds-gray-900);margin-bottom:var(--ds-space-2)}.ds-card__description{font-size:var(--ds-text-sm);color:var(--ds-gray-500)}.ds-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--ds-space-2);font-family:var(--ds-font-sans);font-weight:600;border:none;border-radius:var(--ds-radius-lg);cursor:pointer;transition:all var(--ds-transition-spring);white-space:nowrap;text-decoration:none}.ds-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.ds-btn--sm{padding:var(--ds-space-2) var(--ds-space-4);font-size:var(--ds-text-sm);min-height:36px}.ds-btn--md{padding:var(--ds-space-3) var(--ds-space-6);font-size:var(--ds-text-base);min-height:44px}.ds-btn--lg{padding:var(--ds-space-4) var(--ds-space-8);font-size:var(--ds-text-lg);min-height:52px}.ds-btn--xl{padding:var(--ds-space-5) var(--ds-space-10);font-size:var(--ds-text-lg);min-height:60px;border-radius:var(--ds-radius-xl)}.ds-btn--primary{background:var(--ds-gradient-primary);color:var(--ds-white);box-shadow:var(--ds-shadow-primary)}.ds-btn--primary:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 32px #2563eb59}.ds-btn--secondary{background:var(--ds-white);color:var(--ds-gray-700);border:2px solid var(--ds-gray-200);box-shadow:var(--ds-shadow-sm)}.ds-btn--secondary:hover:not(:disabled){border-color:var(--ds-primary);color:var(--ds-primary);background:var(--ds-primary-light)}.ds-btn--ghost{background:transparent;color:var(--ds-gray-600)}.ds-btn--ghost:hover:not(:disabled){background:var(--ds-gray-100);color:var(--ds-gray-900)}.ds-btn--success{background:var(--ds-gradient-success);color:var(--ds-white);box-shadow:0 8px 24px #10b98140}.ds-btn--danger{background:var(--ds-error);color:var(--ds-white);box-shadow:0 8px 24px #ef444440}.ds-btn--full{width:100%}.ds-form-group{margin-bottom:var(--ds-space-6)}.ds-label{display:block;font-size:var(--ds-text-sm);font-weight:600;color:var(--ds-gray-700);margin-bottom:var(--ds-space-2)}.ds-input{width:100%;padding:var(--ds-space-4) var(--ds-space-5);font-size:var(--ds-text-base);font-family:var(--ds-font-sans);color:var(--ds-gray-900);background:var(--ds-gray-50);border:2px solid var(--ds-gray-200);border-radius:var(--ds-radius-lg);transition:all var(--ds-transition-base)}.ds-input:hover{border-color:var(--ds-gray-300)}.ds-input:focus{outline:none;border-color:var(--ds-primary);background:var(--ds-white);box-shadow:0 0 0 4px #2563eb1a}.ds-input::placeholder{color:var(--ds-gray-400)}.ds-input--error{border-color:var(--ds-error)}.ds-input--error:focus{box-shadow:0 0 0 4px #ef44441a}.ds-textarea{min-height:120px;resize:vertical}.ds-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;background-size:20px;padding-right:48px}.ds-checkbox,.ds-radio{display:flex;align-items:center;gap:var(--ds-space-3);cursor:pointer;padding:var(--ds-space-3);border-radius:var(--ds-radius-md);transition:background var(--ds-transition-fast)}.ds-checkbox:hover,.ds-radio:hover{background:var(--ds-gray-50)}.ds-checkbox input,.ds-radio input{width:20px;height:20px;accent-color:var(--ds-primary);cursor:pointer}.ds-chip-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--ds-space-3)}.ds-chip{display:flex;align-items:center;justify-content:center;padding:var(--ds-space-4) var(--ds-space-5);background:var(--ds-white);border:2px solid var(--ds-gray-200);border-radius:var(--ds-radius-xl);font-size:var(--ds-text-sm);font-weight:600;color:var(--ds-gray-600);cursor:pointer;transition:all var(--ds-transition-spring);text-align:center;min-height:52px}.ds-chip:hover{border-color:var(--ds-primary);color:var(--ds-primary);transform:translateY(-2px);box-shadow:var(--ds-shadow-md)}.ds-chip--selected{background:var(--ds-gradient-primary);border-color:transparent;color:var(--ds-white);box-shadow:var(--ds-shadow-primary);transform:translateY(-2px)}.ds-chip--selected:hover{color:var(--ds-white)}.ds-steps{display:flex;justify-content:center;align-items:center;gap:0;margin-bottom:var(--ds-space-12)}.ds-step{width:44px;height:44px;border-radius:var(--ds-radius-lg);background:var(--ds-white);border:2px solid var(--ds-gray-200);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--ds-text-sm);color:var(--ds-gray-400);transition:all var(--ds-transition-spring);position:relative;margin:0 var(--ds-space-4)}.ds-step:after{content:"";position:absolute;left:calc(100% + 2px);top:50%;width:28px;height:3px;background:var(--ds-gray-200);transform:translateY(-50%);border-radius:2px}.ds-step:last-child:after{display:none}.ds-step--active{background:var(--ds-gradient-primary);border-color:transparent;color:var(--ds-white);transform:scale(1.1);box-shadow:var(--ds-shadow-primary)}.ds-step--completed{background:var(--ds-success);border-color:transparent;color:var(--ds-white)}.ds-step--completed:after,.ds-step--active:after{background:var(--ds-primary)}.ds-progress{height:8px;background:var(--ds-gray-100);border-radius:var(--ds-radius-full);overflow:hidden}.ds-progress__bar{height:100%;background:var(--ds-gradient-primary);border-radius:var(--ds-radius-full);transition:width var(--ds-transition-slow)}.ds-alert{display:flex;align-items:flex-start;gap:var(--ds-space-4);padding:var(--ds-space-4) var(--ds-space-5);border-radius:var(--ds-radius-lg);font-size:var(--ds-text-sm);font-weight:500}.ds-alert--info{background:var(--ds-info-light);color:var(--ds-info);border:1px solid rgba(59,130,246,.2)}.ds-alert--success{background:var(--ds-success-light);color:var(--ds-success-dark);border:1px solid rgba(16,185,129,.2)}.ds-alert--warning{background:var(--ds-warning-light);color:var(--ds-warning-dark);border:1px solid rgba(245,158,11,.2)}.ds-alert--error{background:var(--ds-error-light);color:var(--ds-error-dark);border:1px solid rgba(239,68,68,.2)}.ds-badge{display:inline-flex;align-items:center;padding:var(--ds-space-1) var(--ds-space-3);font-size:var(--ds-text-xs);font-weight:600;border-radius:var(--ds-radius-full);text-transform:uppercase;letter-spacing:.05em}.ds-badge--primary{background:var(--ds-primary-light);color:var(--ds-primary)}.ds-badge--success{background:var(--ds-success-light);color:var(--ds-success-dark)}.ds-badge--warning{background:var(--ds-warning-light);color:var(--ds-warning-dark)}.ds-badge--error{background:var(--ds-error-light);color:var(--ds-error-dark)}.ds-icon-box{display:flex;align-items:center;justify-content:center;border-radius:var(--ds-radius-xl)}.ds-icon-box--sm{width:40px;height:40px}.ds-icon-box--md{width:56px;height:56px}.ds-icon-box--lg{width:80px;height:80px}.ds-icon-box--primary{background:var(--ds-gradient-primary);color:var(--ds-white);box-shadow:var(--ds-shadow-primary)}.ds-icon-box--secondary{background:var(--ds-gray-100);color:var(--ds-gray-600)}.ds-list{list-style:none;padding:0;margin:0}.ds-list__item{display:flex;align-items:center;gap:var(--ds-space-4);padding:var(--ds-space-4) var(--ds-space-5);background:var(--ds-gray-50);border-radius:var(--ds-radius-lg);margin-bottom:var(--ds-space-3);font-weight:500;color:var(--ds-gray-700);transition:all var(--ds-transition-base)}.ds-list__item:hover{background:var(--ds-white);box-shadow:var(--ds-shadow-md);transform:translate(4px)}.ds-list__item-icon{flex-shrink:0;color:var(--ds-primary)}.ds-empty{text-align:center;padding:var(--ds-space-16) var(--ds-space-8)}.ds-empty__icon{width:80px;height:80px;margin:0 auto var(--ds-space-6);background:var(--ds-gray-100);border-radius:var(--ds-radius-2xl);display:flex;align-items:center;justify-content:center;color:var(--ds-gray-400)}.ds-empty__title{font-size:var(--ds-text-xl);font-weight:700;color:var(--ds-gray-900);margin-bottom:var(--ds-space-2)}.ds-empty__description{font-size:var(--ds-text-base);color:var(--ds-gray-500);max-width:320px;margin:0 auto var(--ds-space-6)}.ds-divider{height:1px;background:var(--ds-gray-200);margin:var(--ds-space-6) 0}.ds-divider--lg{margin:var(--ds-space-10) 0}@keyframes ds-fadeIn{0%{opacity:0}to{opacity:1}}@keyframes ds-slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes ds-scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes ds-pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes ds-shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}.ds-animate-fadeIn{animation:ds-fadeIn .3s ease-out}.ds-animate-slideUp{animation:ds-slideUp .4s ease-out}.ds-animate-scaleIn{animation:ds-scaleIn .3s ease-out}.ds-animate-shake{animation:ds-shake .5s ease-in-out}@media (max-width: 768px){.ds-page{padding:var(--ds-space-8) var(--ds-space-4)}.ds-card{padding:var(--ds-space-6);border-radius:var(--ds-radius-xl)}.ds-page-header__title{font-size:var(--ds-text-3xl)}.ds-chip-grid{grid-template-columns:repeat(2,1fr)}.ds-step{width:38px;height:38px;margin:0 var(--ds-space-2)}.ds-step:after{width:16px}}@media (max-width: 480px){.ds-page-header__title{font-size:var(--ds-text-2xl)}.ds-btn--lg{padding:var(--ds-space-4) var(--ds-space-6);font-size:var(--ds-text-base)}}.skeleton{background:linear-gradient(90deg,var(--gray-100) 0%,var(--gray-50) 50%,var(--gray-100) 100%);background-size:200% 100%;animation:skeletonPulse 1.5s ease-in-out infinite;border-radius:var(--radius-md)}@keyframes skeletonPulse{0%,to{opacity:1;background-position:200% 0}50%{opacity:.85;background-position:-200% 0}}@keyframes skeletonShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:16px;margin-bottom:8px;border-radius:4px}.skeleton-text-sm{height:12px;width:60%}.skeleton-text-lg{height:24px}.skeleton-title{height:32px;width:70%;margin-bottom:16px}.skeleton-avatar-lg{width:80px;height:80px}.skeleton-card{height:200px;border-radius:var(--radius-lg)}.skeleton-button{height:48px;width:120px;border-radius:var(--radius-lg)}.skeleton-image{width:100%;height:180px;border-radius:var(--radius-lg)}.skeleton-container{padding:24px}.skeleton-row{display:flex;gap:16px;margin-bottom:16px}.skeleton-col{flex:1}.skeleton-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:32px}.skeleton-stat-card{height:140px;border-radius:var(--radius-lg)}:root{--primary: #2563eb;--primary-hover: #1d4ed8;--primary-light: #dbeafe;--primary-dark: #1e40af;--accent: #60a5fa;--accent-light: #eff6ff;--gradient-start: #2563eb;--gradient-end: #7c3aed;--gradient-primary: linear-gradient(135deg, #2563eb 0%, #7c3aed 100%);--gradient-blue: linear-gradient(135deg, #2563eb 0%, #60a5fa 100%);--gradient-glow: linear-gradient(135deg, #60a5fa 0%, #a78bfa 100%);--success: #10b981;--success-light: #d1fae5;--warning: #f59e0b;--warning-light: #fef3c7;--danger: #ef4444;--danger-light: #fee2e2;--info: #3b82f6;--info-light: #dbeafe;--white: #ffffff;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--bg-primary: var(--white);--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--text-primary: var(--gray-900);--text-secondary: var(--gray-600);--text-muted: var(--gray-400);--primary-dark: var(--primary-hover);--secondary: var(--warning);--bg-light: var(--bg-secondary);--bg-white: var(--white);--text-dark: var(--text-primary);--text-gray: var(--text-secondary);--text-light: var(--text-muted);--border: var(--border-color);--shadow: var(--shadow-sm);--border-color: var(--gray-200);--border-radius-sm: 6px;--border-radius-md: 10px;--border-radius-lg: 16px;--border-radius-xl: 24px;--border-radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04), 0 2px 4px rgba(0, 0, 0, .04);--shadow-md: 0 2px 4px rgba(0, 0, 0, .04), 0 4px 8px rgba(0, 0, 0, .04), 0 8px 16px rgba(0, 0, 0, .04);--shadow-lg: 0 4px 8px rgba(0, 0, 0, .04), 0 8px 16px rgba(0, 0, 0, .04), 0 16px 32px rgba(0, 0, 0, .04);--shadow-xl: 0 8px 16px rgba(0, 0, 0, .04), 0 16px 32px rgba(0, 0, 0, .06), 0 24px 48px rgba(0, 0, 0, .08);--shadow-glow: 0 0 40px rgba(37, 99, 235, .25);--shadow-primary: 0 10px 30px -10px rgba(37, 99, 235, .5);--shadow-card: 0 1px 2px rgba(0, 0, 0, .04), 0 4px 8px rgba(0, 0, 0, .04), 0 12px 24px rgba(0, 0, 0, .04);--shadow-card-hover: 0 4px 8px rgba(0, 0, 0, .06), 0 12px 24px rgba(0, 0, 0, .06), 0 20px 40px rgba(59, 130, 246, .08);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--spacing-3xl: 64px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .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;--font-size-5xl: 3rem;--font-size-6xl: 3.5rem;--line-height-tight: 1.2;--line-height-snug: 1.35;--line-height-normal: 1.5;--line-height-relaxed: 1.65;--line-height-loose: 1.75;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extrabold: 800;--letter-spacing-tight: -.025em;--letter-spacing-normal: 0;--letter-spacing-wide: .025em;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 24px;--radius-full: 9999px;--max-width-sm: 640px;--max-width-md: 768px;--max-width-lg: 1024px;--max-width-xl: 1280px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--text-primary);background-color:var(--bg-primary);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-weight:var(--font-weight-normal)}@supports (padding: max(0px)){body{padding-left:max(0px,env(safe-area-inset-left));padding-right:max(0px,env(safe-area-inset-right))}}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);color:var(--text-primary);letter-spacing:var(--letter-spacing-tight)}h1{font-size:var(--font-size-5xl);font-weight:var(--font-weight-extrabold);line-height:1.1}h2{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);line-height:1.15}h3{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);line-height:1.25}h4{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}@media (max-width: 768px){h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-xl)}}p{color:var(--text-secondary);line-height:var(--line-height-relaxed)}li,span{line-height:var(--line-height-relaxed)}a{color:var(--primary);text-decoration:none;transition:color .2s ease;min-height:24px;display:inline-block}a:hover{color:var(--primary-hover)}@media (max-width: 768px){a{min-height:32px;padding:4px 0}}img{max-width:100%;height:auto;display:block}button{font-family:inherit;cursor:pointer;border:none;outline:none;min-height:44px;touch-action:manipulation}input,textarea,select{font-family:inherit;font-size:var(--font-size-base)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #1f6feb1f}@media (max-width: 768px){input,textarea,select{font-size:16px}}.container{max-width:var(--max-width-xl);margin:0 auto;padding:0 var(--spacing-lg)}@media (max-width: 768px){.container{padding:0 20px}}@media (max-width: 480px){.container{padding:0 16px}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-family);font-weight:600;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;white-space:nowrap;text-decoration:none;min-height:48px;padding:12px 24px;font-size:1rem}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn-sm{min-height:32px;padding:6px 12px;font-size:.875rem;border-radius:var(--radius-md)}.btn-md{min-height:40px;padding:10px 20px;font-size:.9375rem}.btn-lg{min-height:48px;padding:14px 28px;font-size:1rem}.btn-xl{min-height:56px;padding:16px 32px;font-size:1.125rem;border-radius:var(--radius-xl)}.btn-primary{background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;box-shadow:0 8px 24px -8px #2563eb80;border:none;position:relative;overflow:hidden;transition:transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s cubic-bezier(.4,0,.2,1)}.btn-primary:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#3b82f6,#9333ea);opacity:0;transition:opacity .3s ease}.btn-primary:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.btn-primary:hover:not(:disabled){transform:translateY(-3px) scale(1.02);box-shadow:0 16px 40px -12px #2563eb8c}.btn-primary:hover:not(:disabled):before{opacity:1}.btn-primary:hover:not(:disabled):after{left:100%}.btn-primary span,.btn-primary svg{position:relative;z-index:1}.btn-primary:active:not(:disabled){transform:translateY(-1px) scale(.99);box-shadow:0 6px 16px -8px #2563eb80}.btn-secondary{background:#fff;color:var(--text-primary);border:1px solid var(--border-color);box-shadow:0 2px 4px #0000000a;transition:all .25s cubic-bezier(.4,0,.2,1)}.btn-secondary:hover:not(:disabled){border-color:var(--primary);color:var(--primary);background:var(--primary-light);transform:translateY(-2px);box-shadow:0 8px 20px #3b82f61f}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid transparent}.btn-ghost:hover:not(:disabled){background:var(--gray-100);color:var(--text-primary)}.btn-outline{background:transparent;color:var(--primary);border:2px solid var(--primary)}.btn-outline:hover:not(:disabled){background:var(--primary);color:#fff}.btn-full{width:100%}.btn-icon{display:flex;align-items:center;justify-content:center}.input{width:100%;min-height:52px;padding:14px 18px;font-size:1rem;font-family:var(--font-family);color:var(--text-primary);background:#fff;border:1.5px solid var(--border-color);border-radius:var(--radius-lg);transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 2px #0000000a}.input::placeholder{color:var(--gray-400)}.input:hover{border-color:var(--gray-400);box-shadow:0 2px 4px #0000000f}.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px #2563eb1a,0 2px 8px #2563eb1a;background:#fafbff}.input-error{border-color:var(--danger)}.input-error:focus{box-shadow:0 0 0 3px #ff3b301f}.input-sm{min-height:36px;padding:8px 12px;font-size:.875rem}.input-lg{min-height:56px;padding:16px 20px;font-size:1.125rem}.textarea{min-height:120px;resize:vertical}.form-group{margin-bottom:20px}.form-label{display:block;font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:8px}.form-hint{font-size:.8125rem;color:var(--text-muted);margin-top:6px}.form-error{font-size:.8125rem;color:var(--danger);margin-top:6px}.card{background:#fff;border-radius:var(--radius-xl);border:1px solid rgba(226,232,240,.8);box-shadow:var(--shadow-card);transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s cubic-bezier(.4,0,.2,1),border-color .3s ease}.card-hover:hover{transform:translateY(-4px);box-shadow:var(--shadow-card-hover);border-color:#3b82f633}.card-padding{padding:28px}.card-padding-sm{padding:20px}.card-padding-lg{padding:36px}.card-glass{background:#ffffffd9;backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border:1px solid rgba(255,255,255,.6);box-shadow:0 8px 32px #1f268714}.card-glass:hover{background:#ffffffeb;box-shadow:0 12px 40px #1f26871f}.glass-overlay{background:#ffffffbf;backdrop-filter:blur(32px) saturate(200%);-webkit-backdrop-filter:blur(32px) saturate(200%)}.card-gradient-border{position:relative;background:#fff;border:none}.card-gradient-border:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius-xl);padding:1px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}@media (max-width: 768px){html{font-size:15px}h1{font-size:2rem}h2{font-size:1.75rem}h3{font-size:1.4rem}}@media (max-width: 480px){html{font-size:14px}h1{font-size:1.75rem}h2{font-size:1.5rem}h3{font-size:1.25rem}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--gray-100)}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px;box-shadow:0 0 0 4px #1f6feb33}.input:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #1f6feb26}a:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:4px}.card:focus-visible,[role=button]:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.touch-target{min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center}.skip-link:focus{transform:translateY(0);opacity:1}@media (prefers-contrast: high){:root{--border-color: #000000}.btn-primary{border:2px solid #000000}.input{border-width:2px}}::selection{background-color:var(--primary-light);color:var(--primary)}.loading-spinner{display:inline-flex;align-items:center;justify-content:center;gap:8px}.loading-spinner__spinner{display:inline-block;border-radius:50%;border-style:solid;border-color:#1f6feb33;border-top-color:var(--primary);animation:spinner-rotate 1s linear infinite}.loading-spinner--small .loading-spinner__spinner{width:16px;height:16px;border-width:2px}.loading-spinner--medium .loading-spinner__spinner{width:24px;height:24px;border-width:3px}.loading-spinner--large .loading-spinner__spinner{width:40px;height:40px;border-width:4px}.loading-spinner__message{color:var(--text-secondary);font-size:var(--font-size-sm)}@keyframes spinner-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.btn-primary .loading-spinner__spinner{border-color:#ffffff59;border-top-color:#fff}.skeleton{background:linear-gradient(90deg,#f1f5f9,#e2e8f0,#f8fafc,#e2e8f0 60%,#f1f5f9);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-md)}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:1em;margin-bottom:.5em}.skeleton-text:last-child{width:70%}.skeleton-heading{height:1.5em;width:60%;margin-bottom:1em}.skeleton-avatar{width:48px;height:48px;border-radius:50%}.skeleton-avatar--lg{width:80px;height:80px}.skeleton-card{background:#fff;border-radius:var(--radius-xl);padding:24px;border:1px solid var(--border-color)}.skeleton-card__image{height:180px;margin-bottom:16px;border-radius:var(--radius-lg)}.skeleton-card__content{display:flex;flex-direction:column;gap:8px}.skeleton-stat{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px}.skeleton-stat__icon{width:56px;height:56px;border-radius:var(--radius-lg)}.skeleton-stat__value{width:60%;height:2rem}.skeleton-stat__label{width:80%;height:1rem}.skeleton-button{height:48px;width:140px;border-radius:var(--radius-lg)}.skeleton-input{height:52px;border-radius:var(--radius-lg)}.skeleton-row{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--border-color)}.skeleton-row>.skeleton{flex:1;height:1.25rem}.skeleton-chart{height:300px;border-radius:var(--radius-lg)}.skeleton-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}body:before,body:after,#root:before,#root:after{content:none!important;display:none!important}[data-testid=index-html-text],.index-html-text{display:none!important}.floating-element{font-size:0}.floating-element *{font-size:1rem}html{scroll-behavior:smooth}*:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:4px}button,a,input,select,textarea{transition:all .2s cubic-bezier(.4,0,.2,1)}.loading,.loading *{cursor:wait!important}button:disabled,input:disabled,select:disabled,textarea:disabled{opacity:.5;cursor:not-allowed}img{opacity:0;transition:opacity .3s ease-in-out}img.loaded,img[src]{opacity:1}#root{animation:fadeIn .3s ease-out}::selection{background:var(--primary-light);color:var(--primary)}::-moz-selection{background:var(--primary-light);color:var(--primary)}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}*{-webkit-tap-highlight-color:transparent}@media (hover: none) and (pointer: coarse){button,a,.btn-primary,.btn-secondary,.action-card,.nav-link{min-height:48px;min-width:48px}input[type=checkbox],input[type=radio]{min-width:24px;min-height:24px}.card:hover,.btn-primary:hover,.btn-secondary:hover{transform:none}}.bg-gradient-soft{background:linear-gradient(180deg,#fafbff,#f0f4ff,#f8fafc)}.bg-mesh{background-color:#fafbff;background-image:radial-gradient(at 40% 20%,rgba(59,130,246,.08) 0px,transparent 50%),radial-gradient(at 80% 0%,rgba(139,92,246,.06) 0px,transparent 50%),radial-gradient(at 0% 50%,rgba(59,130,246,.04) 0px,transparent 50%),radial-gradient(at 80% 50%,rgba(236,72,153,.04) 0px,transparent 50%),radial-gradient(at 0% 100%,rgba(59,130,246,.06) 0px,transparent 50%),radial-gradient(at 80% 100%,rgba(139,92,246,.04) 0px,transparent 50%)}.bg-hero{background:linear-gradient(135deg,#f8fafc,#e0e7ff,#f0f4ff)}.bg-gradient-card{background:linear-gradient(145deg,#fff,#f8fafc)}.bg-gradient-accent{background:linear-gradient(135deg,#3b82f6,#8b5cf6)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.animate-fade-in{animation:fadeIn .4s ease-out forwards}.animate-fade-in-up{animation:fadeInUp .5s ease-out forwards}.animate-fade-in-scale{animation:fadeInScale .4s ease-out forwards}.animate-slide-in-left{animation:slideInLeft .4s ease-out forwards}.stagger-1{animation-delay:.05s}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.stagger-6{animation-delay:.3s}.page-content{animation:fadeInUp .4s ease-out}.card-grid>*{opacity:0;animation:fadeInUp .5s ease-out forwards}.card-grid>*:nth-child(1){animation-delay:.05s}.card-grid>*:nth-child(2){animation-delay:.1s}.card-grid>*:nth-child(3){animation-delay:.15s}.card-grid>*:nth-child(4){animation-delay:.2s}.card-grid>*:nth-child(5){animation-delay:.25s}.card-grid>*:nth-child(6){animation-delay:.3s}.animate-number{display:inline-block}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}.animate-pulse{animation:pulse 2s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.animate-float{animation:float 3s ease-in-out infinite}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.card-grid>*{opacity:1;animation:none}}@media print{.app-header,.app-nav,.app-breadcrumbs,.app-footer,.skip-link,.back-to-top,.toast-container,[aria-label=Notifications],button:not(.print-show),.app-nav-cta,.app-nav-mobile,.app-nav-user-dropdown{display:none!important}body{background:#fff;color:#111}.app-main{padding:0}a[href]:after{content:" (" attr(href) ")";font-size:.85em;color:#666}img{max-width:100%!important;page-break-inside:avoid}.card{box-shadow:none;border:1px solid #ddd;page-break-inside:avoid}}html{overflow-x:hidden}body{max-width:100%;overflow-x:hidden}p,li,span,.page-container{word-wrap:break-word;overflow-wrap:break-word}@media (max-width: 768px){.btn-primary,.btn-secondary,.btn-outline,.back-button,.back-to-top,button:not([type=checkbox]):not([type=radio]),.app-nav a,.skip-link{min-height:44px;min-width:44px;padding-top:10px;padding-bottom:10px}button.inline-icon,.back-button{min-width:44px}}*{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}button,.btn{position:relative;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}button:hover,.btn:hover{transform:translateY(-1px)}button:active,.btn:active{transform:translateY(0)}button:after,.btn:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff80;transform:translate(-50%,-50%);transition:width .6s,height .6s}button:active:after,.btn:active:after{width:300px;height:300px}@keyframes spin{to{transform:rotate(360deg)}}.loading-spinner{display:inline-block;width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:4px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.card{transition:all .3s cubic-bezier(.4,0,.2,1)}.card:hover{transform:translateY(-4px);box-shadow:0 20px 40px #0000001f}@keyframes glow{0%,to{box-shadow:0 0 5px #1f6feb80}50%{box-shadow:0 0 20px #1f6febcc}}.glow{animation:glow 2s ease-in-out infinite}input:focus,textarea:focus,select:focus{outline:none;transform:scale(1.01);transition:all .2s ease}.focus-ring:focus{outline:none;box-shadow:0 0 0 3px #1f6feb33}.fade-in-on-scroll{opacity:0;transform:translateY(30px);transition:opacity .6s ease-out,transform .6s ease-out}.fade-in-on-scroll.visible{opacity:1;transform:translateY(0)}.progress-bar{position:relative;overflow:hidden}.progress-bar:after{content:"";position:absolute;top:0;left:0;bottom:0;right:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:progress-shine 2s infinite}@keyframes progress-shine{0%{transform:translate(-100%)}to{transform:translate(100%)}}.tooltip{position:relative;animation:fadeIn .2s ease-out}.tooltip:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-8px);padding:8px 12px;background:#1e293b;color:#fff;font-size:.875rem;border-radius:6px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease}.tooltip:hover:after{opacity:1}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.bounce{animation:bounce 1s infinite}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-10px)}20%,40%,60%,80%{transform:translate(10px)}}.shake{animation:shake .5s ease-in-out}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}.wiggle{animation:wiggle .5s ease-in-out}@keyframes gradient-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.animated-gradient{background-size:200% 200%;animation:gradient-shift 3s ease infinite}.smooth-transition{transition:all .3s cubic-bezier(.4,0,.2,1)}.fast-transition{transition:all .15s ease}.slow-transition{transition:all .6s ease}.hover-lift{transition:transform .2s ease}.hover-lift:hover{transform:translateY(-4px)}.hover-scale{transition:transform .2s ease}.hover-scale:hover{transform:scale(1.05)}.hover-glow{transition:box-shadow .3s ease}.hover-glow:hover{box-shadow:0 0 20px #1f6feb66}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
