.navbar{position:fixed;bottom:0;left:0;right:0;background:#12121af2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.08);z-index:100;padding-bottom:env(safe-area-inset-bottom)}.navbar-container{display:flex;justify-content:space-around;align-items:center;max-width:500px;margin:0 auto;padding:var(--spacing-sm) 0}.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--spacing-sm) var(--spacing-lg);color:var(--text-muted);transition:all var(--transition-fast);border-radius:var(--radius-md)}.nav-item span{font-size:var(--font-size-xs);font-weight:500}.nav-item:hover{color:var(--text-secondary)}.nav-item.active{color:var(--accent-purple)}.nav-item.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:40px;height:3px;background:var(--accent-gradient);border-radius:0 0 var(--radius-sm) var(--radius-sm)}.landing-page{min-height:100vh;overflow-x:hidden}.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:var(--spacing-3xl) 0;overflow:hidden}.hero-bg-glow{position:absolute;top:-50%;left:-20%;width:80%;height:100%;background:radial-gradient(circle,rgba(168,85,247,.15) 0%,transparent 60%);pointer-events:none}.hero-bg-glow:after{content:"";position:absolute;top:30%;right:-40%;width:60%;height:80%;background:radial-gradient(circle,rgba(34,211,238,.1) 0%,transparent 60%)}.hero-content{max-width:600px;position:relative;z-index:1}.hero-badge{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#a855f726;border:1px solid rgba(168,85,247,.3);border-radius:var(--radius-full);color:var(--accent-purple-light);font-size:var(--font-size-sm);font-weight:500;margin-bottom:var(--spacing-lg)}.hero-title{font-size:var(--font-size-5xl);font-weight:800;line-height:1.1;margin-bottom:var(--spacing-lg)}@media(max-width:768px){.hero-title{font-size:var(--font-size-3xl)}}.hero-subtitle{font-size:var(--font-size-lg);color:var(--text-secondary);margin-bottom:var(--spacing-xl);line-height:1.7}.hero-cta{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.hero-visual{position:absolute;right:5%;top:50%;transform:translateY(-50%);width:300px;height:400px}@media(max-width:1024px){.hero-visual{display:none}}.floating-card{position:absolute;width:80px;height:80px;background:var(--bg-card);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:2rem;box-shadow:var(--shadow-lg)}.floating-card svg{color:var(--accent-purple)}.card-1{top:10%;left:20%}.card-2{top:40%;right:10%}.card-3{bottom:20%;left:30%}.features{padding:var(--spacing-3xl) 0;background:var(--bg-secondary)}.section-title{font-size:var(--font-size-2xl);font-weight:700;text-align:center;margin-bottom:var(--spacing-2xl)}.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-lg)}@media(max-width:1024px){.features-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.features-grid{grid-template-columns:1fr}}.feature-card{padding:var(--spacing-xl);text-align:center}.feature-icon{width:60px;height:60px;margin:0 auto var(--spacing-md);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#22d3ee33,#22d3ee0d);border-radius:var(--radius-lg);color:var(--accent-cyan)}.feature-icon.icon-purple{background:linear-gradient(135deg,#a855f733,#a855f70d);color:var(--accent-purple)}.feature-icon.icon-pink{background:linear-gradient(135deg,#ec489933,#ec48990d);color:var(--accent-pink)}.feature-icon.icon-cyan{background:linear-gradient(135deg,#22d3ee33,#22d3ee0d);color:var(--accent-cyan)}.feature-card h3{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-sm)}.feature-card p{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.6}.stats{padding:var(--spacing-3xl) 0}.stats-grid{display:flex;justify-content:center;gap:var(--spacing-3xl);flex-wrap:wrap}.stat-item{text-align:center}.stat-number{display:block;font-size:var(--font-size-4xl);font-weight:800;margin-bottom:var(--spacing-sm)}.stat-label{font-size:var(--font-size-sm);color:var(--text-secondary)}.final-cta{padding:var(--spacing-3xl) 0}.cta-card{text-align:center;padding:var(--spacing-3xl);border-radius:var(--radius-xl)}.cta-icon{color:var(--accent-purple);margin-bottom:var(--spacing-lg)}.cta-card h2{font-size:var(--font-size-2xl);font-weight:700;margin-bottom:var(--spacing-sm)}.cta-card p{color:var(--text-secondary);margin-bottom:var(--spacing-xl)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-primary) 0%,#1a1a2e 100%);padding:var(--spacing-lg)}.login-container{width:100%;max-width:400px;text-align:center}.login-header{margin-bottom:var(--spacing-3xl)}.login-icon{color:var(--accent-purple);margin-bottom:var(--spacing-md)}.login-header h1{font-size:var(--font-size-3xl);font-weight:700;background:linear-gradient(135deg,var(--accent-purple),var(--accent-pink));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--spacing-xs)}.login-header p{color:var(--text-secondary);font-size:var(--font-size-sm)}.login-content{background:var(--bg-card);border-radius:var(--radius-xl);padding:var(--spacing-xl);border:1px solid rgba(255,255,255,.1)}.login-content h2{font-size:var(--font-size-xl);margin-bottom:var(--spacing-xs)}.login-subtitle{color:var(--text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-lg)}.login-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--error);padding:var(--spacing-sm);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-size:var(--font-size-sm)}.btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:#fff;color:#333;font-weight:600;font-size:var(--font-size-base);border-radius:var(--radius-md);transition:all var(--transition-fast)}.btn-google:hover:not(:disabled){background:#f5f5f5;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.btn-google:disabled{opacity:.7;cursor:not-allowed}.login-terms{font-size:var(--font-size-xs);color:var(--text-muted);margin-top:var(--spacing-md)}.login-footer{margin-top:var(--spacing-xl)}.btn-skip{color:var(--text-secondary);font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-md);transition:color var(--transition-fast)}.btn-skip:hover{color:var(--accent-purple)}.auth-tabs{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.auth-tab{flex:1;padding:var(--spacing-sm);font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);background:transparent;border-bottom:2px solid transparent;transition:all var(--transition-fast)}.auth-tab.active{color:var(--accent-purple);border-bottom-color:var(--accent-purple)}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.form-group{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-hover);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md)}.form-group svg{color:var(--text-muted);flex-shrink:0}.form-group input{flex:1;background:transparent;border:none;color:var(--text-primary);font-size:var(--font-size-base);outline:none}.form-group input::placeholder{color:var(--text-muted)}.btn-email{width:100%;padding:var(--spacing-md);background:linear-gradient(135deg,var(--accent-purple),var(--accent-pink));color:#fff;font-weight:600;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);transition:all var(--transition-fast)}.btn-email:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-email:disabled{opacity:.7}.divider{display:flex;align-items:center;margin:var(--spacing-lg) 0}.divider:before,.divider:after{content:"";flex:1;height:1px;background:#ffffff1a}.divider span{padding:0 var(--spacing-md);color:var(--text-muted);font-size:var(--font-size-sm)}.clothing-card{overflow:hidden;cursor:pointer}.clothing-image{aspect-ratio:3 / 4;overflow:hidden;background:var(--bg-hover)}.clothing-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-base)}.clothing-card:hover .clothing-image img{transform:scale(1.05)}.clothing-info{padding:var(--spacing-sm) var(--spacing-md)}.clothing-name{font-size:var(--font-size-sm);font-weight:500;margin-bottom:var(--spacing-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.clothing-category{font-size:var(--font-size-xs);color:var(--text-muted)}.clothing-card.unavailable{opacity:.6}.clothing-card.unavailable .clothing-image img{filter:grayscale(100%)}.unavailable-badge{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000b3;color:#fff;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);white-space:nowrap}.clothing-image{position:relative}.availability-toggle{width:100%;padding:var(--spacing-xs);font-size:var(--font-size-xs);border-radius:0;transition:all var(--transition-fast)}.availability-toggle.available{background:#22c55e33;color:var(--success)}.availability-toggle.available:hover,.availability-toggle.unavailable{background:#ef444433;color:var(--error)}.availability-toggle.unavailable:hover{background:#22c55e33;color:var(--success)}.edit-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-xs);background:#0009;color:#fff;opacity:0;transition:opacity var(--transition-fast);font-size:var(--font-size-sm);font-weight:500}.clothing-card:hover .edit-overlay{opacity:1}.upload-modal{max-height:90vh}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid rgba(255,255,255,.08)}.modal-header h2{font-size:var(--font-size-lg);font-weight:600}.modal-close{color:var(--text-secondary);transition:color var(--transition-fast)}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:var(--spacing-lg)}.modal-footer{display:flex;gap:var(--spacing-md);justify-content:flex-end;padding:var(--spacing-lg);border-top:1px solid rgba(255,255,255,.08)}.upload-zone{position:relative;border:2px dashed rgba(255,255,255,.15);border-radius:var(--radius-lg);padding:var(--spacing-2xl);text-align:center;transition:all var(--transition-fast);cursor:pointer;margin-bottom:var(--spacing-lg)}.upload-zone:hover,.upload-zone.active{border-color:var(--accent-purple);background:#a855f70d}.upload-icon{color:var(--accent-purple);margin-bottom:var(--spacing-md)}.upload-text{font-size:var(--font-size-base);font-weight:500;margin-bottom:var(--spacing-xs)}.upload-subtext{font-size:var(--font-size-sm);color:var(--text-muted)}.upload-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.preview-zone{position:relative;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--spacing-lg);background:var(--bg-hover)}.preview-image{width:100%;max-height:300px;object-fit:contain;display:block}.clear-preview{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:#000000b3;border-radius:var(--radius-sm);color:#fff;font-size:var(--font-size-xs)}.ai-result{padding:var(--spacing-md);background:#a855f71a;border-top:1px solid rgba(168,85,247,.2)}.ai-result-header{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--accent-purple);font-size:var(--font-size-sm);font-weight:600;margin-bottom:var(--spacing-sm)}.ai-result-content{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.ai-tag{padding:var(--spacing-xs) var(--spacing-sm);background:var(--accent-gradient);border-radius:var(--radius-full);font-size:var(--font-size-xs);color:#fff}.ai-name{font-size:var(--font-size-sm);color:var(--text-primary);font-weight:500}.preview-section{margin-bottom:var(--spacing-lg)}.upload-form{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-hover);border-radius:var(--radius-md);margin-top:var(--spacing-md)}.upload-form .form-group{display:flex;flex-direction:column;gap:var(--spacing-xs);flex:1}.upload-form .form-row{display:flex;gap:var(--spacing-md)}.upload-form label{font-size:var(--font-size-xs);color:var(--text-muted);font-weight:500}.upload-form input,.upload-form select{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-card);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--font-size-sm)}.upload-form input:focus,.upload-form select:focus{outline:none;border-color:var(--accent-purple)}.upload-form input::placeholder{color:var(--text-muted)}.btn-ai{background:linear-gradient(135deg,#8b5cf6,#ec4899);color:#fff;display:flex;align-items:center;gap:var(--spacing-xs)}.btn-ai:hover:not(:disabled){opacity:.9}.btn-ai:disabled{opacity:.7}.upload-success{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#22c55ee6;color:#fff;gap:var(--spacing-sm);font-weight:600}.upload-error{padding:var(--spacing-md);background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:var(--error);font-size:var(--font-size-sm);margin-bottom:var(--spacing-lg);text-align:center}.upload-actions{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);position:relative}.upload-action{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--bg-hover);border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast)}.upload-action:hover{background:var(--accent-purple);color:#fff}.upload-tips{background:var(--bg-hover);border-radius:var(--radius-md);padding:var(--spacing-md)}.upload-tips h4{font-size:var(--font-size-sm);font-weight:600;margin-bottom:var(--spacing-sm);color:var(--accent-cyan)}.upload-tips ul{list-style:none}.upload-tips li{font-size:var(--font-size-sm);color:var(--text-secondary);padding-left:var(--spacing-md);position:relative;margin-bottom:var(--spacing-xs)}.upload-tips li:before{content:"•";position:absolute;left:0;color:var(--accent-purple)}.edit-clothing-modal{max-width:420px}.edit-preview{width:150px;height:150px;margin:0 auto var(--spacing-lg);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-hover)}.edit-preview img{width:100%;height:100%;object-fit:cover}.edit-clothing-modal .form-group{margin-bottom:var(--spacing-md)}.edit-clothing-modal .form-group label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.edit-clothing-modal .form-group input,.edit-clothing-modal .form-group select{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-hover);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-base)}.edit-clothing-modal .form-group input:focus,.edit-clothing-modal .form-group select:focus{outline:none;border-color:var(--accent-purple)}.edit-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--error);padding:var(--spacing-sm);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-size:var(--font-size-sm);text-align:center}.edit-clothing-modal .modal-footer{display:flex;gap:var(--spacing-md);justify-content:flex-end;margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid rgba(255,255,255,.08)}.edit-clothing-modal .btn-primary{background:linear-gradient(135deg,var(--accent-purple),var(--accent-pink));color:#fff;display:flex;align-items:center;gap:var(--spacing-xs)}.edit-clothing-modal .btn-secondary{background:var(--bg-hover);color:var(--text-secondary)}.closet-page{background:var(--bg-primary)}.closet-header{position:sticky;top:0;background:var(--bg-primary);padding:var(--spacing-lg) 0 var(--spacing-md);z-index:50;border-bottom:1px solid rgba(255,255,255,.05)}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.header-top .page-title{margin:0}.header-actions{display:flex;gap:var(--spacing-sm)}.btn-danger{background:var(--error);color:#fff}.search-bar{position:relative;margin-bottom:var(--spacing-md)}.search-bar input{width:100%;background:var(--bg-card);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);padding:var(--spacing-md) var(--spacing-md) var(--spacing-md) 48px;color:var(--text-primary);font-size:var(--font-size-base);transition:all var(--transition-fast)}.search-bar input:focus{outline:none;border-color:var(--accent-purple);box-shadow:0 0 0 3px #a855f71a}.search-bar input::placeholder{color:var(--text-muted)}.search-icon{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--text-muted)}.category-tabs{display:flex;gap:var(--spacing-sm);overflow-x:auto;padding-bottom:var(--spacing-sm);scrollbar-width:none}.category-tabs::-webkit-scrollbar{display:none}.closet-content{padding:var(--spacing-lg) 0}.closet-stats{display:flex;justify-content:space-between;align-items:center;font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--spacing-md)}.delete-hint{color:var(--error);font-weight:500}.clothes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}@media(max-width:768px){.clothes-grid{grid-template-columns:repeat(2,1fr)}}.empty-state{text-align:center;padding:var(--spacing-3xl) var(--spacing-lg);color:var(--text-muted)}.empty-state svg{margin-bottom:var(--spacing-md);opacity:.5}.empty-state p{margin-bottom:var(--spacing-lg)}.clothing-wrapper{position:relative}.clothing-wrapper.delete-mode{cursor:pointer}.delete-overlay{position:absolute;inset:0;background:#ef4444cc;display:flex;align-items:center;justify-content:center;color:#fff;border-radius:var(--radius-md);opacity:0;transition:opacity var(--transition-fast)}.clothing-wrapper.delete-mode:hover .delete-overlay{opacity:1}.outfit-page{background:var(--bg-primary)}.outfit-header{padding:var(--spacing-xl) 0 var(--spacing-md)}.outfit-header .page-title{display:flex;align-items:center;gap:var(--spacing-sm);justify-content:center}.weather-section{padding:0 0 var(--spacing-lg)}.weather-widget{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-lg);background:linear-gradient(135deg,#22d3ee26,#a855f726);border-radius:var(--radius-xl);border:1px solid rgba(255,255,255,.1)}.weather-icon-large{color:var(--accent-cyan)}.weather-details{flex:1}.weather-temp{font-size:var(--font-size-3xl);font-weight:700;line-height:1}.weather-condition{font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:var(--spacing-xs)}.weather-meta{display:flex;flex-direction:column;gap:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--text-muted)}.weather-location,.weather-humidity{display:flex;align-items:center;gap:var(--spacing-xs)}.weather-live{font-size:10px;color:var(--success);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.location-retry{display:flex;align-items:center;gap:var(--spacing-xs);font-size:10px;color:var(--accent-cyan);padding:2px 6px;background:#22d3ee1a;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.location-retry:hover{background:#22d3ee33}.occasion-section{padding-bottom:var(--spacing-lg)}.occasion-tabs{display:flex;gap:var(--spacing-sm);overflow-x:auto;scrollbar-width:none}.occasion-tabs::-webkit-scrollbar{display:none}.occasion-tab{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary);background:var(--bg-card);border:1px solid transparent;white-space:nowrap;transition:all var(--transition-fast)}.occasion-tab:hover{color:var(--text-primary);border-color:#ffffff1a}.occasion-tab.active{background:var(--accent-gradient);color:#fff;box-shadow:var(--shadow-glow-purple)}.outfit-main{padding:0 0 var(--spacing-xl)}.outfit-card{background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid rgba(255,255,255,.08);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.outfit-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.outfit-name{font-size:var(--font-size-lg);font-weight:600}.outfit-occasion{font-size:var(--font-size-sm);color:var(--accent-purple);background:#a855f726;padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full)}.outfit-items{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);overflow-x:auto;padding-bottom:var(--spacing-sm);min-height:180px}.outfit-item{flex:0 0 120px;text-align:center}.outfit-item img{width:120px;height:150px;object-fit:cover;border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);background:var(--bg-hover)}.item-name{font-size:var(--font-size-xs);color:var(--text-secondary);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.outfit-actions{display:flex;gap:var(--spacing-md)}.outfit-actions .btn{flex:1}.ai-tips{padding:var(--spacing-lg);border-radius:var(--radius-lg)}.tip-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm);color:var(--accent-purple);font-weight:600;font-size:var(--font-size-sm)}.ai-tips p{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.7}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);color:var(--accent-purple);gap:var(--spacing-md);width:100%}.loading-state p{font-size:var(--font-size-sm);color:var(--text-secondary)}.api-notice{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);font-size:var(--font-size-sm);color:var(--warning);flex-wrap:wrap}.notice-link{display:inline-flex;align-items:center;gap:var(--spacing-xs);margin-left:auto;color:var(--accent-cyan);font-weight:500}.notice-link:hover{text-decoration:underline}.error-message{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);font-size:var(--font-size-sm);color:var(--error)}.refresh-advice{margin-left:auto;color:var(--text-muted);padding:var(--spacing-xs);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.refresh-advice:hover{color:var(--accent-purple);background:#a855f71a}.custom-occasion{margin-top:var(--spacing-md)}.custom-occasion-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-card);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-sm)}.custom-occasion-input:focus{border-color:var(--accent-purple);outline:none}.custom-occasion-input::placeholder{color:var(--text-muted)}.btn-tryon{width:100%;margin-top:var(--spacing-md);background:linear-gradient(135deg,#06c755,#00b894);color:#fff;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.btn-tryon:hover{opacity:.9;transform:translateY(-1px)}.calendar-page{background:var(--bg-primary)}.calendar-header{padding:var(--spacing-xl) 0 var(--spacing-lg)}.calendar-nav{display:flex;align-items:center;justify-content:center;gap:var(--spacing-lg)}.nav-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast)}.nav-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.calendar-title{font-size:var(--font-size-xl);font-weight:600;min-width:150px;text-align:center}.calendar-main{padding:0 0 var(--spacing-xl)}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:var(--spacing-sm)}.weekday{text-align:center;font-size:var(--font-size-sm);font-weight:500;color:var(--text-muted);padding:var(--spacing-sm) 0}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;background:var(--bg-secondary);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--spacing-lg)}.calendar-day{aspect-ratio:1;background:var(--bg-card);padding:var(--spacing-xs);display:flex;flex-direction:column;cursor:pointer;transition:all var(--transition-fast);position:relative}.calendar-day:hover{background:var(--bg-hover)}.calendar-day.empty{background:var(--bg-primary);cursor:default}.calendar-day.today{background:#a855f71a}.calendar-day.today .day-number{background:var(--accent-purple);color:#fff;border-radius:var(--radius-full);width:24px;height:24px;display:flex;align-items:center;justify-content:center}.day-number{font-size:var(--font-size-xs);font-weight:500;margin-bottom:var(--spacing-xs)}.day-outfit{flex:1;border-radius:var(--radius-sm);overflow:hidden}.day-outfit img{width:100%;height:100%;object-fit:cover}.day-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);opacity:0;transition:opacity var(--transition-fast)}.calendar-day:hover .day-empty{opacity:1}.calendar-stats{display:flex;justify-content:space-around;padding:var(--spacing-lg);border-radius:var(--radius-lg)}.stat{text-align:center}.stat-value{display:block;font-size:var(--font-size-2xl);font-weight:700;margin-bottom:var(--spacing-xs)}.stat-label{font-size:var(--font-size-xs);color:var(--text-secondary)}@media(max-width:480px){.calendar-day{padding:2px}.day-number{font-size:10px}}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl);color:var(--accent-purple);gap:var(--spacing-md)}.login-required{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl);text-align:center;color:var(--text-muted);gap:var(--spacing-md)}.outfit-modal{max-width:500px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.outfit-modal .modal-body{overflow-y:auto;flex:1}.modal-hint{color:var(--text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-md)}.clothes-select-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm)}.clothes-select-item{position:relative;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all var(--transition-fast)}.clothes-select-item:hover{border-color:#a855f74d}.clothes-select-item.selected{border-color:var(--accent-purple)}.clothes-select-item img{width:100%;aspect-ratio:3/4;object-fit:cover}.clothes-select-item .item-name{display:block;font-size:var(--font-size-xs);padding:var(--spacing-xs);text-align:center;background:var(--bg-hover);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.selected-check{position:absolute;top:4px;right:4px;color:var(--success);background:#fff;border-radius:50%}.empty-clothes{text-align:center;padding:var(--spacing-2xl);color:var(--text-muted)}.empty-clothes svg{margin-bottom:var(--spacing-md);opacity:.5}.btn-danger{background:var(--error);color:#fff;margin-right:auto}.btn-danger:hover{background:#dc2626}.share-modal{max-width:400px}.share-modal .modal-header h2{display:flex;align-items:center;gap:var(--spacing-sm)}.share-preview{background:var(--bg-hover);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-lg)}.share-preview p{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.6}.share-buttons{display:flex;gap:var(--spacing-md);justify-content:center;margin-bottom:var(--spacing-lg)}.share-btn{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md);background:var(--bg-hover);border-radius:var(--radius-lg);min-width:80px;transition:all var(--transition-fast)}.share-btn:hover{background:var(--share-color);color:#fff;transform:translateY(-2px)}.share-btn svg{color:var(--share-color)}.share-btn:hover svg{color:#fff}.share-btn span{font-size:var(--font-size-xs);font-weight:500}.copy-link-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--accent-gradient);border-radius:var(--radius-md);color:#fff;font-weight:500;transition:all var(--transition-fast);margin-bottom:var(--spacing-md)}.copy-link-btn:hover{opacity:.9;transform:scale(1.02)}.native-share-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--bg-hover);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-size-sm)}.native-share-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.tryon-page{background:var(--bg-primary)}.tryon-header{padding:var(--spacing-xl) 0 var(--spacing-md);text-align:center}.tryon-header .page-title{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.page-subtitle{color:var(--text-secondary);font-size:var(--font-size-sm);margin-top:var(--spacing-xs)}.tryon-main{padding:0 0 var(--spacing-xl)}.mannequin-area{display:flex;justify-content:center;margin-bottom:var(--spacing-xl)}.mannequin{position:relative;width:200px;height:400px;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs)}.mannequin-slot{width:100%;border-radius:var(--radius-md);overflow:hidden;background:var(--bg-card);border:2px dashed rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center}.mannequin-slot img{width:100%;height:100%;object-fit:cover}.mannequin-slot.outer{position:absolute;top:0;left:-40px;width:80px;height:120px;z-index:10}.mannequin-slot.top{height:140px}.mannequin-slot.bottom{height:160px}.mannequin-slot.shoes{height:60px}.mannequin-slot.accessory{position:absolute;top:0;right:-40px;width:60px;height:60px;z-index:10}.slot-placeholder{font-size:var(--font-size-xs);color:var(--text-muted);text-align:center}.slot-selectors{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.slot-selector{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs)}.slot-label{font-size:var(--font-size-xs);font-weight:600;color:var(--accent-purple)}.slot-controls{display:flex;align-items:center;gap:var(--spacing-xs)}.slot-nav{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition-fast)}.slot-nav:hover:not(:disabled){background:var(--accent-purple);color:#fff}.slot-nav:disabled{opacity:.3;cursor:not-allowed}.slot-current{width:60px;height:60px;border-radius:var(--radius-md);overflow:hidden;background:var(--bg-hover);display:flex;align-items:center;justify-content:center}.slot-current img{width:100%;height:100%;object-fit:cover}.no-item{font-size:var(--font-size-xs);color:var(--text-muted)}.slot-count{font-size:10px;color:var(--text-muted)}.ai-advice{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg)}.ai-advice svg{color:var(--accent-purple);flex-shrink:0;margin-top:2px}.ai-advice p{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.6}.tryon-actions{display:flex;gap:var(--spacing-md);justify-content:center;flex-wrap:wrap}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl);color:var(--accent-purple);gap:var(--spacing-md);min-height:60vh}.btn-share{background:linear-gradient(135deg,#06c755,#1da1f2);color:#fff}.btn-share:hover{opacity:.9}.btn-share:disabled{background:var(--bg-hover);color:var(--text-muted)}.ai-generated-image{margin-bottom:var(--spacing-xl);border-radius:var(--radius-xl);overflow:hidden;box-shadow:0 10px 40px #0000004d}.ai-generated-image img{width:100%;max-height:500px;object-fit:contain;background:#fff}.image-error{padding:var(--spacing-md);background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);color:var(--error);text-align:center}.btn-ai-tryon{width:100%;padding:var(--spacing-md);margin-bottom:var(--spacing-lg);background:linear-gradient(135deg,#8b5cf6,#ec4899);color:#fff;font-weight:600;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-fast)}.btn-ai-tryon:hover:not(:disabled){opacity:.9;transform:scale(1.02)}.btn-ai-tryon:disabled{background:var(--bg-hover);color:var(--text-muted)}.btn-history{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.btn-history:hover{opacity:.9}.history-modal{max-width:600px;max-height:80vh}.history-modal .modal-header h2{display:flex;align-items:center;gap:var(--spacing-sm)}.history-grid{display:grid;gap:var(--spacing-md);max-height:60vh;overflow-y:auto}.history-item{display:flex;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-hover);border-radius:var(--radius-md)}.history-item img{width:100px;height:100px;object-fit:cover;border-radius:var(--radius-sm)}.history-info{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.history-date{font-size:var(--font-size-sm);font-weight:600;color:var(--accent-purple)}.history-items{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.4}.btn-download{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--accent-gradient);color:#fff;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500;margin-top:var(--spacing-xs);text-decoration:none}.btn-download:hover{opacity:.9}.settings-page{background:var(--bg-primary)}.settings-header{padding:var(--spacing-xl) 0 var(--spacing-lg)}.settings-header .container{display:flex;align-items:center;justify-content:space-between}.settings-header .page-title{display:flex;align-items:center;gap:var(--spacing-sm)}.title-icon{color:var(--accent-purple)}.btn-install{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:linear-gradient(135deg,var(--accent-cyan),var(--accent-purple));color:#fff;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;transition:all var(--transition-base)}.btn-install:hover{transform:translateY(-2px);box-shadow:0 4px 12px #22d3ee4d}.install-modal{max-width:480px}.install-modal .modal-header h2{display:flex;align-items:center;gap:var(--spacing-sm)}.install-section h3{font-size:var(--font-size-lg);margin-bottom:var(--spacing-md)}.install-steps{list-style:none;counter-reset:step;padding:0;margin:0}.install-steps li{counter-increment:step;display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-sm) 0;font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.6}.install-steps li:before{content:counter(step);min-width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--accent-gradient);color:#fff;border-radius:var(--radius-full);font-weight:600;font-size:var(--font-size-xs);flex-shrink:0}.install-steps li strong{color:var(--text-primary)}.install-divider{display:flex;align-items:center;gap:var(--spacing-md);margin:var(--spacing-lg) 0;color:var(--text-muted)}.install-divider:before,.install-divider:after{content:"";flex:1;height:1px;background:#ffffff1a}.install-note{margin-top:var(--spacing-lg);padding:var(--spacing-md);background:#a855f71a;border-radius:var(--radius-md);text-align:center}.install-note p{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0}.settings-main{padding:0 0 var(--spacing-xl)}.settings-section{background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid rgba(255,255,255,.08);margin-bottom:var(--spacing-lg);overflow:hidden}.section-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg);border-bottom:1px solid rgba(255,255,255,.08);color:var(--accent-cyan)}.section-header h2{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary)}.section-content{padding:var(--spacing-lg)}.section-desc{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--spacing-lg);line-height:1.6}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.stat-card{text-align:center;padding:var(--spacing-lg);background:var(--bg-hover);border-radius:var(--radius-lg)}.stat-card svg{color:var(--accent-purple);margin-bottom:var(--spacing-sm)}.stat-card .stat-value{font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--spacing-xs)}.stat-card .stat-label{font-size:var(--font-size-xs);color:var(--text-muted)}.most-worn h4{font-size:var(--font-size-sm);font-weight:600;margin-bottom:var(--spacing-md);color:var(--accent-cyan)}.worn-items{display:flex;flex-direction:column;gap:var(--spacing-sm)}.worn-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm);background:var(--bg-hover);border-radius:var(--radius-md)}.worn-rank{font-size:var(--font-size-lg);font-weight:700;color:var(--accent-purple);width:32px}.worn-item img{width:48px;height:48px;object-fit:cover;border-radius:var(--radius-sm)}.worn-info{flex:1}.worn-name{display:block;font-size:var(--font-size-sm);font-weight:500}.worn-count{font-size:var(--font-size-xs);color:var(--text-muted)}.loading-mini{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-lg);color:var(--text-secondary)}.empty-stats{text-align:center;padding:var(--spacing-lg);color:var(--text-muted);font-size:var(--font-size-sm)}.status-card{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-lg);border-radius:var(--radius-lg);flex-wrap:wrap}.status-card.success{background:#22c55e1a;border:1px solid rgba(34,197,94,.3)}.status-card.warning{background:#f59e0b1a;border:1px solid rgba(245,158,11,.3)}.status-card.success .status-icon{color:var(--success)}.status-card.warning .status-icon{color:var(--warning)}.status-info{flex:1;min-width:200px}.status-info h3{font-size:var(--font-size-base);font-weight:600;margin-bottom:var(--spacing-xs)}.status-info p{font-size:var(--font-size-sm);color:var(--text-secondary)}.setup-steps{list-style:none;counter-reset:step;margin-bottom:var(--spacing-lg)}.setup-steps li{counter-increment:step;display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md) 0;border-bottom:1px solid rgba(255,255,255,.05)}.setup-steps li:before{content:counter(step);width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--accent-gradient);color:#fff;border-radius:var(--radius-full);font-weight:600;font-size:var(--font-size-sm);flex-shrink:0;margin-bottom:var(--spacing-sm)}.step-title{font-weight:500;color:var(--text-primary)}.step-link{display:inline-flex;align-items:center;gap:var(--spacing-xs);color:var(--accent-cyan);font-size:var(--font-size-sm)}.step-link:hover{text-decoration:underline}.step-code{display:block;background:var(--bg-hover);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-family:monospace;font-size:var(--font-size-sm);color:var(--accent-purple-light);overflow-x:auto}.step-note{font-size:var(--font-size-sm);color:var(--text-muted)}.help-note{padding:var(--spacing-md);background:#a855f71a;border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.6}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}}.user-profile{display:flex;align-items:center;gap:var(--spacing-lg);flex-wrap:wrap}.user-avatar{width:80px;height:80px;border-radius:50%;overflow:hidden;flex-shrink:0}.user-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent-purple),var(--accent-pink));color:#fff;font-size:var(--font-size-2xl);font-weight:700}.user-info{flex:1;min-width:150px}.user-name{font-size:var(--font-size-lg);font-weight:600;display:flex;align-items:center;gap:var(--spacing-sm)}.user-name button{color:var(--text-muted);padding:var(--spacing-xs)}.user-name button:hover{color:var(--accent-purple)}.user-email{font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:var(--spacing-xs)}.edit-name{display:flex;align-items:center;gap:var(--spacing-sm)}.edit-name input{flex:1;padding:var(--spacing-sm);background:var(--bg-hover);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-base)}.edit-name button{padding:var(--spacing-sm);background:var(--accent-purple);color:#fff;border-radius:var(--radius-md)}.btn-logout{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.3);display:flex;align-items:center;gap:var(--spacing-sm);margin-left:auto}.btn-logout:hover{background:#ef444433}.not-logged-in{text-align:center;padding:var(--spacing-xl)}.not-logged-in p{color:var(--text-secondary);margin-bottom:var(--spacing-lg)}.gender-selector{margin-top:var(--spacing-lg);width:100%}.gender-selector label{display:block;font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.gender-options{display:flex;gap:var(--spacing-sm)}.gender-btn{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-hover);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-size-sm);transition:all var(--transition-fast)}.gender-btn:hover{border-color:#fff3}.gender-btn.active{background:linear-gradient(135deg,var(--accent-purple),var(--accent-pink));color:#fff;border-color:transparent}:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-card: #1a1a24;--bg-hover: #252532;--text-primary: #ffffff;--text-secondary: #a0a0b0;--text-muted: #606070;--accent-purple: #a855f7;--accent-purple-light: #c084fc;--accent-cyan: #22d3ee;--accent-cyan-light: #67e8f9;--accent-pink: #ec4899;--accent-gradient: linear-gradient(135deg, var(--accent-purple), var(--accent-cyan));--success: #22c55e;--warning: #f59e0b;--error: #ef4444;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", 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: 2rem;--font-size-4xl: 2.5rem;--font-size-5xl: 3.5rem;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--radius-sm: .375rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .5);--shadow-glow-purple: 0 0 20px rgba(168, 85, 247, .4);--shadow-glow-cyan: 0 0 20px rgba(34, 211, 238, .4);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-family);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.text-gradient{background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.glass{background:#1a1a24cc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);transition:all var(--transition-base);white-space:nowrap}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:var(--shadow-glow-purple)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 30px #a855f799}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid rgba(255,255,255,.1)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--accent-purple)}.btn-lg{padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-base);border-radius:var(--radius-lg)}.card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.05);overflow:hidden;transition:all var(--transition-base)}.card:hover{border-color:#a855f74d;transform:translateY(-4px);box-shadow:var(--shadow-lg)}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md)}@media(max-width:768px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.page{padding-bottom:80px;min-height:100vh}.page-header{padding:var(--spacing-xl) 0;text-align:center}.page-title{font-size:var(--font-size-2xl);font-weight:700;margin-bottom:var(--spacing-sm)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.animate-fade-in{animation:fadeIn .5s ease forwards}.animate-pulse{animation:pulse 2s infinite}.animate-float{animation:float 3s ease-in-out infinite}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-hover);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--accent-purple)}.badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:500;background:#a855f733;color:var(--accent-purple-light)}.tag{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:var(--font-size-sm);background:var(--bg-hover);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.tag:hover,.tag.active{background:var(--accent-purple);color:#fff}.modal-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.modal-content{background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid rgba(255,255,255,.1);width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.weather-widget{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:linear-gradient(135deg,#22d3ee26,#a855f726);border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.1)}.weather-temp{font-size:var(--font-size-3xl);font-weight:700}.weather-info{display:flex;flex-direction:column;gap:var(--spacing-xs)}.login-required{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl);text-align:center;color:var(--text-muted);gap:var(--spacing-md);min-height:50vh}.login-required h2{color:var(--text-primary);font-size:var(--font-size-xl);margin:0}.login-required p{color:var(--text-secondary);margin:0 0 var(--spacing-md) 0}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl);color:var(--accent-purple);gap:var(--spacing-md);min-height:50vh}.loading-state p{color:var(--text-secondary)}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
