:root{--color-primary:#667eea;--color-primary-dark:#764ba2;--color-success:#28a745;--color-danger:#dc3545;--color-warning:#ffc107;--color-info:#17a2b8;--color-text-primary:#333;--color-text-secondary:#666;--color-text-muted:#6c757d;--color-text-light:#7f8c8d;--color-bg-primary:#fff;--color-bg-secondary:#f8f9fa;--color-bg-muted:#e9ecef;--color-border:#e1e5e9;--color-border-light:#f1f3f4;--font-size-xs:clamp(0.7rem,0.65rem + 0.25vw,0.75rem);--font-size-sm:clamp(0.8rem,0.75rem + 0.25vw,0.875rem);--font-size-base:clamp(0.875rem,0.825rem + 0.25vw,1rem);--font-size-md:clamp(0.925rem,0.875rem + 0.25vw,1.05rem);--font-size-lg:clamp(1rem,0.95rem + 0.25vw,1.125rem);--font-size-xl:clamp(1.125rem,1rem + 0.5vw,1.25rem);--font-size-2xl:clamp(1.25rem,1.1rem + 0.75vw,1.5rem);--font-size-3xl:clamp(1.5rem,1.2rem + 1.5vw,2.5rem);--font-size-4xl:clamp(1.75rem,1.3rem + 2vw,3.5rem);--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--line-height-tight:1.2;--line-height-base:1.4;--line-height-relaxed:1.6;--space-xs:0.25rem;--space-sm:0.5rem;--space-md:0.75rem;--space-lg:1rem;--space-xl:1.5rem;--space-2xl:2rem;--space-3xl:2.5rem;--space-4xl:3rem;--space-px-10:10px;--space-px-20:20px;--space-px-24:24px;--space-px-30:30px;--space-px-40:40px;--space-px-60:60px;--space-px-80:80px;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-xl:12px;--radius-2xl:20px;--radius-full:50%;--shadow-sm:0 2px 4px #0000001a;--shadow-md:0 2px 8px #0000001a;--shadow-lg:0 2px 10px #0000001a;--shadow-xl:0 4px 20px #00000026;--container-max:1200px;--container-padding:clamp(1rem,2vw,2rem);--breakpoint-sm:480px;--breakpoint-md:768px;--breakpoint-lg:1024px;--breakpoint-xl:1280px;--color-surface-glass:#ffffffd9;--color-surface-glass-dark:#0f172ad9;--shadow-glow:0 0 20px #6366f14d;--shadow-glow-lg:0 0 40px #6366f166;--shadow-elevated-xl:0 32px 64px -12px #00000040;--shadow-inner:inset 0 2px 4px 0 #0000000f;--gradient-hero:linear-gradient(135deg,#667eea,#764ba2);--gradient-surface:linear-gradient(145deg,#ffffffe6,#ffffffb3);--gradient-glass:linear-gradient(145deg,#ffffff1a,#ffffff0d);--transition-fast:0.15s cubic-bezier(0.4,0,0.2,1);--transition-normal:0.3s cubic-bezier(0.4,0,0.2,1);--transition-slow:0.5s cubic-bezier(0.4,0,0.2,1);--transition-bounce:0.6s cubic-bezier(0.68,-0.55,0.265,1.55);--transition-spring:0.4s cubic-bezier(0.175,0.885,0.32,1.275);--duration-fast:150ms;--duration-normal:300ms;--duration-slow:500ms;--duration-slower:750ms;--blur-sm:4px;--blur-md:8px;--blur-lg:16px;--blur-xl:24px;--shadow-inset:inset 0 2px 4px #0000001a;--shadow-focus:0 0 0 3px #667eea33;--gradient-primary:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);--gradient-success:linear-gradient(135deg,var(--color-success) 0%,#1e7e34 100%);--gradient-danger:linear-gradient(135deg,var(--color-danger) 0%,#c82333 100%)}.container{max-width:var(--container-max)}.container,.container-narrow{margin-left:auto;margin-right:auto;padding-left:var(--container-padding);padding-right:var(--container-padding);width:100%}.container-narrow{max-width:800px}.page-wrapper{min-height:calc(100vh - 64px);padding-bottom:var(--space-3xl);padding-top:var(--space-lg)}@media (min-width:768px){.page-wrapper{padding-bottom:var(--space-4xl);padding-top:var(--space-2xl)}}.grid{grid-gap:var(--space-lg);display:grid;gap:var(--space-lg)}.grid-1,.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}@media (min-width:480px){.grid-2,.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (min-width:768px){.grid-3,.grid-4{grid-template-columns:repeat(3,1fr)}}@media (min-width:1024px){.grid-4{grid-template-columns:repeat(4,1fr)}}.stack{display:flex;flex-direction:column;gap:var(--space-lg)}@media (min-width:768px){.stack-row{align-items:flex-start;flex-direction:row}}.layout-sidebar{display:flex;flex-direction:column;gap:var(--space-lg)}@media (min-width:768px){.layout-sidebar{flex-direction:row}.layout-sidebar>.sidebar{flex-shrink:0;width:280px}.layout-sidebar>.main-content{flex:1 1;min-width:0}}.hide-mobile{display:none!important}@media (min-width:768px){.hide-mobile{display:inline!important;display:initial!important}.hide-desktop{display:none!important}}.show-mobile{display:inline;display:initial}@media (min-width:768px){.show-mobile{display:none!important}}.overflow-wrap{-webkit-hyphens:auto;hyphens:auto;overflow-wrap:break-word;word-break:break-word}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-responsive{-webkit-overflow-scrolling:touch;background:var(--color-bg-primary);inset:0;overflow-y:auto;padding:var(--space-lg);position:fixed;z-index:1000}@media (min-width:768px){.modal-responsive{border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);inset:auto;left:50%;max-height:85vh;max-width:600px;top:50%;transform:translate(-50%,-50%);width:90%}}.form-group{width:100%}.form-row{display:flex;flex-direction:column}@media (min-width:480px){.form-row{flex-direction:row}.form-row>*{flex:1 1}}.form-input{border:1px solid var(--color-border);padding:var(--space-md) var(--space-lg);transition:border-color var(--transition-fast);width:100%}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.text-3xl{font-size:var(--font-size-3xl)}.font-normal{font-weight:var(--font-weight-normal)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.p-xs{padding:var(--space-xs)}.p-sm{padding:var(--space-sm)}.p-md{padding:var(--space-md)}.p-lg{padding:var(--space-lg)}.p-xl{padding:var(--space-xl)}.m-xs{margin:var(--space-xs)}.m-sm{margin:var(--space-sm)}.m-md{margin:var(--space-md)}.m-lg{margin:var(--space-lg)}.m-xl{margin:var(--space-xl)}.mobile-stack{display:flex;flex-direction:column;gap:var(--space-lg)}@media (min-width:768px){.mobile-stack{align-items:center;flex-direction:row}}.mobile-center{text-align:center}@media (min-width:768px){.mobile-center{text-align:left}}.mobile-full-width{width:100%}@media (min-width:768px){.mobile-full-width{width:auto}}.btn-mobile-friendly{border-radius:var(--radius-lg);min-height:44px;overflow:hidden;padding:var(--space-md) var(--space-xl);position:relative;transition:all var(--transition-normal);will-change:transform}.btn-mobile-friendly:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left var(--transition-slow);width:100%}.btn-mobile-friendly:hover:before{left:100%}.card-mobile{-webkit-backdrop-filter:blur(var(--blur-sm));backdrop-filter:blur(var(--blur-sm));background:var(--gradient-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin-bottom:var(--space-lg);padding:var(--space-lg);transition:all var(--transition-normal);will-change:transform}.card-mobile:hover{box-shadow:var(--shadow-xl);transform:translateY(-2px)}@media (min-width:768px){.card-mobile{margin-bottom:var(--space-xl);padding:var(--space-xl)}}.glass{background:var(--color-surface-glass);border:1px solid #fff3}.glass,.glass-dark{-webkit-backdrop-filter:blur(var(--blur-md));backdrop-filter:blur(var(--blur-md))}.glass-dark{background:var(--color-surface-glass-dark);border:1px solid #ffffff1a}.animate-fade-in{animation:fadeIn var(--duration-normal) var(--transition-normal)}.animate-slide-up{animation:slideUp var(--duration-normal) var(--transition-normal)}.animate-scale-in{animation:scaleIn var(--duration-normal) var(--transition-bounce)}.animate-glow{animation:glow 2s ease-in-out infinite alternate}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes glow{0%{box-shadow:var(--shadow-glow)}to{box-shadow:var(--shadow-glow-lg)}}.hover-lift{transition:transform var(--transition-normal);will-change:transform}.hover-lift:hover{transform:translateY(-4px)}.hover-glow{transition:box-shadow var(--transition-normal)}.hover-glow:hover{box-shadow:var(--shadow-glow)}.focus-ring{transition:box-shadow var(--transition-fast)}.focus-ring:focus{box-shadow:0 0 0 3px #6366f14d;outline:none}.glass-surface{-webkit-backdrop-filter:blur(var(--blur-sm));backdrop-filter:blur(var(--blur-sm));background:var(--gradient-surface);border:1px solid #fff3;border-radius:var(--radius-xl)}.glass-card{-webkit-backdrop-filter:blur(var(--blur-md));backdrop-filter:blur(var(--blur-md));background:var(--gradient-glass);border:1px solid #ffffff26;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.animate-float{animation:float 6s ease-in-out infinite}.animate-pulse-glow{animation:pulseGlow 2s ease-in-out infinite alternate}.animate-shimmer{animation:shimmer 2s linear infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulseGlow{0%{box-shadow:var(--shadow-glow)}to{box-shadow:var(--shadow-glow-lg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.hover-scale{transition:transform var(--transition-spring);will-change:transform}.hover-scale:hover{transform:scale(1.05)}.hover-lift-lg{transition:all var(--transition-spring);will-change:transform}.hover-lift-lg:hover{box-shadow:var(--shadow-elevated-xl);transform:translateY(-8px) scale(1.02)}.interactive-card{cursor:pointer;transition:all var(--transition-spring);will-change:transform}.interactive-card:hover{box-shadow:var(--shadow-xl),var(--shadow-glow);transform:translateY(-4px)}.interactive-card:active{transform:translateY(-2px);transition:transform var(--transition-fast)}.btn-glass{-webkit-backdrop-filter:blur(var(--blur-sm));backdrop-filter:blur(var(--blur-sm));background:var(--gradient-glass);border:1px solid #fff3;color:var(--color-text-primary);overflow:hidden;position:relative;transition:all var(--transition-spring)}.btn-glass:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left var(--transition-slow);width:100%}.btn-glass:hover:before{left:100%}.btn-glass:hover{background:#ffffff4d;box-shadow:var(--shadow-lg);transform:translateY(-2px) scale(1.02)}.loading-shimmer{animation:shimmer 2s ease-in-out infinite;background:linear-gradient(90deg,#f0f0f0cc 25%,#ffffffe6 50%,#f0f0f0cc 75%);background-size:200% 100%}.status-indicator{display:inline-block;position:relative}.status-indicator:after{animation:pulse 2s infinite;border-radius:var(--radius-full);content:"";height:8px;position:absolute;right:-2px;top:-2px;width:8px}.status-indicator.online:after{background:var(--color-success)}.status-indicator.busy:after{background:var(--color-warning)}.status-indicator.offline:after{background:var(--color-text-muted)}@keyframes pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.2)}to{opacity:1;transform:scale(1)}}@media (prefers-reduced-motion:reduce){.animate-fade-in,.animate-float,.animate-glow,.animate-pulse-glow,.animate-scale-in,.animate-shimmer,.animate-slide-up,.btn-glass:before,.btn-mobile-friendly:before,.hover-glow,.hover-lift,.hover-lift-lg,.hover-scale,.interactive-card,.status-indicator:after{animation:none;transition:none}.btn-glass,.btn-mobile-friendly,.card-mobile,.hover-lift,.hover-lift-lg,.hover-scale,.interactive-card{will-change:auto}}*,:after,:before{box-sizing:border-box}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth}canvas,img,svg,video{display:block;height:auto;max-width:100%}button,input,select,textarea{font:inherit}.btn,[role=button],a.btn,button{min-height:44px}table{border-collapse:collapse;width:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-bg-secondary);color:var(--color-text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:var(--font-size-base);line-height:var(--line-height-base);margin:0;overflow-x:hidden}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.toast-container{flex-direction:column;max-width:calc(100vw - 2rem);pointer-events:none;position:fixed;right:1rem;right:var(--container-padding,1rem);top:70px;width:380px;z-index:9999}.toast,.toast-container{display:flex;gap:.5rem;gap:var(--space-sm,.5rem)}.toast{align-items:center;animation:toast-slide-in .3s ease-out;background:#fff;border-left:4px solid #6b7280;border-radius:10px;box-shadow:0 4px 20px #00000026;cursor:pointer;padding:.75rem 1rem;padding:var(--space-md,.75rem) var(--space-lg,1rem);pointer-events:auto;transition:opacity .2s,transform .2s}.toast:hover{transform:translateX(-2px)}.toast-info{border-left-color:#2563eb}.toast-success{border-left-color:#059669}.toast-error{border-left-color:#dc2626}.toast-warning{border-left-color:#d97706}.toast-icon{flex-shrink:0;font-size:1.1rem}.toast-message{color:#1f2937;flex:1 1;font-size:.875rem;line-height:1.4}.toast-close{background:none;border:none;color:#9ca3af;cursor:pointer;flex-shrink:0;font-size:1.2rem;padding:0 .25rem}.toast-close:hover{color:#374151}@keyframes toast-slide-in{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.home{min-height:100vh}.hero{background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);background:var(--gradient-hero,linear-gradient(135deg,#1a1a2e 0,#16213e 50%,#0f3460 100%));color:#fff;overflow:hidden;padding:calc(64px + var(--space-2xl)) var(--container-padding) var(--space-3xl);position:relative;text-align:center}.hero:before{background:radial-gradient(circle at 20% 80%,#7877c64d 0,#0000 50%),radial-gradient(circle at 80% 20%,#ff77c626 0,#0000 50%);content:"";inset:0;pointer-events:none;position:absolute}.hero-content{margin:0 auto;max-width:700px;position:relative;z-index:2}.hero-logo{margin-bottom:var(--space-lg)}.logo-image{filter:brightness(0) invert(1);height:50px;object-fit:contain;width:50px}.hero-title{font-size:clamp(1.75rem,5vw,3rem);font-weight:800;line-height:1.1;margin:0 0 var(--space-md)}.hero-highlight{color:#34d399}.hero-subtitle{font-size:var(--font-size-base);line-height:var(--line-height-relaxed);margin:0 0 var(--space-xl);opacity:.9}.hero-search{display:flex;flex-direction:column;gap:var(--space-sm);margin:0 auto var(--space-lg);max-width:560px}.hero-search-input{background:#fff;border:none;border-radius:12px;color:#1f2937;flex:1 1;font-size:16px;min-height:48px;outline:none;padding:var(--space-md) var(--space-lg)}.hero-search-input::placeholder{color:#9ca3af}.hero-search-btn{background:#2563eb;border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:var(--font-size-base);font-weight:600;min-height:48px;padding:var(--space-md) var(--space-xl);transition:background .15s}.hero-search-btn:hover{background:#1d4ed8}.hero-quick-links{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-sm);justify-content:center;margin-bottom:var(--space-xl)}.hero-popular{font-size:var(--font-size-sm);opacity:.7}.hero-quick-tag{align-items:center;background:#ffffff26;border-radius:20px;color:#fff;display:inline-flex;font-size:var(--font-size-xs);min-height:32px;padding:var(--space-xs) var(--space-md);text-decoration:none;transition:background .15s}.hero-quick-tag:hover{background:#ffffff40}.hero-actions{align-items:center;display:flex;flex-direction:column;gap:var(--space-sm)}.stats-bar{background:#fff;border-bottom:1px solid #e5e7eb;display:flex;gap:var(--space-2xl);justify-content:center;padding:var(--space-xl) var(--container-padding)}.stat-item{text-align:center}.stat-number{color:#1f2937;display:block;font-size:var(--font-size-xl);font-weight:800}.stat-label{color:#6b7280;font-size:var(--font-size-xs);letter-spacing:.05em;text-transform:uppercase}.home-categories{background:#f9fafb;padding:var(--space-3xl) var(--container-padding)}.section-title{color:#1f2937;font-size:var(--font-size-xl);font-weight:700;margin:0 0 var(--space-xs);text-align:center}.section-subtitle{color:#6b7280;font-size:var(--font-size-sm);margin:0 0 var(--space-2xl);text-align:center}.category-grid{grid-gap:var(--space-md);display:grid;gap:var(--space-md);grid-template-columns:repeat(2,1fr);margin:0 auto;max-width:800px}.category-card{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:12px;color:#374151;display:flex;flex-direction:column;gap:var(--space-sm);min-height:44px;padding:var(--space-lg);text-decoration:none;transition:all .15s}.category-card:hover{border-color:#2563eb;box-shadow:0 4px 12px #2563eb1a;transform:translateY(-2px)}.category-icon{font-size:1.5rem}.category-name{font-size:var(--font-size-sm);font-weight:500;text-align:center}.section-more{margin-top:var(--space-xl);text-align:center}.link-more{color:#2563eb;font-size:var(--font-size-sm);font-weight:500;text-decoration:none}.link-more:hover{text-decoration:underline}.how-it-works{background:#fff;padding:var(--space-3xl) var(--container-padding)}.steps-grid{grid-gap:var(--space-xl);display:grid;gap:var(--space-xl);grid-template-columns:1fr;margin:var(--space-2xl) auto 0;max-width:900px}.step-card{padding:var(--space-lg);text-align:center}.step-number{align-items:center;background:#eff6ff;border-radius:50%;color:#2563eb;display:inline-flex;font-size:var(--font-size-lg);font-weight:700;height:48px;justify-content:center;margin-bottom:var(--space-md);width:48px}.step-card h3{color:#1f2937;font-size:var(--font-size-base);font-weight:600;margin:0 0 var(--space-sm)}.step-card p{color:#6b7280;font-size:var(--font-size-sm);line-height:var(--line-height-relaxed);margin:0}.features{background:#f9fafb;padding:var(--space-3xl) var(--container-padding)}.home .container{margin:0 auto;max-width:1100px}.features-grid{grid-gap:var(--space-lg);display:grid;gap:var(--space-lg);grid-template-columns:1fr;margin-top:var(--space-2xl)}.feature-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:var(--space-xl) var(--space-lg);text-align:center;transition:all .15s}.feature-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.feature-icon{display:block;font-size:2rem;margin-bottom:var(--space-md)}.feature-card h3{color:#1f2937;font-size:var(--font-size-base);font-weight:600;margin:0 0 var(--space-sm)}.feature-card p{color:#6b7280;font-size:var(--font-size-sm);line-height:var(--line-height-relaxed);margin:0}.cta-section{background:linear-gradient(135deg,#1a1a2e,#0f3460);color:#fff;padding:var(--space-3xl) var(--container-padding);text-align:center}.cta-content h2{font-size:var(--font-size-xl);font-weight:700;margin:0 0 var(--space-md)}.cta-content p{font-size:var(--font-size-base);margin:0 0 var(--space-xl);opacity:.9}.cta-actions{display:flex;flex-direction:column;gap:var(--space-sm)}.btn,.cta-actions{align-items:center}.btn{border:2px solid #0000;border-radius:10px;cursor:pointer;display:inline-flex;font-size:var(--font-size-base);font-weight:600;justify-content:center;min-height:44px;padding:var(--space-md) var(--space-xl);text-decoration:none;transition:all .15s}.btn-large{max-width:280px;padding:var(--space-md) var(--space-2xl);width:100%}.btn-primary{background:#2563eb;border-color:#2563eb}.btn-primary:hover{background:#1d4ed8;transform:translateY(-1px)}.btn-secondary{background:#ffffff26;border-color:#ffffff4d;color:#fff}.btn-secondary:hover{background:#ffffff40}.btn-outline{background:#0000;border-color:#2563eb;color:#2563eb}.btn-outline:hover{background:#2563eb;color:#fff}@media (min-width:480px){.category-grid{grid-template-columns:repeat(4,1fr)}}@media (min-width:768px){.hero{padding:calc(64px + 4rem) var(--container-padding) 4rem}.hero-search{flex-direction:row}.hero-search-btn{flex-shrink:0}.cta-actions,.hero-actions{flex-direction:row;justify-content:center}.btn-large{max-width:none;width:auto}.features-grid{grid-template-columns:repeat(2,1fr)}.steps-grid{grid-template-columns:repeat(3,1fr)}.cta-content h2,.section-title{font-size:var(--font-size-2xl)}}@media (min-width:1024px){.features-grid{grid-template-columns:repeat(4,1fr)}}@media (prefers-reduced-motion:reduce){.btn,.category-card,.feature-card,.hero:before{animation:none;transition:none}}.auth-container{align-items:center;background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-dark) 100%);display:flex;justify-content:center;min-height:100vh;padding:var(--space-lg)}.auth-card{background:var(--color-bg-primary);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:400px;padding:var(--space-2xl);width:100%}.auth-header{margin-bottom:var(--space-2xl);text-align:center}.auth-title{color:var(--color-text-primary);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-sm)}.auth-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-base);margin:0}.auth-form{display:flex;flex-direction:column;gap:var(--space-lg)}.form-row{grid-gap:var(--space-md);display:grid;gap:var(--space-md);grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:var(--space-sm)}.form-label{color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.form-input{background:var(--color-bg-primary);border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);min-height:44px;padding:var(--space-md);transition:all .2s ease}.form-input:focus{border-color:var(--color-primary);box-shadow:var(--shadow-focus);outline:none}.form-input::placeholder{color:var(--color-text-muted)}.password-input-wrapper{position:relative}.password-toggle{align-items:center;background:none;border:none;color:var(--color-text-muted);cursor:pointer;display:flex;font-size:var(--font-size-lg);justify-content:center;min-height:44px;min-width:44px;padding:var(--space-xs);position:absolute;right:var(--space-md);top:50%;transform:translateY(-50%)}.password-toggle:hover{color:var(--color-text-secondary)}.password-strength{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);margin-top:var(--space-xs)}.password-strength.weak{color:var(--color-danger)}.password-strength.medium{color:var(--color-warning)}.password-strength.strong{color:var(--color-success)}.form-actions{display:flex;justify-content:flex-end}.forgot-password-link{color:var(--color-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);text-decoration:none}.forgot-password-link:hover{text-decoration:underline}.error-message{background:#dc35451a;border:1px solid #dc354533;border-radius:var(--radius-md);color:var(--color-danger)}.error-message,.success-message{animation:slideInDown var(--transition-normal);font-size:var(--font-size-sm);line-height:1.4;padding:var(--space-md)}.success-message{background:#28a7451a;border:1px solid #28a74533;border-radius:var(--radius-md);color:var(--color-success)}@keyframes slideInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.btn-primary{align-items:center;background:var(--color-primary);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:flex;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);justify-content:center;min-height:48px;padding:var(--space-md) var(--space-lg);transition:all .2s ease}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-primary:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-mobile-friendly{font-size:var(--font-size-base);min-height:48px}.auth-divider{color:var(--color-text-muted);font-size:var(--font-size-sm);margin:var(--space-xl) 0;position:relative;text-align:center}.auth-divider:before{background:var(--color-border);content:"";height:1px;left:0;position:absolute;right:0;top:50%;z-index:1}.auth-divider span{background:var(--color-bg-primary);padding:0 var(--space-lg);position:relative;z-index:2}.oauth-buttons{display:flex;flex-direction:column;gap:var(--space-md)}.oauth-button{align-items:center;background:#fff;border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;display:flex;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);justify-content:center;min-height:48px;padding:var(--space-md);text-decoration:none;transition:all .2s ease}.google-button{border-color:var(--color-border);color:var(--color-text-secondary);transition:all .3s ease}.google-button:hover{border-color:var(--color-border);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.facebook-button{background:var(--color-info);border-color:var(--color-info);color:#fff;transition:all .3s ease}.facebook-button:hover{background:var(--color-primary);border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-1px)}.auth-footer{margin-top:var(--space-xl);text-align:center}.auth-footer p{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0}.auth-link{color:var(--color-primary);font-weight:var(--font-weight-medium);text-decoration:none}.auth-link:hover{text-decoration:underline}.auth-card{padding:var(--space-xl)}.auth-title{font-size:var(--font-size-xl)}.form-row{gap:var(--space-lg);grid-template-columns:1fr}@media (min-width:480px){.auth-card{padding:var(--space-2xl)}.auth-title{font-size:var(--font-size-2xl)}.form-row{gap:var(--space-md);grid-template-columns:1fr 1fr}}@media (prefers-contrast:high){.form-input{border-width:3px}.btn-primary{border:2px solid var(--color-primary-dark)}}.verification-loading{padding:var(--space-2xl) 0;text-align:center}.loading-spinner{border-top:4px solid var(--color-border);border:4px solid var(--color-border);border-radius:50%;height:40px;margin:0 auto var(--space-lg);width:40px}.verification-loading p{color:var(--color-text-secondary);font-size:var(--font-size-base)}@media (prefers-reduced-motion:reduce){.btn-primary,.form-input,.oauth-button{transition:none}.btn-primary:hover:not(:disabled){transform:none}.loading-spinner{animation:none}}.account-type-selection{display:flex;flex-direction:column;gap:12px;margin-top:8px}.radio-option{align-items:center;border:2px solid var(--color-border);border-radius:8px;cursor:pointer;display:flex;gap:8px;padding:12px;transition:all .2s ease}.radio-option:hover{background-color:var(--color-bg-secondary);border-color:var(--color-primary)}.radio-option input[type=radio]{margin:0}.radio-option input[type=radio]:checked+span{color:var(--color-primary);font-weight:600}.radio-option:has(input[type=radio]:checked){background-color:#667eea1a;border-color:var(--color-primary);box-shadow:var(--shadow-focus);transform:scale(1.02)}.navigation{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff2;border-bottom:1px solid #eee;height:64px;left:0;position:fixed;right:0;top:0;transition:box-shadow .2s,background .2s;z-index:1000}.navigation.scrolled{box-shadow:0 2px 12px #00000014}.nav-inner{gap:1.5rem;height:100%;margin:0 auto;max-width:1400px;padding:0 1rem}.nav-brand,.nav-inner{align-items:center;display:flex}.nav-brand{flex-shrink:0;gap:.5rem;text-decoration:none}.nav-logo{height:28px;width:auto}.brand-text{color:#2563eb;font-size:1.1rem;font-weight:700}.nav-links{-webkit-overflow-scrolling:touch;align-items:stretch;background:#fff;bottom:0;box-shadow:-4px 0 24px #00000026;display:flex;flex-direction:column;gap:.25rem;height:100vh;height:100dvh;max-width:85vw;overflow-y:auto;padding:1rem;position:fixed;right:0;top:0;transform:translateX(100%);transition:transform .3s ease;width:300px;z-index:1001}.nav-links.mobile-open{transform:translateX(0)}.mobile-nav-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:.5rem;padding-bottom:.75rem}.mobile-role-switcher{display:flex;gap:.5rem}.role-pill{background:#fff;border:1px solid #e5e7eb;border-radius:20px;color:#6b7280;cursor:pointer;font-size:.8rem;font-weight:500;padding:.35rem .75rem;transition:all .15s}.role-pill.active{background:#2563eb;border-color:#2563eb;color:#fff}.mobile-close-btn{background:none;border:none;color:#6b7280;cursor:pointer;display:block;font-size:1.5rem;padding:0 .25rem}.desktop-role-switcher{display:none}.role-toggle{background:#f3f4f6;border-radius:8px;display:flex;gap:2px;padding:3px}.role-btn{background:#0000;border:none;border-radius:6px;color:#6b7280;cursor:pointer;font-size:.8rem;font-weight:500;padding:.35rem .75rem;transition:all .15s}.role-btn:hover{color:#2563eb}.role-btn.active{background:#fff;box-shadow:0 1px 3px #0000001a;color:#2563eb;font-weight:600}.nav-link{align-items:center;border-radius:10px;color:#4b5563;display:flex;font-size:.95rem;font-weight:500;min-height:44px;padding:.75rem;position:relative;text-decoration:none;transition:color .15s,background .15s;white-space:nowrap}.nav-link:hover{background:#f0f4ff;color:#2563eb}.nav-link.active{background:#eff6ff;color:#2563eb;font-weight:600}.nav-link.active:after{display:none}.nav-badge-inline{background:#ef4444;border-radius:10px;color:#fff;display:inline-block;font-size:.65rem;font-weight:700;line-height:1.3;margin-left:.35rem;min-width:16px;padding:.1rem .4rem;text-align:center}.nav-divider{background:#e5e7eb;flex-shrink:0;height:1px;margin:.25rem 0;width:100%}.nav-spacer{display:none}.nav-login{color:#2563eb!important;font-weight:600!important}.nav-cta-btn{background:#2563eb;border-radius:8px;color:#fff!important;display:block;font-size:.9rem;font-weight:600;min-height:44px;padding:.75rem;text-align:center;text-decoration:none;transition:background .15s;white-space:nowrap}.nav-cta-btn:hover{background:#1d4ed8}.nav-logout-btn{background:none;border:1px solid #e5e7eb;border-radius:8px;color:#6b7280;cursor:pointer;font-size:.85rem;font-weight:500;margin-top:.5rem;min-height:44px;padding:.4rem .75rem;transition:all .15s;width:100%}.nav-logout-btn:hover{background:#fef2f2;border-color:#ef4444;color:#ef4444}.mobile-menu-toggle{-webkit-tap-highlight-color:transparent;align-items:center;background:none;border:none;cursor:pointer;display:flex!important;flex-direction:column;gap:6px;justify-content:center;min-height:44px;min-width:44px;padding:10px;position:relative;touch-action:manipulation;z-index:1002}.mobile-menu-toggle span{background:#374151;border-radius:2px;display:block;height:2.5px;transition:all .3s;width:24px}.mobile-menu-toggle.open span:first-child{transform:rotate(45deg) translate(5px,5px)}.mobile-menu-toggle.open span:nth-child(2){opacity:0}.mobile-menu-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.nav-overlay{background:#0000004d;inset:0;position:fixed;z-index:999}@media (min-width:1024px){.nav-inner{padding:0 1.5rem}.nav-logo{height:32px}.brand-text{font-size:1.25rem}.mobile-menu-toggle{display:none!important}.nav-links{align-items:center;background:#0000;box-shadow:none;flex:1 1;flex-direction:row;gap:.25rem;height:auto;max-width:none;overflow:visible;padding:0;position:static;transform:none;width:auto}.mobile-close-btn,.mobile-nav-header,.mobile-role-switcher{display:none}.desktop-role-switcher{display:flex}.nav-link{border-radius:8px;font-size:.9rem;min-height:auto;padding:.5rem .75rem}.nav-link.active:after{background:#2563eb;border-radius:2px;bottom:-1px;content:"";display:block;height:2px;left:50%;position:absolute;transform:translateX(-50%);width:60%}.nav-divider{height:24px;margin:0 .25rem;width:1px}.nav-spacer{display:flex;flex:1 1}.nav-logout-btn{margin-top:0;min-height:auto;width:auto}.nav-cta-btn{display:inline-block;min-height:auto;padding:.5rem 1.25rem}}.mobile-menu-toggle:focus-visible,.nav-link:focus-visible,.nav-logout-btn:focus-visible,.role-btn:focus-visible{outline:2px solid #2563eb;outline-offset:2px}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;transition-duration:.01ms!important}}.notif-bell-btn,.notif-bell-wrapper{align-items:center;display:flex;position:relative}.notif-bell-btn{background:none;border:none;border-radius:8px;cursor:pointer;font-size:1.2rem;justify-content:center;min-height:44px;min-width:44px;padding:.5rem;transition:background .15s}.notif-bell-btn:hover{background:#f3f4f6}.notif-badge{align-items:center;background:#dc2626;border-radius:8px;color:#fff;display:flex;font-size:.6rem;font-weight:700;height:16px;justify-content:center;line-height:1;min-width:16px;padding:0 3px;position:absolute;right:2px;top:4px}.notif-dropdown{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 8px 30px #00000026;left:.5rem;max-height:400px;overflow:hidden;position:fixed;right:.5rem;top:64px;width:auto;z-index:1100}.notif-dropdown-header{align-items:center;border-bottom:1px solid #f3f4f6;color:#1f2937;display:flex;font-size:.9rem;font-weight:600;justify-content:space-between;padding:.75rem 1rem}.notif-mark-all{background:none;border:none;border-radius:4px;color:#2563eb;cursor:pointer;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.notif-mark-all:hover{background:#eff6ff}.notif-empty{color:#9ca3af;font-size:.85rem;padding:2rem;text-align:center}.notif-list{max-height:340px;overflow-y:auto}.notif-item{border-bottom:1px solid #f9fafb;cursor:pointer;padding:.75rem 1rem;transition:background .1s}.notif-item:hover{background:#f9fafb}.notif-item.unread{background:#eff6ff;border-left:3px solid #2563eb}.notif-item.read{opacity:.7}.notif-item-title{color:#1f2937;font-size:.8rem;font-weight:600;margin-bottom:.15rem}.notif-item-msg{color:#6b7280;font-size:.75rem;line-height:1.3}@media (min-width:768px){.notif-dropdown{left:auto;position:absolute;right:0;top:100%;width:320px}}.footer{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-dark) 100%);color:#fff;margin-top:auto;padding:var(--space-px-60) 0 var(--space-px-20) 0}.footer-container{margin:0 auto;max-width:var(--breakpoint-xl);padding:0 var(--space-px-20)}.footer-content{grid-gap:var(--space-px-40);display:grid;gap:var(--space-px-40);grid-template-columns:2fr 1fr 1fr 1fr;margin-bottom:var(--space-px-40)}.footer-section{display:flex;flex-direction:column}.footer-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#fffc);-webkit-background-clip:text;background-clip:text;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);margin:0 0 var(--space-lg) 0}.footer-description{font-size:var(--font-size-base);line-height:var(--line-height-relaxed);margin:0;opacity:.9}.footer-heading{color:#fff;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0 0 var(--space-lg) 0}.footer-links{list-style:none;margin:0;padding:0}.footer-links li{margin-bottom:var(--space-sm)}.footer-links a{color:#fffc;font-size:var(--font-size-base);text-decoration:none;transition:color .3s ease}.footer-links a:hover{color:#fff}.footer-bottom{border-top:1px solid #fff3;padding-top:var(--space-px-20);text-align:center}.footer-bottom p{font-size:var(--font-size-sm);margin:0;opacity:.8}.footer-content{grid-template-columns:1fr}.footer-content,.footer-description,.footer-section,.footer-title{text-align:center}@media (min-width:768px){.footer-content{grid-template-columns:2fr 1fr 1fr 1fr;text-align:left}.footer-description,.footer-section,.footer-title{text-align:left}}.msg-preview{align-items:center;animation:msg-slide-up .3s ease-out;background:#fff;border:1px solid #e5e7eb;border-radius:14px;bottom:1rem;bottom:var(--space-lg,1rem);box-shadow:0 8px 30px #00000026;cursor:pointer;display:flex;gap:.75rem;gap:var(--space-md,.75rem);left:1rem;left:var(--space-lg,1rem);padding:.75rem 1rem;padding:var(--space-md,.75rem) var(--space-lg,1rem);position:fixed;right:1rem;right:var(--space-lg,1rem);transition:transform .15s;z-index:9998}.msg-preview:hover{transform:translateY(-2px)}@keyframes msg-slide-up{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}.msg-preview-avatar{align-items:center;background:#eff6ff;border-radius:50%;color:#2563eb;display:flex;flex-shrink:0;font-size:.85rem;font-weight:700;height:40px;justify-content:center;width:40px}.msg-preview-body{flex:1 1;min-width:0}.msg-preview-sender{color:#1f2937;font-size:.875rem;font-weight:600}.msg-preview-text{color:#6b7280;font-size:.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msg-preview-close{background:none;border:none;color:#9ca3af;cursor:pointer;flex-shrink:0;font-size:1.3rem;padding:.25rem}.msg-preview-close:hover{color:#374151}@media (min-width:768px){.msg-preview{left:auto;max-width:400px}}.App{display:flex;flex-direction:column;min-height:100vh;text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:var(--color-bg-secondary);color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:var(--color-primary)}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:200px;padding:2rem}.loading-spinner{animation:spin 1s linear infinite;border-top:4px solid var(--color-bg-muted);border:4px solid var(--color-bg-muted);border-radius:var(--radius-full);border-top-color:var(--color-primary);height:var(--space-px-40);margin-bottom:1rem;width:var(--space-px-40)}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.auth-error-boundary{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:300px;padding:2rem;text-align:center}.login-button,.retry-button{border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-md);font-weight:var(--font-weight-medium);margin:var(--space-sm);padding:var(--space-md) var(--space-xl);transition:all .2s ease}.retry-button{background-color:var(--color-info);color:#fff;transition:all .3s ease}.retry-button:hover{background-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-1px)}.login-button{background-color:var(--color-text-muted);color:#fff;transition:all .3s ease}.login-button:hover{background-color:var(--color-text-secondary);box-shadow:var(--shadow-md);transform:translateY(-1px)}
/*# sourceMappingURL=main.c5000f20.css.map*/