.header{position:sticky;top:0;z-index:var(--z-sticky);background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--glass-border);padding:var(--space-md) 0}.header-content{display:flex;align-items:center;justify-content:space-between;gap:var(--space-lg)}.logo{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);text-decoration:none;transition:transform var(--transition-fast)}.logo:hover{transform:scale(1.05)}.logo-icon{font-size:var(--font-size-2xl)}.logo-text{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav{display:flex;align-items:center;gap:var(--space-lg);flex:1;margin-left:var(--space-2xl)}.nav-link{color:var(--color-text-secondary);font-weight:var(--font-weight-medium);transition:color var(--transition-fast);position:relative}.nav-link:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--gradient-primary);transition:width var(--transition-fast)}.nav-link:hover{color:var(--color-text-primary)}.nav-link:hover:after{width:100%}.header-actions,.user-menu{display:flex;align-items:center;gap:var(--space-md)}.user-profile{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);background:var(--color-surface);transition:all var(--transition-fast)}.user-profile:hover{background:var(--color-surface-hover);transform:translateY(-2px)}.user-avatar,.user-avatar-placeholder{width:32px;height:32px;border-radius:var(--radius-full);object-fit:cover}.user-avatar-placeholder{display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);color:#fff;font-weight:var(--font-weight-bold);font-size:var(--font-size-sm)}.user-name{color:var(--color-text-primary);font-weight:var(--font-weight-medium)}@media(max-width:768px){.nav,.logo-text,.user-name{display:none}}.footer{margin-top:var(--space-3xl);padding:var(--space-3xl) 0 var(--space-xl);background:var(--color-bg-secondary);border-top:1px solid var(--color-border)}.footer-content{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--space-2xl);margin-bottom:var(--space-2xl)}.footer-section{display:flex;flex-direction:column;gap:var(--space-md)}.footer-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:0}.footer-description{color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.6;margin-bottom:0}.footer-heading{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-primary);margin-bottom:var(--space-xs)}.footer-links{list-style:none;display:flex;flex-direction:column;gap:var(--space-sm)}.footer-links a{color:var(--color-text-secondary);font-size:var(--font-size-sm);transition:color var(--transition-fast)}.footer-links a:hover{color:var(--color-primary-light)}.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:var(--space-xl);border-top:1px solid var(--color-border)}.footer-copyright{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-bottom:0}.footer-legal{display:flex;align-items:center;gap:var(--space-md)}.footer-legal a{color:var(--color-text-muted);font-size:var(--font-size-sm);transition:color var(--transition-fast)}.footer-legal a:hover{color:var(--color-text-secondary)}.footer-separator{color:var(--color-text-muted)}@media(max-width:1024px){.footer-content{grid-template-columns:1fr 1fr}}@media(max-width:640px){.footer-content{grid-template-columns:1fr}.footer-bottom{flex-direction:column;gap:var(--space-md);text-align:center}}.home-page{width:100%}.hero{padding:var(--space-3xl) 0;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 50% 0%,hsla(210,100%,50%,.1) 0%,transparent 50%);pointer-events:none}.hero-content{max-width:800px;margin:0 auto;text-align:center;position:relative;z-index:1}.hero-title{font-size:var(--font-size-4xl);line-height:1.1;margin-bottom:var(--space-lg)}.gradient-text{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:var(--font-size-lg);color:var(--color-text-secondary);margin-bottom:var(--space-2xl);line-height:1.6}.hero-actions{display:flex;gap:var(--space-md);justify-content:center;flex-wrap:wrap}.features{padding:var(--space-3xl) 0}.section-title{margin-bottom:var(--space-2xl)}.feature-card{text-align:center;padding:var(--space-xl)}.feature-icon{font-size:3rem;margin-bottom:var(--space-md)}.feature-card h3{margin-bottom:var(--space-md);color:var(--color-text-primary)}.feature-card p{color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.6}.stats{padding:var(--space-3xl) 0;background:var(--color-bg-secondary)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-lg)}.stat-card{text-align:center;padding:var(--space-xl)}.stat-number{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-sm)}.stat-label{color:var(--color-text-secondary);font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.5px}.cta{padding:var(--space-3xl) 0}.cta-card{text-align:center;padding:var(--space-3xl) var(--space-2xl);max-width:800px;margin:0 auto}.cta-title{margin-bottom:var(--space-md)}.cta-description{font-size:var(--font-size-lg);color:var(--color-text-secondary);margin-bottom:var(--space-2xl);line-height:1.6}.cta-actions{display:flex;gap:var(--space-md);justify-content:center;flex-wrap:wrap}@media(max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.hero-title{font-size:var(--font-size-3xl)}.hero-subtitle{font-size:var(--font-size-base)}.stats-grid{grid-template-columns:1fr}.stat-number{font-size:var(--font-size-3xl)}}.vote-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.vote-button:hover{background:#ffffff1a;border-color:#fff3;transform:translateY(-2px)}.vote-button:active{transform:translateY(0)}.vote-button.voted{background:linear-gradient(135deg,#ec4899,#ef4444);border-color:#ec489980;color:#fff}.vote-button.voted:hover{background:linear-gradient(135deg,#db2777,#dc2626);box-shadow:0 4px 12px #ec48994d}.vote-button.loading{opacity:.6;cursor:not-allowed}.vote-button:disabled{cursor:not-allowed}.vote-icon{width:18px;height:18px;transition:all .3s ease}.vote-button:hover .vote-icon{transform:scale(1.1)}.vote-button.voted .vote-icon{animation:heartbeat .6s ease}.vote-count{font-variant-numeric:tabular-nums;min-width:20px;text-align:left}@keyframes heartbeat{0%,to{transform:scale(1)}25%{transform:scale(1.3)}50%{transform:scale(1.1)}75%{transform:scale(1.2)}}@media(max-width:768px){.vote-button{padding:.4rem .8rem;font-size:.8rem}.vote-icon{width:16px;height:16px}}.challenge-card-link{text-decoration:none;color:inherit;display:block}.challenge-card{position:relative;padding:1.5rem;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;cursor:pointer;display:flex;flex-direction:column;gap:1rem;height:100%;min-height:320px}.challenge-card:hover{transform:translateY(-4px);border-color:#fff3;box-shadow:0 8px 24px #0000004d}.badge-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.private-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.4rem .8rem;background:#fbbf2426;border:1px solid rgba(251,191,36,.3);border-radius:8px;font-size:.75rem;font-weight:600;color:#fbbf24;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.challenge-content{flex:1;display:flex;flex-direction:column;gap:.75rem}.challenge-title{font-size:1.25rem;font-weight:700;margin:0;color:#fff;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.challenge-description{font-size:.9rem;color:#ffffffb3;line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.challenge-creator{display:flex;align-items:center;gap:.75rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.1)}.creator-avatar,.creator-avatar-placeholder{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.2)}.creator-avatar-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600;font-size:.9rem}.creator-info{display:flex;flex-direction:column;gap:.2rem;flex:1}.creator-name{font-size:.875rem;font-weight:600;color:#fff}.challenge-time{font-size:.75rem;color:#ffffff80}.challenge-footer{display:flex;flex-direction:column;gap:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}.challenge-stats{display:flex;align-items:center;gap:1rem}.stat-item{display:flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;font-size:.875rem;color:#fffc}.stat-icon{width:16px;height:16px;color:#fff9}.adopt-button{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease}.adopt-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.plus-icon,.check-icon{width:18px;height:18px}@media(max-width:768px){.challenge-card{padding:1.25rem;min-height:280px}.challenge-title{font-size:1.1rem}.challenge-description{font-size:.85rem}.challenge-stats{flex-wrap:wrap}.adopt-button{padding:.65rem 1.25rem;font-size:.85rem}}.challenges-page{min-height:100vh;padding:2rem 0 4rem}.container{max-width:1400px;margin:0 auto;padding:0 2rem}.challenges-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:3rem;gap:2rem}.header-content h1{font-size:2.5rem;font-weight:800;margin:0 0 .5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-content p{font-size:1.1rem;color:#ffffffb3;margin:0}.create-challenge-btn{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.75rem;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap}.create-challenge-btn svg{width:20px;height:20px}.create-challenge-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.challenges-controls{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem;padding:1.5rem;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.search-bar{position:relative;flex:1;min-width:250px}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);width:20px;height:20px;color:#ffffff80;pointer-events:none}.search-input{width:100%;padding:.875rem 3rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#fff;font-size:.95rem;transition:all .3s ease}.search-input::placeholder{color:#fff6}.search-input:focus{outline:none;border-color:#667eea80;background:#ffffff14}.clear-search{position:absolute;right:1rem;top:50%;transform:translateY(-50%);background:#ffffff1a;border:none;border-radius:50%;width:24px;height:24px;color:#fff9;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.clear-search:hover{background:#fff3;color:#fff}.type-filters{display:flex;gap:.5rem;flex-wrap:wrap}.filter-btn{padding:.75rem 1.25rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#ffffffb3;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap}.filter-btn:hover{background:#ffffff1a;border-color:#fff3;color:#fff}.filter-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea80;color:#fff}.sort-dropdown{display:flex;align-items:center;gap:.75rem}.sort-dropdown label{font-size:.9rem;color:#ffffffb3;font-weight:500;white-space:nowrap}.sort-dropdown select{padding:.75rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#fff;font-size:.9rem;cursor:pointer;transition:all .3s ease}.sort-dropdown select:hover{background:#ffffff1a;border-color:#fff3}.sort-dropdown select:focus{outline:none;border-color:#667eea80}.sort-dropdown select option{background:#1a1a2e;color:#fff}.results-count{font-size:.9rem;color:#fff9;margin-bottom:1.5rem}.challenges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem;margin-top:2rem}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1.5rem}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1.5rem;text-align:center}.error-state p{color:#ef4444;font-size:1.1rem}.error-state button{padding:.875rem 1.75rem;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.error-state button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1.5rem;text-align:center}.empty-icon{font-size:4rem;opacity:.5}.empty-state h2{font-size:1.75rem;font-weight:700;color:#fff;margin:0}.empty-state p{font-size:1.1rem;color:#fff9;margin:0;max-width:500px}.create-first-btn{padding:.875rem 1.75rem;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:1rem}.create-first-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}@media(max-width:1024px){.challenges-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}}@media(max-width:768px){.challenges-header{flex-direction:column;align-items:flex-start}.header-content h1{font-size:2rem}.create-challenge-btn{width:100%;justify-content:center}.challenges-controls{flex-direction:column}.search-bar,.type-filters{width:100%}.filter-btn{flex:1;text-align:center}.sort-dropdown{width:100%;justify-content:space-between}.sort-dropdown select{flex:1}.challenges-grid{grid-template-columns:1fr;gap:1.25rem}}@media(max-width:480px){.container{padding:0 1rem}.header-content h1{font-size:1.75rem}.header-content p{font-size:1rem}}.challenge-detail-page{min-height:100vh;padding:2rem 0 4rem}.container{max-width:900px;margin:0 auto;padding:0 2rem}.back-link{display:inline-flex;align-items:center;gap:.5rem;color:#ffffffb3;text-decoration:none;font-size:.95rem;margin-bottom:2rem;transition:all .3s ease}.back-link:hover{color:#fff;transform:translate(-4px)}.challenge-header{margin-bottom:3rem}.type-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:10px;font-size:.85rem;font-weight:600;margin-bottom:1.5rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.type-icon{font-size:1.2rem}.type-name{text-transform:uppercase;letter-spacing:.5px}.challenge-header h1{font-size:2.5rem;font-weight:800;margin:0 0 1.5rem;color:#fff;line-height:1.2}.challenge-meta{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.creator-info{display:flex;align-items:center;gap:1rem}.creator-avatar,.creator-avatar-placeholder{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.2)}.creator-avatar-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:700;font-size:1.2rem}.creator-info>div{display:flex;flex-direction:column;gap:.25rem}.creator-label{font-size:.8rem;color:#ffffff80}.creator-name{font-size:1rem;font-weight:600;color:#fff}.challenge-time{font-size:.9rem;color:#ffffff80}.challenge-description{padding:2rem;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:16px;margin-bottom:2rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.challenge-description h3{font-size:1.25rem;font-weight:700;margin:0 0 1rem;color:#fff}.challenge-description p{font-size:1.05rem;line-height:1.7;color:#fffc;margin:0;white-space:pre-wrap}.story-details{padding:2rem;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:16px;margin-bottom:2rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.story-details h3{font-size:1.25rem;font-weight:700;margin:0 0 1rem;color:#fff}.constraint-box{padding:1.5rem;background:linear-gradient(135deg,#4f46e51a,#6366f10d);border:1px solid rgba(79,70,229,.3);border-radius:12px;margin-bottom:1.5rem}.constraint-box p{font-size:1.1rem;font-weight:500;color:#fff;margin:0}.info-note{display:flex;gap:1rem;padding:1rem;background:#ffffff0d;border-radius:10px}.info-note svg{width:24px;height:24px;color:#667eeacc;flex-shrink:0}.info-note p{font-size:.9rem;color:#ffffffb3;margin:0;line-height:1.5}.build-details{padding:2rem;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:16px;margin-bottom:2rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.build-details h3{font-size:1.25rem;font-weight:700;margin:0 0 1.5rem;color:#fff}.build-section{padding:1.5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;margin-bottom:1.5rem}.build-section h4{font-size:1.1rem;font-weight:600;margin:0 0 1rem;color:#fff}.build-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.05)}.build-item:last-child{border-bottom:none}.item-label{font-size:.9rem;color:#fff9;font-weight:500}.item-value{font-size:.95rem;color:#fff;font-weight:600}.item-value.skill{padding:.4rem .8rem;background:linear-gradient(135deg,#dc262633,#ef44441a);border:1px solid rgba(220,38,38,.3);border-radius:6px;font-size:.85rem}.armor-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.armor-piece{padding:1.25rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px}.armor-piece h4{font-size:1rem;font-weight:600;margin:0 0 .75rem;color:#fff}.other-details{margin-bottom:2rem}.challenge-image{border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.1)}.challenge-image img{width:100%;height:auto;display:block}.challenge-actions{display:flex;flex-direction:column;gap:1.5rem;padding:2rem;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.challenge-stats{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.stat-item{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;font-size:.95rem;color:#fffc}.stat-item svg{width:18px;height:18px;color:#fff9}.adopt-button{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;color:#fff;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.adopt-button svg{width:20px;height:20px}.adopt-button:hover{transform:translateY(-2px);box-shadow:0 8px 24px #667eea66}.adopt-button:active{transform:translateY(0)}.adopt-button.adopted{background:#22c55e33;border:1px solid rgba(34,197,94,.4);cursor:default}.adopt-button.adopted:hover{transform:none;box-shadow:none}.adopt-button:disabled{cursor:not-allowed}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1.5rem;text-align:center}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.1);border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}.loading-state p{color:#ffffffb3;font-size:1.1rem}.error-state h2{font-size:1.75rem;font-weight:700;color:#fff;margin:0}.error-state p{color:#ffffffb3;font-size:1.1rem;margin:0}@media(max-width:768px){.challenge-header h1{font-size:2rem}.challenge-description,.story-details,.build-details,.challenge-actions{padding:1.5rem}.armor-grid{grid-template-columns:1fr}.challenge-meta{flex-direction:column;align-items:flex-start}}@media(max-width:480px){.container{padding:0 1rem}.challenge-header h1{font-size:1.75rem}.build-item{flex-direction:column;align-items:flex-start;gap:.5rem}}.challenge-form{background:var(--card-bg);border-radius:1rem;padding:2rem;box-shadow:0 4px 16px #0003}.form-header{text-align:center;margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border-color)}.form-icon{font-size:3rem;margin-bottom:1rem;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}.form-header h2{font-size:2rem;font-weight:700;margin-bottom:.5rem;color:var(--text-primary)}.form-header p{color:var(--text-secondary);font-size:1rem}.form-group{margin-bottom:1.5rem;position:relative}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary);font-size:.95rem}.form-input,.form-textarea,.form-select{width:100%;padding:.875rem 1rem;background:#ffffff0d;border:1px solid var(--border-color);border-radius:.5rem;color:var(--text-primary);font-size:1rem;font-family:inherit;transition:all .3s ease}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--primary);background:#ffffff14;box-shadow:0 0 0 3px #8b5cf61a}.form-textarea{resize:vertical;min-height:100px}.form-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23999' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}.char-count{position:absolute;right:0;top:0;font-size:.75rem;color:var(--text-secondary)}.field-hint{margin-top:.5rem;font-size:.875rem;color:var(--text-secondary)}.info-box{background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:.5rem;padding:1rem;margin-bottom:1.5rem;font-size:.9rem;color:var(--text-secondary)}.info-box strong{color:var(--primary)}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border-color)}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:1rem;border-radius:.5rem;margin-bottom:1.5rem}.gear-section{background:#ffffff08;border:1px solid var(--border-color);border-radius:.75rem;padding:1.5rem;margin-bottom:1.5rem}.gear-section h3{font-size:1.25rem;font-weight:600;margin-bottom:1rem;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.gear-icon{font-size:1.5rem}.gear-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.constraint-section{background:#ffffff08;border:1px solid var(--border-color);border-radius:.75rem;padding:1.5rem;margin-bottom:1.5rem}.constraint-section h3{font-size:1.125rem;font-weight:600;margin-bottom:1rem;color:var(--text-primary)}.checkbox-group{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#ffffff05;border-radius:.5rem;cursor:pointer;transition:all .3s ease}.checkbox-group:hover{background:#ffffff0d}.checkbox-group input[type=checkbox]{width:1.25rem;height:1.25rem;cursor:pointer;accent-color:var(--primary)}.checkbox-group label{margin:0;cursor:pointer;flex:1}@media(max-width:768px){.challenge-form{padding:1.5rem}.form-header h2{font-size:1.5rem}.form-icon{font-size:2.5rem}.gear-grid{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}}.create-challenge-page{min-height:100vh;padding:2rem 1rem;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.create-challenge-container{max-width:1200px;margin:0 auto}.type-selection{text-align:center}.page-title{font-size:2.5rem;font-weight:700;margin-bottom:.5rem;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-subtitle{font-size:1.125rem;color:var(--text-secondary);margin-bottom:3rem}.challenge-types{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:2rem}.challenge-type-card{background:var(--card-bg);border:2px solid transparent;border-radius:1rem;padding:2rem;cursor:pointer;transition:all .3s ease;text-align:center;position:relative;overflow:hidden}.challenge-type-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);opacity:0;transition:opacity .3s ease;z-index:0}.challenge-type-card:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:0 8px 24px #0000004d}.challenge-type-card:hover:before{opacity:.1}.challenge-type-card>*{position:relative;z-index:1}.type-icon{font-size:3rem;margin-bottom:1rem;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}.challenge-type-card h3{font-size:1.5rem;font-weight:600;margin-bottom:.75rem;color:var(--text-primary)}.challenge-type-card p{color:var(--text-secondary);margin-bottom:1.5rem;line-height:1.6}.type-examples{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.example-tag{background:#ffffff1a;padding:.25rem .75rem;border-radius:1rem;font-size:.875rem;color:var(--text-secondary);border:1px solid rgba(255,255,255,.1)}.challenge-form-container{max-width:800px;margin:0 auto}.back-button{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);padding:.75rem 1.5rem;border-radius:.5rem;cursor:pointer;font-size:1rem;transition:all .3s ease;margin-bottom:2rem;display:inline-flex;align-items:center;gap:.5rem}.back-button:hover{background:#ffffff0d;border-color:var(--primary);color:var(--text-primary)}@media(max-width:768px){.page-title{font-size:2rem}.challenge-types{grid-template-columns:1fr;gap:1.5rem}.challenge-type-card{padding:1.5rem}.type-icon{font-size:2.5rem}}.progress-bar-container{display:flex;align-items:center;gap:.75rem;width:100%}.progress-bar-track{flex:1;background:#ffffff1a;border-radius:100px;overflow:hidden;position:relative}.progress-bar-fill{height:100%;border-radius:100px;transition:width .6s cubic-bezier(.4,0,.2,1);position:relative}.progress-bar-fill.animated:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-bar-label{font-size:.875rem;font-weight:600;color:#ffffffe6;min-width:3rem;text-align:right}:root{--progress-low: linear-gradient(90deg, #ef4444, #f97316);--progress-medium: linear-gradient(90deg, #f97316, #fbbf24);--progress-high: linear-gradient(90deg, #84cc16, #22c55e);--progress-complete: linear-gradient(90deg, #10b981, #059669)}.my-challenge-card-link{text-decoration:none;display:block}.my-challenge-card{background:linear-gradient(135deg,#3b82f61a,#9333ea1a);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;overflow:hidden}.my-challenge-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(255,255,255,.05),transparent);opacity:0;transition:opacity .3s ease;pointer-events:none}.my-challenge-card:hover{transform:translateY(-4px);border-color:#fff3;box-shadow:0 20px 40px #0000004d}.my-challenge-card:hover:before{opacity:1}.my-challenge-card.completed{border-color:#22c55e4d}.my-challenge-card.completed:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(34,197,94,.1),transparent);pointer-events:none}.my-challenge-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;gap:.5rem}.challenge-type-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .8rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:8px;font-size:.75rem;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.type-icon{font-size:1rem}.completed-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .8rem;background:#22c55e33;border:1px solid rgba(34,197,94,.4);border-radius:8px;font-size:.75rem;font-weight:600;color:#22c55e}.check-icon{width:14px;height:14px}.my-challenge-title{font-size:1.25rem;font-weight:700;color:#fff;margin:0 0 .75rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.challenge-creator-info{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.875rem}.creator-label{color:#fff9}.creator-name{color:#ffffffe6;font-weight:600}.progress-section{margin:1.25rem 0}.my-challenge-footer{display:flex;align-items:center;justify-content:space-between;margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}.last-updated{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#ffffffb3}.clock-icon{width:16px;height:16px;stroke:#fff9}@media(max-width:768px){.my-challenge-card{padding:1.25rem}.my-challenge-title{font-size:1.125rem}}.my-challenges-page{max-width:1400px;margin:0 auto;padding:2rem}.page-header{text-align:center;margin-bottom:2.5rem}.page-title{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,#fff,#ffffffb3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 .5rem}.page-subtitle{font-size:1.125rem;color:#ffffffb3;margin:0}.stats-bar{display:flex;align-items:center;justify-content:center;gap:2rem;padding:1.5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin-bottom:2rem}.stat-item{text-align:center}.stat-divider{width:1px;height:40px;background:#ffffff1a}.filter-tabs{display:flex;gap:1rem;margin-bottom:2rem;padding:.5rem;background:#ffffff0d;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.filter-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;background:transparent;border:none;border-radius:8px;font-size:1rem;font-weight:600;color:#fff9;cursor:pointer;transition:all .2s ease}.filter-tab:hover{background:#ffffff0d;color:#ffffffe6}.filter-tab.active{background:#3b82f633;color:#fff;border:1px solid rgba(59,130,246,.3)}.tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 .5rem;background:#ffffff1a;border-radius:12px;font-size:.75rem;font-weight:700}.filter-tab.active .tab-count{background:#3b82f64d}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;background:#ffffff08;border:2px dashed rgba(255,255,255,.1);border-radius:16px}.empty-state h3{font-size:1.5rem;font-weight:700;color:#fff;margin:0 0 .5rem}.empty-state p{font-size:1.125rem;color:#fff9;margin:0 0 2rem;max-width:500px}.cta-button{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.75rem;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;border-radius:12px;font-size:1rem;font-weight:600;color:#fff;text-decoration:none;cursor:pointer;transition:all .2s ease}.cta-button:hover{transform:translateY(-2px);box-shadow:0 10px 30px #3b82f64d}.auth-required{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.auth-required h2{font-size:2rem;font-weight:700;color:#fff;margin:0 0 .5rem}.auth-required p{font-size:1.125rem;color:#fff9;margin:0}@media(max-width:768px){.my-challenges-page{padding:1.5rem 1rem}.page-title{font-size:2rem}.stats-bar{flex-direction:column;gap:1rem}.stat-divider{width:100%;height:1px}.filter-tabs{flex-direction:column}.challenges-grid{grid-template-columns:1fr}}.story-progress-tracker{width:100%;max-width:800px;margin:0 auto}.tracker-header{text-align:center;margin-bottom:1.5rem}.tracker-header h3{font-size:1.5rem;font-weight:600;color:var(--text-primary, #ffffff);margin:0 0 .25rem}.chapter-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;overflow-x:auto;padding:.5rem;background:#0000004d;border-radius:8px}.chapter-tab{min-width:48px;height:48px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);border-radius:6px;color:#ffffffb3;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.chapter-tab:hover{background:#ffffff26;border-color:#fff6;color:#ffffffe6}.chapter-tab.active{background:#4a90e24d;border-color:#4a90e2;color:#fff}.chapter-tab.complete{border-color:#4caf5080}.chapter-tab.complete.active{border-color:#4a90e2}.chapter-tab-number{display:block}.chapter-tab-completion-mark{position:absolute;top:2px;right:2px;width:16px;height:16px;background:#4caf50f2;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;font-weight:700;animation:markAppear .3s ease}.monster-grid{display:flex;flex-direction:column;gap:.5rem}.chapter-row{display:flex;gap:.5rem;align-items:flex-start}.chapter-number-cell{min-width:60px;width:60px;height:80px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;background:linear-gradient(135deg,#3a5a3a,#2d4a2d);border:2px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-size:1.5rem;font-weight:700;flex-shrink:0;transition:all .3s ease}.chapter-number-cell.complete{background:linear-gradient(135deg,#2d5a2d,#1e4a1e);border-color:#4caf5099;box-shadow:0 0 12px #4caf504d}.chapter-number{display:block}.chapter-completion-mark{position:absolute;top:4px;right:4px;width:20px;height:20px;background:#4caf50f2;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.875rem;font-weight:700;animation:markAppear .3s ease}.monsters-row{display:flex;flex-wrap:wrap;gap:.5rem;flex:1}.monster-cell{position:relative;width:80px;height:80px;background:#2a2a2ae6;border:2px solid rgba(255,255,255,.15);border-radius:8px;cursor:pointer;transition:all .2s ease;overflow:hidden;display:flex;align-items:center;justify-content:center}.monster-cell:hover{border-color:#fff6;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.monster-cell.complete{border-color:#4caf5080}.monster-icon{width:100%;height:100%;object-fit:cover}.monster-placeholder{padding:.5rem;font-size:.75rem;text-align:center;color:#fff9;word-wrap:break-word;line-height:1.2}.completion-mark{position:absolute;top:4px;right:4px;width:24px;height:24px;background:#4caf50f2;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem;font-weight:700;pointer-events:none;animation:markAppear .3s ease}@keyframes markAppear{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}@media(max-width:768px){.chapter-tabs{padding:.25rem;gap:.25rem}.chapter-tab{min-width:40px;height:40px;font-size:.875rem}.chapter-number-cell{min-width:50px;width:50px;height:70px;font-size:1.25rem}.monster-cell{width:70px;height:70px}.monster-placeholder{font-size:.65rem;padding:.25rem}.completion-mark{width:20px;height:20px;font-size:.875rem}}@media(max-width:480px){.chapter-number-cell{min-width:40px;width:40px;height:60px;font-size:1rem}.monster-cell{width:60px;height:60px}.monsters-row,.chapter-row{gap:.375rem}}.build-progress-tracker{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:1.5rem}.tracker-subtitle{font-size:.875rem;color:#fff9;margin:0 0 .75rem}.build-stats{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:8px}.stat-label{font-size:.875rem;color:#ffffffb3}.stat-value{font-size:.875rem;font-weight:700;color:#3b82f6}.build-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.build-piece{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1rem;transition:all .3s ease}.build-piece.fully-complete{background:#22c55e1a;border-color:#22c55e4d}.piece-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.1)}.piece-icon{font-size:1.5rem}.piece-label{font-size:1rem;font-weight:600;color:#fff}.piece-requirements{display:flex;flex-direction:column;gap:.5rem}.requirement-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:8px;cursor:pointer;transition:all .2s ease;position:relative}.requirement-item:hover{background:#ffffff0d;border-color:#ffffff1a}.requirement-item.complete{background:#22c55e0d;border-color:#22c55e33}.requirement-item.driftstone-skill{background:#9333ea0d;border:1px solid rgba(147,51,234,.1)}.requirement-item.driftstone-skill.complete{background:#9333ea1a;border-color:#9333ea4d}.requirement-item.driftstone-skill.disabled{opacity:.5;cursor:not-allowed;background:#9333ea05;border-color:#9333ea0d}.requirement-item.driftstone-skill.disabled:hover{background:#9333ea05;border-color:#9333ea0d}.requirement-checkbox{position:absolute;opacity:0;pointer-events:none}.checkbox-custom{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.requirement-item:hover .checkbox-custom{border-color:#ffffff80}.requirement-item.complete .checkbox-custom{background:#22c55e;border-color:#22c55e}.requirement-item.driftstone-skill.complete .checkbox-custom{background:#9333ea;border-color:#9333ea}.checkbox-custom svg{width:14px;height:14px;stroke:#fff}.monster-icon-container{position:relative;width:48px;height:48px;flex-shrink:0;margin-left:.25rem}.monster-icon{width:100%;height:100%;object-fit:contain;border-radius:8px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);padding:2px}.driftstone-icon-container{position:relative;width:40px;height:40px;flex-shrink:0;margin-left:.25rem}.driftstone-icon{width:100%;height:100%;object-fit:contain;border-radius:6px;background:#9333ea1a;border:1px solid rgba(147,51,234,.2);padding:4px}.hunt-indicator{position:absolute;top:-6px;right:-6px;width:20px;height:20px;background:#22c55e;border-radius:50%;display:flex;align-items:center;justify-content:center;animation:pulse 2s ease-in-out infinite;box-shadow:0 0 8px #22c55e99}.hunt-indicator svg{width:12px;height:12px;fill:#fff}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.requirement-item.complete .hunt-indicator{display:none}.requirement-details{flex:1;display:flex;flex-direction:column;gap:.25rem}.requirement-name-with-sources{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.requirement-name{font-size:.9375rem;font-weight:500;color:#ffffffe6}.requirement-item.complete .requirement-name{color:#fff9;text-decoration:line-through}.driftstone-sources{display:inline-flex;align-items:center;gap:2px;font-size:.875rem;color:#9333eacc}.driftstone-source-icon{width:20px;height:20px;object-fit:contain;vertical-align:middle;border-radius:3px;background:#9333ea1a;border:1px solid rgba(147,51,234,.2);padding:2px}.requirement-type{font-size:.75rem;color:#ffffff80;text-transform:uppercase;letter-spacing:.05em}@media(max-width:768px){.build-grid{grid-template-columns:1fr}}.other-progress-tracker{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:1.5rem}.tracker-header{margin-bottom:1.5rem}.tracker-header h3{font-size:1.25rem;font-weight:700;color:#fff;margin:0 0 .5rem}.tracker-subtitle{font-size:.875rem;color:#fff9;margin:0}.completion-toggle-container{margin-bottom:1.5rem}.completion-toggle{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:12px;cursor:pointer;transition:all .3s ease}.completion-toggle:hover{background:#ffffff12;border-color:#fff3}.completion-toggle.complete{background:#22c55e1a;border-color:#22c55e4d}.toggle-checkbox{position:absolute;opacity:0;pointer-events:none}.toggle-visual{width:56px;height:32px;background:#ffffff1a;border-radius:16px;position:relative;transition:all .3s ease;flex-shrink:0}.completion-toggle.complete .toggle-visual{background:#22c55e}.toggle-slider{width:24px;height:24px;background:#fff;border-radius:50%;position:absolute;top:4px;left:4px;transition:all .3s ease;box-shadow:0 2px 4px #0003}.completion-toggle.complete .toggle-slider{transform:translate(24px)}.toggle-label{display:flex;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:600;color:#ffffffe6}.completion-toggle.complete .toggle-label{color:#22c55e}.check-icon{width:20px;height:20px;stroke:#22c55e}.completion-message{margin-top:1rem;padding:1rem;background:linear-gradient(135deg,#22c55e1a,#10b9811a);border:1px solid rgba(34,197,94,.2);border-radius:12px;display:flex;align-items:center;gap:1rem;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.celebration-icon{font-size:2rem;animation:bounce .6s ease infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.completion-message p{margin:0;font-size:.9375rem;color:#ffffffe6}.notes-reminder{display:flex;gap:1rem;padding:1rem;background:#3b82f60d;border:1px solid rgba(59,130,246,.1);border-radius:12px}.info-icon{width:20px;height:20px;stroke:#3b82f6;flex-shrink:0;margin-top:.125rem}.notes-reminder p{margin:0;font-size:.875rem;color:#ffffffb3;line-height:1.5}.confirm-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirm-dialog{background:linear-gradient(135deg,#1e1e1ef2,#141414f2);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:2rem;max-width:450px;width:90%;box-shadow:0 20px 60px #00000080;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.confirm-dialog-header{margin-bottom:1rem}.confirm-dialog-header h3{font-size:1.5rem;font-weight:700;color:#fff;margin:0}.confirm-dialog-body{margin-bottom:2rem}.confirm-dialog-body p{font-size:1rem;line-height:1.6;color:#fffc;margin:0}.confirm-dialog-actions{display:flex;gap:1rem;justify-content:flex-end}.btn-dialog-cancel,.btn-dialog-confirm{padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.btn-dialog-cancel{background:#ffffff0d;border:1px solid rgba(255,255,255,.2);color:#ffffffe6}.btn-dialog-cancel:hover{background:#ffffff1a}.btn-dialog-confirm{color:#fff}.btn-dialog-confirm.danger{background:linear-gradient(135deg,#ef4444,#dc2626)}.btn-dialog-confirm.danger:hover{transform:translateY(-2px);box-shadow:0 10px 30px #ef444466}.btn-dialog-confirm.warning{background:linear-gradient(135deg,#f59e0b,#d97706)}.btn-dialog-confirm.warning:hover{transform:translateY(-2px);box-shadow:0 10px 30px #f59e0b66}.btn-dialog-confirm.info{background:linear-gradient(135deg,#3b82f6,#2563eb)}.btn-dialog-confirm.info:hover{transform:translateY(-2px);box-shadow:0 10px 30px #3b82f666}@media(max-width:768px){.confirm-dialog{padding:1.5rem}.confirm-dialog-actions{flex-direction:column-reverse}.btn-dialog-cancel,.btn-dialog-confirm{width:100%}}.proof-modal{background:var(--card-bg);border-radius:16px;padding:2rem;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{margin-bottom:2rem}.modal-header h2{margin:0 0 .5rem;color:var(--text-primary);font-size:1.75rem}.modal-subtitle{margin:0;color:var(--text-secondary);font-size:.95rem}.modal-content{margin-bottom:2rem}.proof-type-selector{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.radio-option{display:flex;align-items:center;padding:1rem;border:2px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .2s ease}.radio-option:hover{border-color:var(--primary-color);background:#8b5cf60d}.radio-option input[type=radio]{margin-right:.75rem;cursor:pointer;width:18px;height:18px;accent-color:var(--primary-color)}.radio-option input[type=radio]:checked+.radio-label{color:var(--primary-color);font-weight:600}.radio-option:has(input:checked){border-color:var(--primary-color);background:#8b5cf61a}.radio-label{display:flex;align-items:center;gap:.5rem;color:var(--text-primary);font-size:.95rem;transition:all .2s ease}.radio-label svg{width:20px;height:20px;flex-shrink:0}.input-group{margin-bottom:1.5rem}.input-group label{display:block;margin-bottom:.5rem;color:var(--text-primary);font-weight:500;font-size:.95rem}.upload-section{margin-bottom:1.5rem}.file-input{display:none}.file-label{display:block;cursor:pointer;border-radius:12px;overflow:hidden;transition:all .2s ease}.upload-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;background:var(--input-bg);border:2px dashed var(--border-color);border-radius:12px;transition:all .2s ease}.file-label:hover .upload-placeholder{border-color:var(--primary-color);background:#8b5cf60d}.upload-placeholder svg{width:48px;height:48px;color:var(--text-secondary);margin-bottom:1rem}.upload-text{display:block;color:var(--text-primary);font-weight:600;font-size:1rem;margin-bottom:.5rem}.upload-hint{display:block;color:var(--text-secondary);font-size:.85rem}.preview-container{position:relative;width:100%;max-height:300px;overflow:hidden;border-radius:12px}.preview-image{width:100%;height:auto;display:block;max-height:300px;object-fit:contain;background:var(--input-bg)}.preview-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease;color:#fff}.file-label:hover .preview-overlay{opacity:1}.preview-overlay svg{width:32px;height:32px;margin-bottom:.5rem}.preview-overlay span{font-size:.9rem;font-weight:600}.proof-input{width:100%;padding:.875rem 1rem;background:var(--input-bg);border:2px solid var(--border-color);border-radius:10px;color:var(--text-primary);font-size:.95rem;transition:all .2s ease}.proof-input:focus{outline:none;border-color:var(--primary-color);background:var(--card-bg);box-shadow:0 0 0 3px #8b5cf61a}.proof-input:disabled{opacity:.6;cursor:not-allowed}.input-hint{margin:.5rem 0 0;color:var(--text-secondary);font-size:.85rem;line-height:1.4}.error-message{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:10px;color:#ef4444;font-size:.9rem;margin-bottom:1rem}.error-message svg{width:20px;height:20px;flex-shrink:0}.moderation-notice{display:flex;gap:.75rem;padding:1rem;background:#3b82f61a;border:1px solid rgba(59,130,246,.3);border-radius:10px;color:var(--text-secondary);font-size:.85rem;line-height:1.5}.moderation-notice svg{width:20px;height:20px;flex-shrink:0;color:#3b82f6;margin-top:2px}.moderation-notice p{margin:0}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;flex-wrap:wrap}.modal-actions button{padding:.75rem 1.5rem;border-radius:10px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s ease;border:none;display:flex;align-items:center;gap:.5rem}.modal-actions .btn-primary{background:var(--primary-color);color:#fff}.modal-actions .btn-primary:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf64d}.modal-actions .btn-primary:disabled{opacity:.5;cursor:not-allowed}.modal-actions .btn-secondary{background:var(--card-bg);color:var(--text-primary);border:2px solid var(--border-color)}.modal-actions .btn-secondary:hover:not(:disabled){border-color:var(--text-secondary);background:var(--input-bg)}.modal-actions .btn-tertiary{background:transparent;color:var(--text-secondary);border:2px solid transparent}.modal-actions .btn-tertiary:hover:not(:disabled){color:var(--text-primary);background:var(--input-bg)}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@media(max-width:640px){.proof-modal{padding:1.5rem;width:95%}.modal-header h2{font-size:1.5rem}.proof-type-selector{grid-template-columns:1fr}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%;justify-content:center}}.challenge-progress-page{max-width:900px;margin:0 auto;padding:2rem}.back-link{display:inline-flex;align-items:center;gap:.5rem;color:#ffffffb3;text-decoration:none;font-size:.9375rem;margin-bottom:1.5rem;transition:color .2s ease}.back-link:hover{color:#fff}.back-link svg{width:20px;height:20px}.page-header{margin-bottom:2rem}.challenge-header{margin-bottom:1.5rem}.challenge-type-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:8px;font-size:.875rem;font-weight:600;margin-bottom:1rem}.type-icon{font-size:1.125rem}.type-name{color:#ffffffe6}.title-display{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.title-display h1{font-size:2rem;font-weight:800;color:#fff;margin:0;flex:1}.btn-edit{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#ffffffb3;font-size:.875rem;cursor:pointer;transition:all .2s ease}.btn-edit:hover{background:#ffffff1a;color:#fff}.btn-edit svg{width:16px;height:16px}.title-editor{display:flex;gap:.75rem;margin-bottom:1rem}.title-input{flex:1;padding:.75rem 1rem;background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-size:1.5rem;font-weight:700}.title-input:focus{outline:none;border-color:#3b82f6}.btn-save,.btn-cancel{padding:.75rem 1.5rem;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-save{background:#3b82f6;border:none;color:#fff}.btn-save:hover{background:#2563eb}.btn-cancel{background:transparent;border:1px solid rgba(255,255,255,.2);color:#ffffffb3}.btn-cancel:hover{background:#ffffff0d}.challenge-description{font-size:1.125rem;color:#fffc;line-height:1.6;margin:0 0 .75rem}.creator-info{font-size:.9375rem;color:#fff9;margin:0}.creator-info strong{color:#ffffffe6}.progress-section{padding:1.5rem;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:12px}.progress-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;font-size:.9375rem;color:#ffffffb3}.saving-indicator{color:#3b82f6;font-size:.875rem}.progress-tracker-section,.notes-section{margin-bottom:2rem}.notes-section h3{font-size:1.25rem;font-weight:700;color:#fff;margin:0 0 1rem}.notes-textarea{width:100%;padding:1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:.9375rem;line-height:1.6;resize:vertical;font-family:inherit}.notes-textarea:focus{outline:none;border-color:#3b82f6;background:#ffffff12}.notes-textarea::placeholder{color:#fff6}.notes-hint{margin:.5rem 0 0;font-size:.8125rem;color:#ffffff80;font-style:italic}.actions-section{display:flex;gap:1rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1)}.btn-complete{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 2rem;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:12px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-complete:hover{transform:translateY(-2px);box-shadow:0 10px 30px #22c55e4d}.btn-complete svg{width:20px;height:20px}.btn-abandon{padding:1rem 2rem;background:transparent;border:1px solid rgba(239,68,68,.3);border-radius:12px;color:#ef4444;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-abandon:hover{background:#ef44441a;border-color:#ef444480}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.loading-state p,.error-state h2{color:#ffffffe6}.btn-primary{display:inline-block;padding:.875rem 1.75rem;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;border-radius:12px;color:#fff;font-size:1rem;font-weight:600;text-decoration:none;cursor:pointer;transition:all .2s ease;margin-top:1rem}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 30px #3b82f64d}@media(max-width:768px){.challenge-progress-page{padding:1.5rem 1rem}.title-display{flex-direction:column;align-items:flex-start}.title-display h1{font-size:1.5rem}.title-editor,.actions-section{flex-direction:column}}.profile-page{max-width:1200px;margin:0 auto;padding:2rem 1rem}.profile-header{display:flex;flex-direction:column;align-items:center;text-align:center;padding:2rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin-bottom:2rem;position:relative}.profile-avatar{width:120px;height:120px;border-radius:50%;overflow:hidden;border:4px solid rgba(255,255,255,.2);margin-bottom:1.5rem;background:linear-gradient(135deg,#3b82f633,#9333ea33)}.profile-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff9}.avatar-placeholder svg{width:60px;height:60px}.profile-info{margin-bottom:1.5rem}.profile-username{font-size:2rem;font-weight:800;background:linear-gradient(135deg,#fff,#ffffffb3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 .5rem}.profile-role{font-size:1rem;color:#fffc;margin:0 0 .25rem;font-weight:600}.profile-joined{font-size:.875rem;color:#ffffff80;margin:0}.profile-actions{width:100%;max-width:300px}.edit-profile-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.875rem 1.5rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:12px;font-size:1rem;font-weight:600;color:#fff;cursor:pointer;transition:all .2s ease}.edit-profile-btn:hover{background:#ffffff26;border-color:#ffffff4d;transform:translateY(-2px)}.edit-profile-btn svg{width:18px;height:18px}.profile-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{padding:1.5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .2s ease}.stat-card:hover{transform:translateY(-2px);border-color:#fff3}.stat-value{font-size:2rem;font-weight:700;color:#fff;line-height:1;margin-bottom:.5rem}.stat-label{font-size:.875rem;color:#fff9;text-transform:uppercase;letter-spacing:.05em}.active-challenges-section{margin-top:2rem}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.section-header h2{font-size:1.75rem;font-weight:700;color:#fff;margin:0}.view-all-link{font-size:1rem;font-weight:600;color:#3b82f6;text-decoration:none;transition:color .2s ease}.view-all-link:hover{color:#60a5fa}.challenges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.empty-challenges{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;background:#ffffff08;border:2px dashed rgba(255,255,255,.1);border-radius:16px}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-challenges h3{font-size:1.5rem;font-weight:700;color:#fff;margin:0 0 .5rem}.empty-challenges p{font-size:1.125rem;color:#fff9;margin:0 0 2rem;max-width:500px}.browse-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.75rem;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;border-radius:12px;font-size:1rem;font-weight:600;color:#fff;text-decoration:none;cursor:pointer;transition:all .2s ease}.browse-btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px #3b82f64d}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.loading-spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.1);border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.loading-state p{color:#ffffffb3;font-size:1.125rem}.auth-required,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.auth-required h2,.error-state h2{font-size:2rem;font-weight:700;color:#fff;margin:0 0 .5rem}.auth-required p,.error-state p{font-size:1.125rem;color:#fff9;margin:0}@media(max-width:768px){.profile-page{padding:1.5rem 1rem}.profile-header{padding:1.5rem}.profile-avatar{width:100px;height:100px}.avatar-placeholder svg{width:50px;height:50px}.profile-username{font-size:1.75rem}.profile-stats{grid-template-columns:repeat(2,1fr)}.section-header h2{font-size:1.5rem}.challenges-grid{grid-template-columns:1fr}}@media(max-width:480px){.profile-avatar{width:80px;height:80px}.avatar-placeholder svg{width:40px;height:40px}.profile-username,.stat-value{font-size:1.5rem}.stat-card{padding:1rem}}.login-page{min-height:calc(100vh - 200px);display:flex;align-items:center;justify-content:center;padding:var(--space-2xl) 0}.login-container{width:100%;max-width:480px;padding:0 var(--space-lg)}.login-card{padding:var(--space-2xl)}.login-title{text-align:center;margin-bottom:var(--space-sm);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-subtitle{text-align:center;color:var(--color-text-secondary);margin-bottom:var(--space-2xl)}.error-message{padding:var(--space-md);background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:#fca5a5;font-size:var(--font-size-sm);margin-bottom:var(--space-lg)}.social-login{display:flex;flex-direction:column;gap:var(--space-md)}.btn-social{width:100%;justify-content:center;background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border);font-weight:var(--font-weight-medium)}.btn-social:hover{background:var(--color-surface-hover);border-color:var(--color-border-light);transform:translateY(-2px)}.btn-social:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-google svg,.btn-apple svg{flex-shrink:0}.divider{display:flex;align-items:center;text-align:center;margin:var(--space-xl) 0;color:var(--color-text-muted);font-size:var(--font-size-sm)}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px solid var(--color-border)}.divider span{padding:0 var(--space-md)}.email-form{display:flex;flex-direction:column;gap:var(--space-lg)}.form-group{display:flex;flex-direction:column;gap:var(--space-sm)}.form-group label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.form-input{padding:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-base);transition:all var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--color-primary);background:var(--color-surface-hover)}.form-input::placeholder{color:var(--color-text-muted)}.btn-full{width:100%}.toggle-mode{margin-top:var(--space-xl);text-align:center}.toggle-link{background:none;border:none;color:var(--color-primary-light);font-size:var(--font-size-sm);cursor:pointer;transition:color var(--transition-fast)}.toggle-link:hover{color:var(--color-primary);text-decoration:underline}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary: hsl(210, 100%, 55%);--color-primary-dark: hsl(210, 100%, 45%);--color-primary-light: hsl(210, 100%, 65%);--color-secondary: hsl(30, 95%, 55%);--color-secondary-dark: hsl(30, 95%, 45%);--color-accent: hsl(160, 85%, 45%);--color-accent-glow: hsl(160, 85%, 55%);--color-danger: hsl(0, 85%, 60%);--color-warning: hsl(45, 95%, 55%);--color-success: hsl(140, 75%, 50%);--color-bg-primary: hsl(220, 20%, 8%);--color-bg-secondary: hsl(220, 18%, 12%);--color-bg-tertiary: hsl(220, 16%, 16%);--color-surface: hsla(220, 18%, 18%, .6);--color-surface-hover: hsla(220, 18%, 22%, .7);--color-text-primary: hsl(0, 0%, 95%);--color-text-secondary: hsl(0, 0%, 75%);--color-text-muted: hsl(0, 0%, 55%);--color-border: hsla(220, 15%, 30%, .4);--color-border-light: hsla(220, 15%, 40%, .3);--gradient-primary: linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary) 100%);--gradient-surface: linear-gradient(135deg, hsla(220, 18%, 18%, .8) 0%, hsla(220, 18%, 14%, .9) 100%);--gradient-hero: linear-gradient(180deg, transparent 0%, var(--color-bg-primary) 100%);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(var(--color-accent), .3);--glass-bg: rgba(255, 255, 255, .05);--glass-border: rgba(255, 255, 255, .1);--glass-blur: blur(12px);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", sans-serif;--font-display: "Inter", var(--font-sans);--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-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-size:var(--font-size-base);line-height:1.6;color:var(--color-text-primary);background-color:var(--color-bg-primary);background-image:radial-gradient(at 0% 0%,hsla(210,100%,20%,.15) 0px,transparent 50%),radial-gradient(at 100% 100%,hsla(30,95%,20%,.15) 0px,transparent 50%);background-attachment:fixed;min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:var(--font-weight-bold);line-height:1.2;margin-bottom:var(--space-md);color:var(--color-text-primary)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}p{margin-bottom:var(--space-md);color:var(--color-text-secondary)}a{color:var(--color-primary-light);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary)}.container{width:100%;max-width:1280px;margin:0 auto;padding:0 var(--space-lg)}.container-sm{max-width:768px}.container-lg{max-width:1536px}.glass-card{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-md);transition:all var(--transition-base)}.glass-card:hover{background:#ffffff14;border-color:#ffffff26;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--transition-fast);text-decoration:none;white-space:nowrap}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);filter:brightness(1.1)}.btn-secondary{background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-surface-hover);border-color:var(--color-border-light)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover{background:var(--color-surface);color:var(--color-text-primary)}.btn-sm{padding:var(--space-xs) var(--space-md);font-size:var(--font-size-sm)}.btn-lg{padding:var(--space-md) var(--space-xl);font-size:var(--font-size-lg)}.badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.5px}.badge-primary{background:var(--color-primary);color:#fff}.badge-success{background:var(--color-success);color:#fff}.badge-warning{background:var(--color-warning);color:var(--color-bg-primary)}.badge-danger{background:var(--color-danger);color:#fff}.grid{display:grid;gap:var(--space-lg)}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}@media(max-width:768px){.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}}@media(min-width:769px)and (max-width:1024px){.grid-cols-3,.grid-cols-4{grid-template-columns:repeat(2,1fr)}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.text-center{text-align:center}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.animate-fade-in{animation:fadeIn var(--transition-base) ease-out}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.skeleton{background:linear-gradient(90deg,var(--color-surface) 0%,var(--color-surface-hover) 50%,var(--color-surface) 100%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-surface);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-surface-hover)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}button:focus-visible,a:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.app-container{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1}
