:root{--elf-forest-green: #4a5d35;--workshop-dusty-blue: #5B7C8D;--warm-earth-tan: #D4A574;--burgundy-accent: #7F1D1D;--artisan-wood-brown: #6B4423;--parchment-cream: #F5EBD7;--success-warm-gold: #D4AF37;--alert-soft-red: #C85A54;--text-dark-soil: #3E3227;--text-medium-gray: #6B6B6B;--stone-50: #fafaf9;--stone-100: #f5f5f4;--stone-200: #e7e5e4;--stone-300: #d6d3d1;--stone-400: #a8a29e;--stone-500: #78716c;--stone-600: #57534e;--stone-700: #44403c;--stone-800: #292524;--stone-900: #1c1917;--emerald-100: #d1fae5;--emerald-600: #059669;--sky-100: #e0f2fe;--sky-600: #0284c7;--amber-100: #fef3c7;--amber-600: #d97706;--red-100: #fee2e2;--red-200: #fecaca;--red-600: #dc2626;--red-700: #b91c1c;--red-800: #991b1b;--cabin-dark-brown: #2A1E17;--cabin-card-brown: #382A22;--cabin-icon-green: #1dd1a1;--cabin-icon-brown: #4D3B31;--snow-white: #FFFFFF;--border-grey: #E1E4E8;--background-light: var(--parchment-cream);--primary: var(--elf-forest-green);--secondary: var(--workshop-dusty-blue);--accent: var(--burgundy-accent);--danger: var(--alert-soft-red);--success: var(--success-warm-gold);--warning: var(--warm-earth-tan);--info: var(--workshop-dusty-blue);--text-primary: var(--text-dark-soil);--text-secondary: var(--text-medium-gray);--light-bg: var(--parchment-cream);--light-card-bg: rgba(255, 255, 255, .7);--light-card-bg-solid: var(--snow-white);--light-card-border: var(--stone-200);--light-card-muted: rgba(231, 229, 228, .3);--light-header-bg: var(--elf-forest-green);--light-text: var(--stone-800);--light-text-muted: var(--stone-500);--light-text-dark: var(--stone-900);--light-btn-primary: var(--elf-forest-green);--dark-bg: var(--cabin-dark-brown);--dark-card-bg: var(--cabin-card-brown);--dark-card-border: var(--cabin-icon-brown);--dark-header-bg: var(--cabin-card-brown);--dark-text: var(--parchment-cream);--dark-text-muted: var(--warm-earth-tan);--dark-accent: var(--cabin-icon-green);--font-display: "Merriweather", "Georgia", "Times New Roman", serif;--font-body: "Lato", "Segoe UI", "Tahoma", sans-serif;--font-primary: var(--font-display);--font-secondary: var(--font-body);--font-decorative: var(--font-display);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-xxl: 3rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 20px;--radius-round: 50%;--shadow-sm: 0 2px 4px rgba(47, 82, 51, .1);--shadow-md: 0 4px 8px rgba(47, 82, 51, .15);--shadow-lg: 0 8px 16px rgba(47, 82, 51, .2);--shadow-xl: 0 12px 24px rgba(47, 82, 51, .25);--transition-fast: .15s ease-in-out;--transition-base: .3s ease-in-out;--transition-slow: .5s ease-in-out;--z-base: 1;--z-dropdown: 100;--z-sticky: 200;--z-overlay: 300;--z-modal: 400;--z-tooltip: 500}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-body);color:var(--text-primary);background-color:var(--parchment-cream);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--elf-forest-green);margin-bottom:var(--spacing-md);line-height:1.3;font-weight:700}h1{font-size:2rem;font-weight:700}h2{font-size:1.75rem;font-weight:600}h3{font-size:1.25rem;font-weight:600}h4{font-size:1.1rem;font-weight:500}a{color:var(--workshop-dusty-blue);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--elf-forest-green);text-decoration:underline}.btn{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-family:var(--font-body);font-size:1rem;font-weight:500;border:2px solid transparent;cursor:pointer;transition:all var(--transition-base);display:inline-block;text-align:center;text-decoration:none;line-height:1.5}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--burgundy-accent);color:var(--parchment-cream);border-color:var(--burgundy-accent);border-bottom-width:4px}.btn-primary:hover:not(:disabled){background-color:#722f2f;border-color:#722f2f;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background-color:var(--workshop-dusty-blue);color:var(--snow-white);border-color:var(--workshop-dusty-blue)}.btn-secondary:hover:not(:disabled){background-color:#4a6675;border-color:#4a6675;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-accent{background-color:var(--warm-earth-tan);color:var(--charcoal-grey);border-color:var(--warm-earth-tan)}.btn-accent:hover:not(:disabled){background-color:#c19660;border-color:#c19660;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-outline{background-color:transparent;color:var(--elf-forest-green);border-color:var(--elf-forest-green)}.btn-outline:hover:not(:disabled){background-color:var(--elf-forest-green);color:var(--snow-white)}.btn-danger{background-color:var(--burgundy-accent);color:var(--snow-white);border-color:var(--burgundy-accent)}.btn-danger:hover:not(:disabled){background-color:#722f2f;border-color:#722f2f}.btn-action{padding:var(--spacing-sm) var(--spacing-md);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity var(--transition-fast);font-family:var(--font-body);color:var(--snow-white)}.btn-action:hover:not(:disabled){opacity:.9}.btn-action.btn-green{background:var(--elf-forest-green)}.btn-action.btn-red{background:var(--red-700)}.btn-action.btn-yellow{background:var(--amber-100);color:var(--amber-600);border:1px solid var(--amber-600)}.btn-action.btn-yellow:hover:not(:disabled){background:var(--amber-100);opacity:.8}.btn-action.btn-full-width{width:100%;padding:var(--spacing-md);font-size:1rem;margin:var(--spacing-md) 0}.card{background-color:var(--warm-earth-tan);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base);border:2px solid var(--artisan-wood-brown)}.card:hover{box-shadow:var(--shadow-md)}.card-header{border-bottom:2px solid var(--warm-earth-tan);padding-bottom:var(--spacing-md);margin-bottom:var(--spacing-lg)}.form-label{display:block;margin-bottom:var(--spacing-sm);font-weight:500;color:var(--elf-forest-green);font-family:var(--font-display)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--text-medium-gray);border-radius:var(--radius-md);font-family:var(--font-body);font-size:1rem;background-color:var(--parchment-cream);color:var(--text-dark-soil);transition:border-color var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--text-dark-soil);box-shadow:0 0 0 3px #3e32271a}.form-textarea{min-height:100px;resize:vertical}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mt-1{margin-top:var(--spacing-sm)}.mt-2{margin-top:var(--spacing-md)}.mt-3{margin-top:var(--spacing-lg)}.mt-4{margin-top:var(--spacing-xl)}.mb-1{margin-bottom:var(--spacing-sm)}.mb-2{margin-bottom:var(--spacing-md)}.mb-3{margin-bottom:var(--spacing-lg)}.mb-4{margin-bottom:var(--spacing-xl)}.p-1{padding:var(--spacing-sm)}.p-2{padding:var(--spacing-md)}.p-3{padding:var(--spacing-lg)}.p-4{padding:var(--spacing-xl)}.elf-border{border:3px solid var(--warm-earth-tan);border-radius:var(--radius-lg);position:relative}.elf-border:before{content:"";position:absolute;inset:-6px;border:1px solid var(--workshop-dusty-blue);border-radius:calc(var(--radius-lg) + 3px);z-index:-1}.spinner{width:40px;height:40px;border:4px solid var(--parchment-cream);border-top:4px solid var(--elf-forest-green);border-radius:50%;animation:spin 1s linear infinite}@media(max-width:768px){h1{font-size:1.75rem}h2{font-size:1.5rem}h3{font-size:1.1rem}h4{font-size:1rem}}:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}a{font-weight:500;color:#667eea;text-decoration:inherit}a:hover{color:#764ba2}h1{line-height:1.2}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#667eea;color:#fff;cursor:pointer;transition:all .25s}button:hover{background-color:#5a6fd4;transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}button:active{transform:translateY(0)}button:focus,button:focus-visible{outline:2px solid #667eea;outline-offset:2px}ul{list-style-type:none}li:before{content:"✨ ";position:absolute;left:-1.5rem}.auth-container{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:var(--spacing-xl);background:var(--parchment-cream);position:relative}.auth-container:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 10% 20%,rgba(245,235,215,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(212,165,116,.1) 0%,transparent 50%),radial-gradient(circle at 40% 60%,rgba(91,124,141,.1) 0%,transparent 50%);pointer-events:none}.auth-card{background:var(--warm-earth-tan);border-radius:var(--radius-lg);padding:var(--spacing-xl);max-width:480px;width:100%;box-shadow:var(--shadow-xl);border:3px solid var(--artisan-wood-brown);position:relative;z-index:1}.auth-card:before,.auth-card:after{content:"✨";position:absolute;font-size:1.5rem}.auth-card:before{top:-12px;left:-12px}.auth-card:after{bottom:-12px;right:-12px}.auth-card h2{color:var(--elf-forest-green);margin-bottom:var(--spacing-sm);font-size:2rem;font-family:var(--font-primary);text-align:center}.auth-subtitle{color:var(--text-medium-gray);margin-bottom:var(--spacing-xl);text-align:center;font-family:var(--font-secondary)}.auth-form{margin-top:var(--spacing-xl)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:block;margin-bottom:var(--spacing-sm);color:var(--elf-forest-green);font-weight:500;font-size:.9rem;font-family:var(--font-primary)}.form-group input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--text-medium-gray);border-radius:var(--radius-md);font-size:1rem;transition:all var(--transition-fast);font-family:var(--font-secondary);background-color:var(--parchment-cream);color:var(--text-dark-soil)}.form-group input:focus{outline:none;border-color:var(--text-dark-soil);box-shadow:0 0 0 3px #3e32271a;background-color:var(--parchment-cream)}.form-group input.input-readonly{background-color:#e9ecef;cursor:not-allowed;opacity:.8}.form-group .field-hint{display:block;margin-top:var(--spacing-xs);color:var(--workshop-dusty-blue);font-size:.85rem;font-style:italic}.error-message{background:#8b3a3a1a;color:var(--burgundy-accent);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-size:.9rem;border:1px solid var(--burgundy-accent);font-family:var(--font-secondary)}.auth-button{width:100%;padding:var(--spacing-md);background:var(--burgundy-accent);color:var(--parchment-cream);border:none;border-radius:var(--radius-md);border-bottom:4px solid #722F2F;font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);margin-top:var(--spacing-sm);font-family:var(--font-secondary);position:relative;overflow:hidden}.auth-button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#fff3;transform:translate(-50%,-50%);transition:width .5s,height .5s}.auth-button:hover:before{width:300px;height:300px}.auth-button:hover:not(:disabled){background:#722f2f;transform:translateY(-1px);box-shadow:var(--shadow-md)}.auth-button:disabled{opacity:.7;cursor:not-allowed;background:var(--light-grey)}.forgot-password{text-align:center;margin-top:var(--spacing-md);font-size:.9rem;font-family:var(--font-secondary)}.forgot-password a{color:var(--workshop-dusty-blue);text-decoration:none}.forgot-password a:hover{text-decoration:underline}.forgot-password .coming-soon{color:var(--light-grey);font-size:.85rem;font-style:italic}.auth-footer{text-align:center;margin-top:var(--spacing-xl);padding-top:var(--spacing-xl);border-top:2px solid var(--artisan-wood-brown);color:var(--text-medium-gray);font-family:var(--font-secondary)}.auth-footer a{color:var(--workshop-dusty-blue);font-weight:600;text-decoration:none}.auth-footer a:hover{color:var(--elf-forest-green);text-decoration:underline}.auth-back-link{display:inline-block;margin-bottom:var(--spacing-lg);color:var(--workshop-dusty-blue);text-decoration:none;font-family:var(--font-secondary);transition:all var(--transition-fast)}.auth-back-link:hover{color:var(--elf-forest-green);transform:translate(-4px)}.auth-back-link:before{content:"← ";margin-right:var(--spacing-xs)}@media(max-width:768px){.auth-container{padding:var(--spacing-md)}.auth-card{padding:var(--spacing-lg)}.auth-card h2{font-size:1.5rem}.form-row{grid-template-columns:1fr}.auth-card:before,.auth-card:after{display:none}}.app-nav{background-color:var(--parchment-cream);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a;position:relative;border-bottom:2px solid var(--warm-earth-tan)}.nav-logo{height:50px;width:auto;display:block;transition:transform .2s ease}.nav-brand:hover .nav-logo{transform:scale(1.05)}.nav-right{display:flex;align-items:center;gap:1rem;position:relative}.nav-user{color:var(--text-dark-soil);font-size:.95rem;font-weight:500}.hamburger-menu{background:transparent;border:none;cursor:pointer;padding:.5rem;display:flex;flex-direction:column;gap:4px;width:30px;height:30px;justify-content:center}.hamburger-line{width:100%;height:3px;background-color:var(--cabin-dark-brown);border-radius:2px;transition:all .3s ease}.hamburger-menu:hover .hamburger-line{background-color:var(--burgundy-accent)}.nav-dropdown{position:absolute;top:100%;right:0;margin-top:1rem;background-color:var(--parchment-cream);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border:2px solid var(--warm-earth-tan);min-width:160px;display:none;flex-direction:column;overflow:hidden;z-index:1000}.nav-dropdown.open{display:flex}.nav-item{background:none;border:none;padding:.75rem 1.25rem;text-align:left;font-size:.95rem;cursor:pointer;color:var(--text-dark-soil);transition:background-color var(--transition-fast);border-bottom:1px solid var(--warm-earth-tan);font-family:var(--font-body)}.nav-item:last-child{border-bottom:none}.nav-item:hover{background-color:var(--warm-earth-tan);color:var(--elf-forest-green)}.nav-item.logout{color:var(--burgundy-accent);font-weight:500}.nav-item.logout:hover{background-color:var(--alert-soft-red);color:var(--parchment-cream)}.profile-check{color:var(--emerald-600);font-weight:700;margin-left:.5rem}.activity-card{padding:var(--spacing-md);background:var(--light-card-bg);border-radius:var(--radius-lg);border:1px solid var(--light-card-border);box-shadow:var(--shadow-sm);transition:all var(--transition-fast);cursor:pointer}.activity-card:hover{box-shadow:var(--shadow-md)}.activity-card--exchange:hover{border-color:var(--elf-forest-green)}.activity-card--game:hover{border-color:var(--workshop-dusty-blue)}.activity-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.activity-card-icon-title{display:flex;align-items:center;gap:var(--spacing-sm)}.activity-icon{flex-shrink:0}.activity-icon--exchange{color:var(--elf-forest-green)}.activity-icon--game{color:var(--workshop-dusty-blue)}.activity-card-title{cursor:pointer;transition:color var(--transition-fast);color:var(--light-text-dark);margin:0;font-family:var(--font-body);font-weight:700;font-size:1rem}.activity-card--exchange:hover .activity-card-title{color:var(--elf-forest-green)}.activity-card--game:hover .activity-card-title{color:var(--workshop-dusty-blue)}.activity-status{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-xl);font-size:.75rem;font-weight:600;font-family:var(--font-body)}.activity-status.matched{background:var(--emerald-100);color:var(--emerald-600)}.activity-status.pending{background:var(--amber-100);color:var(--amber-600)}.activity-status.pending-approval{background:var(--blue-100);color:var(--blue-700)}.activity-status.completed{background:var(--stone-200);color:var(--stone-600)}.activity-card-info{display:flex;flex-direction:column;gap:var(--spacing-sm)}.activity-member-row{display:flex;justify-content:space-between;align-items:center}.activity-member-count{color:var(--light-text-muted);font-size:.75rem;font-family:var(--font-body);margin:0}.activity-dates{display:flex;gap:var(--spacing-xl);padding:var(--spacing-sm) 0;font-size:.875rem}.activity-countdown{padding:var(--spacing-sm) var(--spacing-md);background:var(--emerald-100);color:var(--emerald-600);border-radius:var(--radius-md);text-align:center;font-weight:600;font-size:.875rem;font-family:var(--font-body)}.activity-actions{margin-top:var(--spacing-sm);display:flex;gap:var(--spacing-sm)}.btn-view-match-secondary:hover,.btn-manage{background:var(--elf-forest-green);color:var(--snow-white)}.btn-archive-small{padding:var(--spacing-xs) var(--spacing-sm);font-size:.75rem;background:var(--amber-100);color:var(--amber-700);border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-family:var(--font-body);transition:all var(--transition-fast)}.btn-archive-small:hover{background:var(--amber-200)}.btn-archive-small:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.activity-dates{flex-wrap:wrap;gap:var(--spacing-md)}}.activity-filters{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.filter-label{font-family:var(--font-body);font-size:.875rem;font-weight:700;color:var(--elf-forest-green)}.filter-select-wrapper{position:relative;display:inline-flex;align-items:center}.filter-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding:var(--spacing-sm) calc(var(--spacing-md) * 2.5) var(--spacing-sm) var(--spacing-md);background-color:#fbf9f3;border:1px solid var(--elf-forest-green);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.875rem;font-weight:500;color:var(--elf-forest-green);cursor:pointer;transition:all var(--transition-fast);min-width:150px;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%234a5d35' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right var(--spacing-sm) center;background-size:16px}.filter-select:hover{background-color:var(--elf-forest-green);color:var(--snow-white);background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e")}.filter-select:focus{outline:none;box-shadow:0 0 0 2px #4a5d3533}.filter-select option{font-family:var(--font-body);font-size:.875rem;padding:var(--spacing-sm);background:#fbf9f3;color:var(--elf-forest-green)}.filter-select-arrow{display:none}@media(max-width:480px){.activity-filters{width:100%}.filter-select-wrapper{flex:1}.filter-select{width:100%}}.step-indicator{display:flex;align-items:center;justify-content:center;gap:0;padding:var(--spacing-md) 0;margin-bottom:var(--spacing-lg)}.step{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);position:relative}.step-number{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-round);font-family:var(--font-body);font-size:.875rem;font-weight:600;background:var(--stone-200);color:var(--stone-500);transition:all var(--transition-fast)}.step.active .step-number,.step.completed .step-number{background:var(--elf-forest-green);color:var(--snow-white)}.step-label{font-family:var(--font-body);font-size:.75rem;font-weight:500;color:var(--stone-400);text-transform:uppercase;letter-spacing:.5px;transition:color var(--transition-fast)}.step.active .step-label{color:var(--elf-forest-green);font-weight:600}.step.completed .step-label{color:var(--stone-600)}.step-connector{width:40px;height:2px;background:var(--stone-200);margin:0 var(--spacing-xs);margin-bottom:20px;transition:background var(--transition-fast)}.step-connector.completed{background:var(--elf-forest-green)}@media(max-width:480px){.step-indicator{gap:0}.step-number{width:28px;height:28px;font-size:.75rem}.step-label{font-size:.625rem}.step-connector{width:24px;margin-bottom:18px}}.mode-selector{width:100%}.mode-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}.mode-card{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg);background:var(--stone-50);border:2px solid var(--stone-200);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:center;position:relative}.mode-card:hover:not(.disabled){border-color:var(--elf-forest-green);background:var(--snow-white);transform:translateY(-2px);box-shadow:var(--shadow-md)}.mode-card:focus:not(.disabled){outline:2px solid var(--elf-forest-green);outline-offset:2px}.mode-card.selected{border-color:var(--elf-forest-green);background:#ecf5ed;box-shadow:var(--shadow-sm)}.mode-card.disabled{opacity:.6;cursor:not-allowed;background:var(--stone-100)}.mode-icon{font-size:2.5rem;line-height:1}.mode-name{font-family:var(--font-display);font-weight:600;font-size:1.125rem;color:var(--elf-forest-green);margin:0}.mode-description{font-family:var(--font-body);font-size:.875rem;color:var(--light-text-muted);margin:0;line-height:1.4}.mode-card .coming-soon-badge{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);font-size:.625rem;font-weight:600;text-transform:uppercase;padding:3px 8px;background:var(--workshop-dusty-blue);color:var(--snow-white);border-radius:var(--radius-sm)}@media(max-width:768px){.mode-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.mode-grid{grid-template-columns:1fr}.mode-card{padding:var(--spacing-md);flex-direction:row;text-align:left;gap:var(--spacing-md)}.mode-icon{font-size:2rem;flex-shrink:0}.mode-card-content{flex:1}.mode-name{font-size:1rem}.mode-description{font-size:.8125rem}}.movie-card{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--stone-50);border:2px solid var(--stone-200);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.movie-card:hover{border-color:var(--elf-forest-green);background:var(--snow-white)}.movie-card:focus{outline:2px solid var(--elf-forest-green);outline-offset:2px}.movie-card.selected{border-color:var(--elf-forest-green);background:#ecf5ed}.movie-poster{width:80px;height:120px;flex-shrink:0;border-radius:var(--radius-md);overflow:hidden;background:var(--stone-200)}.movie-poster img{width:100%;height:100%;object-fit:cover}.poster-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--stone-200) 0%,var(--stone-300) 100%)}.poster-icon{font-size:2rem;opacity:.5}.movie-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--spacing-xs)}.movie-title{font-family:var(--font-display);font-weight:600;font-size:1rem;color:var(--light-text);margin:0;line-height:1.3}.movie-meta{font-family:var(--font-body);font-size:.8125rem;color:var(--light-text-muted);margin:0}.movie-questions{font-family:var(--font-body);font-size:.8125rem;color:var(--elf-forest-green);font-weight:500;margin:0}.movie-genres{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-top:var(--spacing-xs)}.genre-tag{font-size:.6875rem;font-weight:500;padding:2px 6px;background:var(--stone-200);color:var(--stone-600);border-radius:var(--radius-sm)}.movie-checkbox{flex-shrink:0;padding-top:var(--spacing-xs)}.checkbox{width:24px;height:24px;border:2px solid var(--stone-300);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;background:var(--snow-white);transition:all var(--transition-fast)}.movie-card:hover .checkbox{border-color:var(--elf-forest-green)}.checkbox.checked{background:var(--elf-forest-green);border-color:var(--elf-forest-green)}.checkmark{color:var(--snow-white);font-size:.875rem;font-weight:700}@media(max-width:480px){.movie-poster{width:60px;height:90px}.movie-title{font-size:.9375rem}.poster-icon{font-size:1.5rem}}.movie-selector{width:100%}.movie-selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--stone-200)}.selection-info{display:flex;flex-direction:column;gap:2px}.selection-count{font-family:var(--font-body);font-size:.875rem;font-weight:500;color:var(--light-text)}.validation-hint{font-family:var(--font-body);font-size:.75rem;color:var(--alert-soft-red)}.selection-actions{display:flex;align-items:center;gap:var(--spacing-xs)}.btn-link{background:none;border:none;padding:var(--spacing-xs) var(--spacing-sm);font-family:var(--font-body);font-size:.8125rem;font-weight:500;color:var(--elf-forest-green);cursor:pointer;transition:opacity var(--transition-fast)}.btn-link:hover:not(:disabled){opacity:.8;text-decoration:underline}.btn-link:disabled{color:var(--stone-400);cursor:not-allowed}.divider{color:var(--stone-300);font-size:.75rem}.movie-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md);max-height:400px;overflow-y:auto;padding-right:var(--spacing-xs)}.movie-loading{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-xl);color:var(--light-text-muted);font-family:var(--font-body);font-size:.875rem}.movie-loading .loading-spinner{display:inline-block;width:1.25rem;height:1.25rem;border:2px solid var(--stone-300);border-radius:50%;border-top-color:var(--elf-forest-green);animation:spin .8s linear infinite}.movie-error{padding:var(--spacing-md);background:var(--red-100);border:1px solid var(--alert-soft-red);border-radius:var(--radius-md);color:var(--burgundy-accent);font-size:.875rem;font-family:var(--font-body);text-align:center}.no-movies-message{font-family:var(--font-body);font-size:.875rem;color:var(--light-text-muted);text-align:center;padding:var(--spacing-xl);margin:0}@media(max-width:768px){.movie-grid{grid-template-columns:1fr}}@media(max-width:480px){.movie-selector-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.movie-grid{max-height:350px}}.difficulty-slider{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-sm) 0}.slider-header{display:flex;justify-content:space-between;align-items:center}.difficulty-label{font-family:var(--font-body);font-weight:600;font-size:.9375rem}.slider-value{font-family:var(--font-body);font-size:.9375rem;font-weight:600;color:var(--light-text)}.slider-max{font-weight:400;font-size:.8125rem;color:var(--light-text-muted);margin-left:var(--spacing-xs)}.slider-track-container{position:relative;height:8px;background:var(--stone-200);border-radius:var(--radius-sm);overflow:hidden}.slider-input{position:absolute;top:0;left:0;width:100%;height:100%;margin:0;padding:0;opacity:0;cursor:pointer;z-index:2}.slider-fill{position:absolute;top:0;left:0;height:100%;border-radius:var(--radius-sm);transition:width var(--transition-fast)}.slider-input::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;background:var(--snow-white);border:2px solid var(--slider-color, var(--elf-forest-green));border-radius:var(--radius-round);cursor:pointer;box-shadow:var(--shadow-sm)}.slider-input::-moz-range-thumb{width:20px;height:20px;background:var(--snow-white);border:2px solid var(--slider-color, var(--elf-forest-green));border-radius:var(--radius-round);cursor:pointer;box-shadow:var(--shadow-sm)}.slider-warning{font-family:var(--font-body);font-size:.75rem;color:var(--alert-soft-red);font-style:italic}@media(max-width:480px){.slider-header{flex-direction:column;align-items:flex-start;gap:2px}.slider-value{font-size:.8125rem}}.quiz-config-step{display:flex;flex-direction:column;gap:var(--spacing-lg)}.config-section{display:flex;flex-direction:column;gap:var(--spacing-sm)}.section-title{font-family:var(--font-display);font-size:1.125rem;font-weight:600;color:var(--elf-forest-green);margin:0;display:flex;align-items:center;gap:var(--spacing-sm)}.section-description{font-family:var(--font-body);font-size:.875rem;color:var(--light-text-muted);margin:0}.custom-badge{font-family:var(--font-body);font-size:.6875rem;font-weight:500;text-transform:uppercase;padding:2px 8px;background:var(--stone-200);color:var(--stone-600);border-radius:var(--radius-sm)}.presets-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-sm)}.preset-btn{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md);background:var(--stone-50);border:2px solid var(--stone-200);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:center}.preset-btn:hover{border-color:var(--elf-forest-green);background:var(--snow-white)}.preset-btn.selected{border-color:var(--elf-forest-green);background:#ecf5ed}.preset-icon{font-size:1.5rem}.preset-name{font-family:var(--font-body);font-weight:600;font-size:.875rem;color:var(--light-text)}.preset-desc{font-family:var(--font-body);font-size:.75rem;color:var(--light-text-muted);line-height:1.3}.preset-counts{font-family:var(--font-body);font-size:.6875rem;font-weight:500;color:var(--stone-500);padding:2px 6px;background:var(--stone-100);border-radius:var(--radius-sm)}.sliders-container{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--stone-50);border-radius:var(--radius-md)}.total-questions{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--stone-100);border-radius:var(--radius-md);margin-top:var(--spacing-sm)}.total-label{font-family:var(--font-body);font-size:.9375rem;color:var(--light-text)}.total-value{font-family:var(--font-body);font-size:1.25rem;font-weight:700;color:var(--elf-forest-green)}.total-value.exceeds-max{color:var(--alert-soft-red)}.total-max{font-family:var(--font-body);font-size:.875rem;color:var(--light-text-muted)}.validation-error{padding:var(--spacing-sm) var(--spacing-md);background:var(--red-100);border:1px solid var(--alert-soft-red);border-radius:var(--radius-md);color:var(--burgundy-accent);font-size:.875rem;font-family:var(--font-body)}.timing-grid{display:grid;gap:var(--spacing-md)}.timing-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.timing-label{font-family:var(--font-body);font-size:.875rem;font-weight:500;color:var(--light-text)}.timing-input{padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--stone-300);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.9375rem;color:var(--light-text);background:var(--snow-white);transition:border-color var(--transition-fast)}.timing-input:focus{outline:none;border-color:var(--elf-forest-green)}.timing-hint{font-family:var(--font-body);font-size:.75rem;color:var(--light-text-muted);font-style:italic}.config-summary{padding:var(--spacing-md);background:var(--stone-100);border-radius:var(--radius-md)}.summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}.summary-item{display:flex;flex-direction:column;align-items:center;gap:2px}.summary-label{font-family:var(--font-body);font-size:.75rem;font-weight:500;color:var(--light-text-muted);text-transform:uppercase}.summary-value{font-family:var(--font-display);font-size:1.25rem;font-weight:600;color:var(--elf-forest-green)}.submit-error{padding:var(--spacing-md);background:var(--red-100);border:1px solid var(--alert-soft-red);border-radius:var(--radius-md);color:var(--burgundy-accent);font-size:.9375rem;font-family:var(--font-body);text-align:center}.config-actions{display:flex;justify-content:space-between;gap:var(--spacing-md);padding-top:var(--spacing-lg);border-top:1px solid var(--stone-200);margin-top:var(--spacing-md)}.btn-back:hover:not(:disabled){background:var(--stone-100);border-color:var(--stone-400)}.btn-back:disabled{opacity:.5;cursor:not-allowed}.btn-create{padding:var(--spacing-sm) var(--spacing-xl);background:var(--elf-forest-green);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.btn-create:hover:not(:disabled){opacity:.9}.btn-create:disabled{background:var(--stone-300);cursor:not-allowed}@media(max-width:768px){.presets-grid{grid-template-columns:repeat(2,1fr)}.summary-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:480px){.presets-grid{grid-template-columns:1fr 1fr}.preset-btn{padding:var(--spacing-sm)}.preset-desc{display:none}.config-actions{flex-direction:column;gap:var(--spacing-sm)}.btn-back,.btn-create{width:100%;text-align:center}}.countdown-timer{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-lg);background:var(--stone-100);border-radius:var(--radius-lg);text-align:center}.countdown-label{font-family:var(--font-body);font-size:.875rem;color:var(--light-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-xs)}.countdown-value{font-family:var(--font-heading);font-size:2.5rem;font-weight:700;color:var(--elf-forest-green)}.countdown-timer.starting-soon{background:var(--amber-100)}.countdown-timer.starting-soon .countdown-value{color:var(--amber-700);animation:pulse 1s ease-in-out infinite}.countdown-timer.starting-now{background:var(--elf-forest-green)}.countdown-timer.starting-now .countdown-label{color:var(--snow-white);font-size:1.25rem;font-weight:600;text-transform:none;animation:pulse .5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@media(max-width:480px){.countdown-timer{padding:var(--spacing-md)}.countdown-value{font-size:2rem}}.participant-list{background:var(--snow-white);border:1px solid var(--stone-200);border-radius:var(--radius-lg);overflow:hidden}.participant-list-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:var(--stone-50);border-bottom:1px solid var(--stone-200)}.participant-list-title{font-family:var(--font-heading);font-size:1rem;font-weight:600;color:var(--light-text);margin:0}.refresh-indicator{display:flex;align-items:center}.refresh-dot{width:8px;height:8px;background:var(--elf-forest-green);border-radius:var(--radius-round);animation:pulse-dot 1s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:.3}50%{opacity:1}}.participant-items{list-style:none;margin:0;padding:0;max-height:300px;overflow-y:auto}.participant-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border-bottom:1px solid var(--stone-100)}.participant-item:last-child{border-bottom:none}.participant-item.is-current-user{background:var(--emerald-50)}.participant-status-icon{font-size:1rem;width:24px;text-align:center}.participant-info{display:flex;flex-direction:column;gap:2px;flex:1}.participant-name{font-family:var(--font-body);font-size:.9375rem;color:var(--light-text);display:flex;align-items:center;gap:var(--spacing-xs)}.organizer-badge{font-size:.6875rem;font-weight:500;text-transform:uppercase;letter-spacing:.03em;color:var(--amber-700);background:var(--amber-100);padding:2px 6px;border-radius:var(--radius-sm)}.you-badge{font-size:.6875rem;font-weight:500;text-transform:uppercase;letter-spacing:.03em;color:var(--elf-forest-green);background:var(--emerald-100);padding:2px 6px;border-radius:var(--radius-sm)}.participant-status-text{font-size:.75rem;color:var(--light-text-muted);font-style:italic}.no-participants{padding:var(--spacing-lg);text-align:center;color:var(--light-text-muted)}.no-participants p{margin:0}@media(max-width:480px){.participant-list-header,.participant-item{padding-left:var(--spacing-md);padding-right:var(--spacing-md)}}.quiz-question-card{background:var(--snow-white);border:1px solid var(--stone-200);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.quiz-question-meta{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.quiz-difficulty-badge{font-family:var(--font-body);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;padding:4px 10px;border-radius:var(--radius-sm)}.quiz-difficulty-badge.difficulty--easy{background:var(--emerald-100);color:var(--emerald-700)}.quiz-difficulty-badge.difficulty--medium{background:var(--amber-100);color:var(--amber-700)}.quiz-difficulty-badge.difficulty--hard{background:var(--red-100);color:var(--red-700)}.quiz-category-badge{font-family:var(--font-body);font-size:.75rem;font-weight:500;text-transform:capitalize;padding:4px 10px;background:var(--stone-100);color:var(--stone-600);border-radius:var(--radius-sm)}.quiz-question-text{font-family:var(--font-display);font-size:1.375rem;font-weight:600;color:var(--light-text);line-height:1.4;margin:0}@media(max-width:480px){.quiz-question-card{padding:var(--spacing-md)}.quiz-question-text{font-size:1.125rem}}.answer-options{display:flex;flex-direction:column;gap:var(--spacing-sm)}.answer-btn{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:var(--snow-white);border:2px solid var(--stone-200);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left;min-height:44px;touch-action:manipulation;font-family:var(--font-body)}.answer-btn:hover:not(:disabled){border-color:var(--elf-forest-green);background:var(--stone-50)}.answer-btn.selected{border-color:var(--elf-forest-green);background:#ecf5ed}.answer-btn:disabled{opacity:.6;cursor:not-allowed}.answer-indicator{flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:2px}.radio-indicator{width:20px;height:20px;border:2px solid var(--stone-400);border-radius:50%;background:var(--snow-white);position:relative;transition:all var(--transition-fast)}.radio-indicator.checked{border-color:var(--elf-forest-green)}.radio-indicator.checked:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:10px;height:10px;background:var(--elf-forest-green);border-radius:50%}.checkbox-indicator{width:20px;height:20px;border:2px solid var(--stone-400);border-radius:var(--radius-sm);background:var(--snow-white);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:var(--snow-white);transition:all var(--transition-fast)}.checkbox-indicator.checked{background:var(--elf-forest-green);border-color:var(--elf-forest-green)}.answer-text{font-size:1rem;color:var(--light-text);line-height:1.4;flex:1}@media(max-width:480px){.answer-btn{padding:var(--spacing-sm) var(--spacing-md);gap:var(--spacing-sm)}.answer-text{font-size:.9375rem}}.progress-indicator{display:flex;flex-direction:column;gap:var(--spacing-xs)}.progress-text{font-family:var(--font-body);font-size:.875rem;color:var(--light-text-muted)}.progress-current{font-weight:600;color:var(--elf-forest-green)}.progress-total{font-weight:500;color:var(--light-text)}.progress-bar{width:100%;height:8px;background:var(--stone-200);border-radius:var(--radius-round);overflow:hidden}.progress-fill{height:100%;background:var(--elf-forest-green);border-radius:var(--radius-round);transition:width var(--transition-normal)}.quiz-timer{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--stone-100);border-radius:var(--radius-md);font-family:var(--font-body);transition:all var(--transition-fast)}.quiz-timer.low{background:var(--amber-100);color:var(--amber-700)}.quiz-timer.very-low{background:var(--red-100);color:var(--red-700);animation:timer-pulse 1s ease-in-out infinite}@keyframes timer-pulse{0%,to{opacity:1}50%{opacity:.7}}.timer-icon{font-size:1rem}.timer-value{font-size:1.125rem;font-weight:600;font-variant-numeric:tabular-nums;color:inherit}.timer-label{font-size:.75rem;color:var(--light-text-muted)}.quiz-timer.low .timer-label,.quiz-timer.very-low .timer-label{color:inherit;opacity:.8}.anti-cheat-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.anti-cheat-modal{background:var(--snow-white);border-radius:var(--radius-lg);max-width:480px;width:100%;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.anti-cheat-modal-content{padding:var(--spacing-xl);text-align:center}.warning-icon{font-size:3rem;color:var(--amber-500, #f59e0b);margin-bottom:var(--spacing-md)}.anti-cheat-modal h2{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--light-text);margin:0 0 var(--spacing-md) 0}.warning-description{font-family:var(--font-body);font-size:1rem;color:var(--light-text);margin:0 0 var(--spacing-md) 0;line-height:1.5}.rules-list{text-align:left;margin:0 0 var(--spacing-md) 0;padding-left:var(--spacing-lg);font-family:var(--font-body);font-size:.9375rem;color:var(--light-text);line-height:1.8}.rules-list li{margin-bottom:var(--spacing-xs)}.tip-text{font-family:var(--font-body);font-size:.875rem;color:var(--elf-forest-green);background:var(--stone-100);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);margin:0 0 var(--spacing-lg) 0}.btn-accept{background:var(--elf-forest-green);color:var(--snow-white);border:none;padding:var(--spacing-sm) var(--spacing-xl);border-radius:var(--radius-md);font-family:var(--font-body);font-size:1rem;font-weight:600;cursor:pointer;transition:opacity var(--transition-fast);min-width:160px}.btn-accept:hover{opacity:.9}@media(max-width:480px){.anti-cheat-modal-content{padding:var(--spacing-lg)}.anti-cheat-modal h2{font-size:1.25rem}.warning-description{font-size:.9375rem}}.anti-cheat-indicator{display:flex;align-items:center;gap:6px;font-family:var(--font-body);font-size:.75rem;color:var(--elf-forest-green);background:var(--stone-100);padding:4px 10px;border-radius:var(--radius-sm)}.pulse-dot{width:8px;height:8px;background:var(--elf-forest-green);border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.indicator-text{text-transform:uppercase;letter-spacing:.5px;font-weight:600}.violation-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1100;padding:var(--spacing-md)}.violation-modal{background:var(--snow-white);border-radius:var(--radius-lg);max-width:400px;width:100%;box-shadow:0 20px 60px #0006;animation:violationShake .4s ease-out;border:3px solid var(--amber-500, #f59e0b)}@keyframes violationShake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}.violation-modal-content{padding:var(--spacing-xl);text-align:center}.violation-icon{font-size:3.5rem;color:var(--amber-500, #f59e0b);margin-bottom:var(--spacing-sm)}.violation-modal h2{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--red-600, #dc2626);margin:0 0 var(--spacing-md) 0}.violation-description{font-family:var(--font-body);font-size:1rem;color:var(--light-text);margin:0 0 var(--spacing-sm) 0}.violation-warning{font-family:var(--font-body);font-size:.9375rem;color:var(--red-600, #dc2626);background:var(--red-50, #fef2f2);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);margin:0 0 var(--spacing-lg) 0;line-height:1.5}.btn-continue{background:var(--elf-forest-green);color:var(--snow-white);border:none;padding:var(--spacing-sm) var(--spacing-xl);border-radius:var(--radius-md);font-family:var(--font-body);font-size:1rem;font-weight:600;cursor:pointer;transition:opacity var(--transition-fast);min-width:160px}.btn-continue:hover{opacity:.9}@media(max-width:480px){.violation-modal-content{padding:var(--spacing-lg)}.violation-modal h2{font-size:1.25rem}}.winner-announcement{text-align:center;padding:40px 24px;background:linear-gradient(135deg,gold,#ffec8b,gold);border-radius:16px;margin-bottom:32px;box-shadow:0 4px 20px #ffd7004d;position:relative;overflow:hidden}.winner-announcement:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(255,255,255,.1) 10px,rgba(255,255,255,.1) 20px);animation:shimmer 3s linear infinite}@keyframes shimmer{0%{transform:translate(-50%) translateY(-50%) rotate(0)}to{transform:translate(-50%) translateY(-50%) rotate(360deg)}}.crown-icon{font-size:64px;margin-bottom:8px;position:relative;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.winner-title{font-size:1.5rem;font-weight:800;color:#8b4513;margin:0 0 8px;letter-spacing:4px;text-shadow:2px 2px 0 rgba(255,255,255,.5);position:relative}.winner-name{font-size:2rem;font-weight:700;color:#2f5233;margin:0 0 12px;position:relative}.winner-score{font-size:1.75rem;font-weight:700;color:#1a3a1f;margin:0 0 8px;position:relative}.winner-time{font-size:1rem;color:#5c3d1e;margin:0;position:relative}.winner-violations{font-size:.875rem;color:#c9302c;margin:8px 0 0;position:relative}@media(max-width:600px){.winner-announcement{padding:32px 16px}.crown-icon{font-size:48px}.winner-name,.winner-score{font-size:1.5rem}}.leaderboard{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014}.leaderboard h3{margin:0 0 16px;color:var(--color-primary);font-size:1.25rem}.leaderboard-table{width:100%}.leaderboard-header{display:grid;grid-template-columns:60px 1fr 80px 80px;gap:8px;padding:12px 16px;background:var(--color-background);border-radius:8px;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary)}.leaderboard-body{margin-top:8px}.leaderboard-row{display:grid;grid-template-columns:60px 1fr 80px 80px;gap:8px;padding:12px 16px;align-items:center;border-radius:8px;transition:background-color .2s}.leaderboard-row:hover{background:var(--color-background)}.leaderboard-row.current-user{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border:2px solid var(--color-primary)}.leaderboard-row.rank-1{background:linear-gradient(135deg,#fff8e1,#ffecb3)}.leaderboard-row.rank-2{background:linear-gradient(135deg,#fafafa,#e0e0e0)}.leaderboard-row.rank-3{background:linear-gradient(135deg,#fff3e0,#ffe0b2)}.col-rank{font-weight:600}.rank-medal{font-size:1.25rem}.col-name{display:flex;align-items:center;gap:8px;font-weight:500;color:var(--color-text)}.violation-badge{font-size:.875rem;cursor:help}.col-score{font-weight:600;color:var(--color-primary)}.col-time{color:var(--color-text-secondary);font-size:.875rem}@media(max-width:600px){.leaderboard-header,.leaderboard-row{grid-template-columns:50px 1fr 60px 70px;padding:10px 12px;font-size:.875rem}.rank-medal{font-size:1rem}.col-time{font-size:.75rem}}.question-stat-card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 8px #00000014}.question-stat-card.stat-missed{border-left:4px solid #e53935}.question-stat-card.stat-aced{border-left:4px solid #43a047}.question-stat-card.stat-divisive{border-left:4px solid #fb8c00}.stat-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.stat-icon{font-size:1.5rem}.stat-header h4{margin:0;font-size:1rem;color:var(--color-text)}.question-text{font-style:italic;color:var(--color-text-secondary);margin:0 0 12px;font-size:.875rem;line-height:1.4}.stat-value{font-weight:600;color:var(--color-primary);margin:0 0 12px;font-size:.875rem}.answer-distribution{border-top:1px solid var(--color-border);padding-top:12px}.correct-answer-label{font-size:.75rem;color:var(--color-text-secondary);margin:0 0 8px}.correct-answer-label strong{color:#43a047}.distribution-bars{display:flex;flex-direction:column;gap:6px}.distribution-row{display:grid;grid-template-columns:100px 1fr 30px;gap:8px;align-items:center;font-size:.75rem}.answer-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--color-text-secondary)}.answer-label.correct{color:#43a047;font-weight:600}.bar-container{height:8px;background:var(--color-background);border-radius:4px;overflow:hidden}.bar{height:100%;background:var(--color-secondary);border-radius:4px;min-width:2px;transition:width .3s ease}.bar.bar-correct{background:#43a047}.count{text-align:right;color:var(--color-text-secondary);font-weight:500}@media(max-width:600px){.question-stat-card{padding:14px}.distribution-row{grid-template-columns:80px 1fr 25px;gap:6px}}.participant-stats{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014}.participant-stats h3{margin:0 0 16px;color:var(--color-primary);font-size:1.25rem}.speed-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:16px}.speed-stat-card{display:flex;align-items:center;gap:12px;padding:16px;border-radius:10px}.speed-stat-card.fastest{background:linear-gradient(135deg,#fff8e1,#ffecb3);border:1px solid #ffd54f}.speed-stat-card.slowest{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border:1px solid #81c784}.speed-icon{font-size:2rem}.speed-content{display:flex;flex-direction:column;gap:2px}.speed-label{font-size:.75rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.speed-name{font-weight:600;color:var(--color-text)}.speed-time{font-size:.875rem;color:var(--color-primary);font-weight:500}.avg-time{display:flex;justify-content:center;gap:8px;padding-top:16px;border-top:1px solid var(--color-border)}.avg-label{color:var(--color-text-secondary);font-size:.875rem}.avg-value{font-weight:600;color:var(--color-primary);font-size:.875rem}@media(max-width:600px){.speed-stats-grid{grid-template-columns:1fr}}.all-answers-review{margin-top:16px}.all-answers-review h3{color:var(--color-primary);margin:0 0 16px;font-size:1.125rem}.questions-list{display:flex;flex-direction:column;gap:12px}.question-review-card{background:#fff;border-radius:10px;padding:16px;box-shadow:0 1px 4px #0000000f;border:1px solid var(--color-border)}.question-review-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.question-number{font-weight:700;color:var(--color-text-secondary);font-size:.875rem}.result-badge{padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:600}.result-badge.correct{background:#e8f5e9;color:#2e7d32}.result-badge.incorrect{background:#ffebee;color:#c62828}.question-review-card .question-text{margin:0 0 12px;color:var(--color-text);font-size:.9375rem;line-height:1.4}.answer-section{display:flex;flex-direction:column;gap:8px;padding-top:12px;border-top:1px solid var(--color-border)}.correct-answer,.user-answer{display:flex;align-items:flex-start;gap:8px;font-size:.875rem}.correct-answer .answer-icon{color:#43a047;font-weight:700}.user-answer .answer-icon{color:#e53935;font-weight:700}.correct-answer .answer-text{color:#2e7d32}.user-answer .answer-text{color:#c62828}.response-time{font-size:.75rem;color:var(--color-text-secondary);margin-top:4px}@media(max-width:600px){.question-review-card{padding:14px}.question-review-card .question-text{font-size:.875rem}}.btn-share{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s;border:2px solid var(--color-secondary);background:#fff;color:var(--color-secondary)}.btn-share:hover{background:var(--color-secondary);color:#fff}.btn-share.copied{background:#43a047;border-color:#43a047;color:#fff}.share-icon{font-size:1.125rem}.quiz-card{position:relative;background:var(--light-card-bg);border-radius:var(--radius-lg);padding:var(--spacing-md);border:1px solid var(--light-card-border);box-shadow:var(--shadow-sm);cursor:pointer;transition:all var(--transition-fast)}.quiz-card:hover{box-shadow:var(--shadow-md);border-color:var(--stone-300)}.quiz-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.quiz-card-icon-title{display:flex;align-items:center;gap:var(--spacing-sm);flex:1;min-width:0}.quiz-card-icon{width:20px;height:20px;flex-shrink:0;color:#7b1fa2}.quiz-card-title{font-size:.9375rem;font-weight:700;color:var(--light-text-dark);margin:0;font-family:var(--font-body);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.quiz-card-movies{font-size:.8125rem;color:var(--light-text);font-family:var(--font-body);margin-bottom:var(--spacing-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.movie-label{color:var(--light-text-muted)}.quiz-status{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-xl);font-size:.6875rem;font-weight:600;font-family:var(--font-body);text-transform:uppercase;letter-spacing:.025em;white-space:nowrap;flex-shrink:0}.quiz-status--draft{background:var(--stone-200);color:var(--stone-600)}.quiz-status--scheduled{background:var(--sky-100);color:var(--sky-600)}.quiz-status--active{background:var(--emerald-100);color:var(--emerald-600)}.quiz-status--completed{background:#f3e5f5;color:#7b1fa2}.quiz-status--cancelled{background:var(--red-100);color:var(--red-600)}.quiz-card-info{display:flex;flex-direction:column;align-items:stretch;gap:var(--spacing-sm)}.quiz-card-details{display:flex;gap:var(--spacing-lg);padding:var(--spacing-sm) 0;justify-content:flex-start;text-align:left}.quiz-detail-item{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.quiz-detail-label{font-size:.75rem;color:var(--light-text-muted);font-family:var(--font-body)}.quiz-detail-value{font-size:.875rem;color:var(--light-text);font-weight:600;font-family:var(--font-body)}.quiz-card-actions{margin-top:var(--spacing-sm);display:flex;gap:var(--spacing-sm)}.btn-play-quiz,.btn-view-results,.btn-view-quiz,.btn-manage-quiz,.btn-play-quiz-secondary,.btn-view-results-secondary{flex:1;padding:var(--spacing-sm);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.btn-manage-quiz{background:#7b1fa2;color:var(--snow-white)}.btn-manage-quiz:hover{background:#6a1b8a}.btn-play-quiz{background:var(--emerald-600);color:var(--snow-white)}.btn-play-quiz:hover{opacity:.9}.btn-play-quiz-secondary{background:transparent;color:var(--emerald-600);border:1px solid var(--emerald-600)}.btn-play-quiz-secondary:hover{background:var(--emerald-50)}.btn-view-results{background:#7b1fa2;color:var(--snow-white)}.btn-view-results:hover{opacity:.9}.btn-view-results-secondary{background:transparent;color:#7b1fa2;border:1px solid #7b1fa2}.btn-view-results-secondary:hover{background:#f3e5f5}.btn-view-quiz{background:var(--stone-200);color:var(--stone-700)}.btn-view-quiz:hover{background:var(--stone-300)}.quiz-actions-menu{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);z-index:var(--z-dropdown)}.quiz-menu-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;color:var(--stone-500);transition:all var(--transition-fast)}.quiz-menu-btn:hover{background:var(--stone-100);color:var(--stone-700)}.menu-dots{font-size:1.25rem;line-height:1}.quiz-dropdown-menu{position:absolute;top:100%;right:0;margin-top:4px;background:var(--snow-white);border:1px solid var(--light-card-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);min-width:120px;overflow:hidden}.quiz-dropdown-menu button{width:100%;padding:var(--spacing-sm) var(--spacing-md);text-align:left;background:none;border:none;font-size:.875rem;font-family:var(--font-body);color:var(--light-text);cursor:pointer;transition:background var(--transition-fast)}.quiz-dropdown-menu button:hover{background:var(--stone-100)}.quiz-dropdown-menu button.danger{color:var(--red-600)}.quiz-dropdown-menu button.danger:hover{background:var(--red-100)}@media(max-width:480px){.quiz-card-details{flex-wrap:wrap;gap:var(--spacing-md)}}.add-activity-modal{width:500px;max-width:95vw;padding:var(--spacing-lg);max-height:85vh;overflow-y:auto}.add-activity-content{display:flex;flex-direction:column;gap:var(--spacing-lg)}.add-activity-modal .modal-title{font-family:var(--font-display);font-size:1.5rem;color:var(--elf-forest-green);margin:0;text-align:center}.add-activity-modal .modal-subtitle{font-family:var(--font-body);font-size:.875rem;color:var(--light-text-muted);margin:0;text-align:center}.activity-step{display:flex;flex-direction:column;gap:var(--spacing-sm)}.step-label{font-family:var(--font-body);font-size:.875rem;font-weight:600;color:var(--light-text);margin:0}.step-hint{font-family:var(--font-body);font-size:.75rem;color:var(--light-text-muted);margin:0}.activity-type-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm)}.activity-type-card{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md);background:var(--stone-50);border:2px solid var(--stone-200);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:center;position:relative}.activity-type-card:hover:not(.disabled){border-color:var(--elf-forest-green);background:var(--snow-white)}.activity-type-card.selected{border-color:var(--elf-forest-green);background:var(--emerald-50)}.activity-type-card.disabled{opacity:.6;cursor:not-allowed;background:var(--stone-100)}.activity-type-icon{font-size:2rem}.activity-type-name{font-family:var(--font-body);font-weight:600;font-size:.9375rem;color:var(--light-text)}.activity-type-desc{font-family:var(--font-body);font-size:.75rem;color:var(--light-text-muted)}.coming-soon-badge{position:absolute;top:var(--spacing-xs);right:var(--spacing-xs);font-size:.625rem;font-weight:600;text-transform:uppercase;padding:2px 6px;background:var(--workshop-dusty-blue);color:var(--snow-white);border-radius:var(--radius-sm)}.group-loading{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);color:var(--light-text-muted);font-family:var(--font-body);font-size:.875rem}.group-loading .loading-spinner{display:inline-block;width:1rem;height:1rem;border:2px solid var(--stone-300);border-radius:50%;border-top-color:var(--elf-forest-green);animation:spin .8s linear infinite}.group-error{padding:var(--spacing-sm) var(--spacing-md);background:var(--red-50);border:1px solid var(--alert-soft-red);border-radius:var(--radius-md);color:var(--burgundy-accent);font-size:.875rem;font-family:var(--font-body);text-align:center}.group-selection{display:flex;flex-direction:column;gap:var(--spacing-xs);max-height:200px;overflow-y:auto;padding:var(--spacing-xs)}.group-option{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--stone-50);border:1px solid var(--stone-200);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%}.group-option:hover:not(:disabled){border-color:var(--elf-forest-green);background:var(--snow-white)}.group-option.selected{border-color:var(--elf-forest-green);background:var(--emerald-50)}.group-option.has-exchange{opacity:.5;cursor:not-allowed}.group-option:disabled{cursor:not-allowed}.group-option-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--stone-200);border-radius:var(--radius-round);font-size:1rem;color:var(--light-text);flex-shrink:0}.group-option.selected .group-option-icon{background:var(--elf-forest-green);color:var(--snow-white)}.group-option-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.group-option-name{font-family:var(--font-body);font-weight:500;font-size:.875rem;color:var(--light-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-option-meta{font-family:var(--font-body);font-size:.75rem;color:var(--light-text-muted)}.group-option-check{font-size:1rem;color:var(--elf-forest-green);font-weight:600;flex-shrink:0}.no-groups-message{font-family:var(--font-body);font-size:.875rem;color:var(--light-text-muted);text-align:center;padding:var(--spacing-md);margin:0}.add-activity-modal .modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);margin-top:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid var(--stone-200)}.add-activity-modal .btn-cancel{padding:var(--spacing-sm) var(--spacing-lg);background:transparent;color:var(--stone-600);border:1px solid var(--stone-300);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.add-activity-modal .btn-cancel:hover{background:var(--stone-100);border-color:var(--stone-400)}.add-activity-modal .btn-continue{padding:var(--spacing-sm) var(--spacing-lg);background:var(--elf-forest-green);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.add-activity-modal .btn-continue:hover:not(:disabled){opacity:.9}.add-activity-modal .btn-continue:disabled{background:var(--stone-300);cursor:not-allowed}@media(max-width:480px){.add-activity-modal{width:100%;margin:var(--spacing-md);padding:var(--spacing-md)}.activity-type-grid{grid-template-columns:1fr}.group-selection{max-height:150px}}.dashboard-container{min-height:100vh;background:var(--light-bg);padding:var(--spacing-lg)}.dashboard-content{max-width:600px;margin:0 auto}.dashboard-header{margin-bottom:var(--spacing-lg)}.dashboard-header h2{font-family:var(--font-display);font-size:2rem;color:var(--elf-forest-green);margin:0}.dashboard-grid{display:flex;flex-direction:column;gap:var(--spacing-lg)}.dashboard-card{background:var(--light-card-bg);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);border:1px solid var(--light-card-border)}.dashboard-card h3{font-size:1rem;font-weight:700;color:var(--light-text-dark);margin:0 0 var(--spacing-md) 0;font-family:var(--font-body)}.dashboard-card.groups-card,.dashboard-card.activities-card{background:transparent;border:none;box-shadow:none;padding:0}.activities-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);flex-wrap:wrap;gap:var(--spacing-sm)}.activities-header h3{margin:0;font-weight:700;color:var(--light-text-dark)}.dashboard-actions{display:flex;gap:var(--spacing-sm)}.activities-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.groups-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.groups-header h3{margin:0;font-weight:700;color:var(--light-text-dark)}.btn-add-activity{padding:var(--spacing-sm) var(--spacing-md);background:var(--elf-forest-green);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity var(--transition-fast);font-family:var(--font-body)}.btn-add-activity:hover{opacity:.9}.empty-state.games-empty{background:var(--light-card-bg);border-color:var(--workshop-dusty-blue)}.empty-state{text-align:center;padding:var(--spacing-xl);border:2px dashed var(--stone-300);border-radius:var(--radius-lg);background:var(--light-card-bg)}.empty-icon{font-size:3rem;color:var(--stone-400);margin-bottom:var(--spacing-sm);display:block}.empty-title{font-weight:700;font-size:1.125rem;color:var(--light-text);margin-bottom:var(--spacing-xs);font-family:var(--font-body)}.empty-message{font-size:.875rem;color:var(--light-text-muted);line-height:1.5;font-family:var(--font-body)}.group-item{padding:var(--spacing-md);background:var(--light-card-bg);border-radius:var(--radius-lg);border:1px solid var(--light-card-border);box-shadow:var(--shadow-sm);transition:all var(--transition-fast)}.group-item:hover{box-shadow:var(--shadow-md)}.group-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.group-header h4{cursor:pointer;transition:color var(--transition-fast);color:var(--light-text-dark);margin:0;font-family:var(--font-body);font-weight:700}.group-header h4:hover{color:var(--elf-forest-green)}.match-status{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-xl);font-size:.75rem;font-weight:600;font-family:var(--font-body)}.match-status.matched{background:var(--emerald-100);color:var(--emerald-600)}.match-status.pending{background:var(--amber-100);color:var(--amber-600)}.match-status.pending-approval{background:var(--blue-100);color:var(--blue-700)}.match-status.invited{background:var(--sky-100, #e0f2fe);color:var(--sky-600, #0284c7)}.dashboard-card.invitations-card{background:transparent;border:none;box-shadow:none;padding:0}.invitation-count{padding:var(--spacing-xs) var(--spacing-sm);background:var(--sky-100, #e0f2fe);color:var(--sky-600, #0284c7);border-radius:var(--radius-xl);font-size:.75rem;font-weight:600}.invited-by{color:var(--light-text-muted);font-size:.875rem;margin:0}.invitation-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.invitation-actions .btn-accept{flex:2}.invitation-actions .btn-decline{flex:1}.group-info{display:flex;flex-direction:column;gap:var(--spacing-sm)}.member-count{color:var(--light-text-muted);font-size:.75rem;font-family:var(--font-body);margin:0}.group-dates{display:flex;gap:var(--spacing-xl);padding:var(--spacing-sm) 0;font-size:.875rem}.date-item{display:flex;flex-direction:column;gap:2px}.date-label{font-size:.75rem;color:var(--light-text-muted);font-family:var(--font-body)}.date-value{font-size:.875rem;color:var(--light-text);font-weight:600;font-family:var(--font-body)}.countdown{padding:var(--spacing-sm) var(--spacing-md);background:var(--emerald-100);color:var(--emerald-600);border-radius:var(--radius-md);text-align:center;font-weight:600;font-size:.875rem;font-family:var(--font-body)}.group-actions{margin-top:var(--spacing-sm);display:flex;gap:var(--spacing-sm)}.btn-view-match,.btn-manage,.btn-view-details{flex:1;padding:var(--spacing-sm);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.btn-view-match{background:var(--elf-forest-green);color:var(--snow-white)}.btn-view-match:hover{opacity:.9}.btn-view-match-secondary{flex:0 0 auto;padding:var(--spacing-sm);border:1px solid var(--elf-forest-green);border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body);background:transparent;color:var(--elf-forest-green)}.btn-view-match-secondary:hover{background:var(--elf-forest-green);color:var(--snow-white)}.btn-archive{flex:0 0 auto;padding:var(--spacing-sm) var(--spacing-md);background:var(--stone-200);color:var(--stone-600);border:none;border-radius:var(--radius-md);font-size:.75rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.btn-archive:hover:not(:disabled){background:var(--stone-300)}.btn-archive:disabled{opacity:.6;cursor:not-allowed}.member-row{display:flex;justify-content:space-between;align-items:center}.btn-archive-small{padding:var(--spacing-xs) var(--spacing-sm);font-size:.75rem}.btn-manage{background:var(--elf-forest-green);color:var(--snow-white)}.btn-manage:hover{opacity:.9}.btn-view-details{background:var(--stone-200);color:var(--stone-700)}.btn-view-details:hover{background:var(--stone-300)}.btn-approve-matches{flex:1;padding:var(--spacing-sm);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body);background:var(--blue-600);color:var(--snow-white)}.btn-approve-matches:hover{background:var(--blue-700)}.quick-actions{display:flex;flex-direction:column;gap:var(--spacing-sm)}.action-btn{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--light-card-border);background:var(--snow-white);border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body);color:var(--light-text);font-size:.875rem}.action-btn:hover:not(:disabled){background:var(--stone-50);border-color:var(--stone-300)}.action-btn.primary{background:var(--elf-forest-green);color:var(--snow-white);border:none}.action-btn.primary:hover{opacity:.9}.action-btn:disabled{opacity:.5;cursor:not-allowed}.tips-list{list-style:none;padding:0;margin:0}.tips-list li{padding:var(--spacing-sm) 0;border-bottom:1px solid var(--light-card-border);color:var(--light-text-muted);font-size:.875rem;font-family:var(--font-body)}.tips-list li:last-child{border-bottom:none}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);border:1px solid var(--light-card-border);border-radius:var(--radius-lg);background:var(--light-card-bg);min-height:60vh}.dashboard-loading .spinner{width:32px;height:32px;border:4px solid var(--elf-forest-green);border-top-color:transparent;border-radius:var(--radius-round);animation:spin 1s linear infinite;margin-bottom:var(--spacing-md)}.dashboard-loading p{color:var(--stone-600);font-family:var(--font-body)}@media(max-width:768px){.dashboard-container{padding:var(--spacing-md)}.dashboard-header h2{font-size:1.5rem}}.question-card{background:var(--cabin-card-brown);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:0 4px 12px #0000004d;animation:fadeInCard .3s ease-in;max-width:100%;margin:0 auto}@keyframes fadeInCard{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.question-progress-header{margin-bottom:var(--spacing-lg)}.question-number{color:var(--cabin-icon-green);font-size:.9rem;font-weight:600;display:block;font-family:var(--font-body)}.question-content{margin-bottom:var(--spacing-md)}.question-label{display:block;color:var(--parchment-cream);font-weight:600;font-size:1.1rem;font-family:var(--font-display);margin-bottom:var(--spacing-md)}.question-required{color:var(--cabin-icon-green);margin-left:var(--spacing-xs);font-weight:700}.question-input-container{margin-top:var(--spacing-md)}.question-input-wrapper{width:100%}.question-input{width:100%;padding:var(--spacing-md);border:2px solid var(--cabin-icon-brown);border-radius:var(--radius-md);font-size:1rem;font-family:var(--font-body);background:var(--artisan-wood-brown);color:var(--parchment-cream);transition:all var(--transition-fast)}.question-input:hover:not(:disabled){border-color:var(--cabin-icon-green);background:#6b4423cc}.question-input:focus{outline:none;border-color:var(--cabin-icon-green);box-shadow:0 0 0 3px #4a8b6f33;background:var(--artisan-wood-brown)}.question-input:disabled{opacity:.5;cursor:not-allowed}.question-input.error{border-color:var(--alert-soft-red)}.question-select-input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%234A8B6F' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right var(--spacing-md) center;background-size:20px;padding-right:calc(var(--spacing-md) * 3)}.question-textarea-input{min-height:120px;resize:vertical;line-height:1.5}.question-multiselect-options{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);padding:var(--spacing-md);background:#6b44234d;border-radius:var(--radius-md)}.question-option-chip{padding:var(--spacing-sm) var(--spacing-md);background:var(--artisan-wood-brown);border:2px solid var(--cabin-icon-brown);border-radius:20px;cursor:pointer;transition:all var(--transition-base);font-size:.95rem;font-family:var(--font-body);color:var(--parchment-cream);position:relative;display:inline-flex;align-items:center;gap:var(--spacing-xs)}.question-option-chip:hover:not(:disabled){border-color:var(--cabin-icon-green);transform:translateY(-2px);box-shadow:0 2px 8px #4a8b6f4d}.question-option-chip:disabled{opacity:.5;cursor:not-allowed}.question-option-chip.selected{background:var(--cabin-icon-green);color:var(--cabin-dark-brown);border-color:var(--cabin-icon-green);font-weight:600}.question-option-chip.none-option{border-style:dashed}.question-option-chip.none-option.selected{background:var(--parchment-cream);color:var(--cabin-dark-brown);border-color:var(--cabin-icon-green);border-style:solid}.option-chip-check{font-size:1.1em;font-weight:700}.shirt-size-wrapper,.pant-size-wrapper,.shoe-size-wrapper{display:flex;flex-direction:column;gap:var(--spacing-md)}.shirt-size-row,.pant-size-row,.shoe-size-row{display:flex;flex-direction:column;gap:var(--spacing-xs)}.shirt-size-sublabel,.pant-size-sublabel,.shoe-size-sublabel{color:var(--parchment-cream);font-size:.9rem;font-weight:500;font-family:var(--font-body);opacity:.9}.question-help-text{display:block;color:var(--parchment-cream);opacity:.8;font-size:.9rem;margin-top:var(--spacing-sm);font-family:var(--font-body);font-style:italic}.question-constraint{display:inline-block;color:var(--cabin-icon-green);font-size:.85rem;margin-right:var(--spacing-md);font-family:var(--font-body)}.question-selection-count{display:inline-block;color:var(--parchment-cream);font-size:.85rem;font-weight:600;font-family:var(--font-body)}.question-char-count{display:block;color:var(--parchment-cream);opacity:.7;font-size:.85rem;margin-top:var(--spacing-xs);text-align:right;font-family:var(--font-body)}.question-char-count.warning{color:var(--warm-earth-tan);font-weight:600}.question-error{display:block;color:var(--alert-soft-red);font-size:.9rem;margin-top:var(--spacing-sm);font-family:var(--font-body);font-weight:500}.question-footer{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid rgba(139,98,57,.3)}.question-required-hint{color:var(--cabin-icon-green);font-size:.85rem;opacity:.8;font-family:var(--font-body)}.question-multiselect-info,.question-textarea-info{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}@media(max-width:768px){.question-card{padding:var(--spacing-lg);border-radius:var(--radius-md)}.question-category-title{font-size:1.25rem}.question-label{font-size:1rem}.question-option-chip{font-size:.9rem;padding:var(--spacing-xs) var(--spacing-sm)}.question-multiselect-options{gap:var(--spacing-xs)}}@media(prefers-color-scheme:dark){.question-input{background:#3a2f26e6}.question-input:hover:not(:disabled){background:#3a2f26b3}}.questionnaire-container{min-height:100vh;background:var(--cabin-dark-brown);position:relative;padding-bottom:100px}.questionnaire-header{background:transparent;padding:var(--spacing-lg);text-align:center}.questionnaire-header h1{color:var(--parchment-cream);margin:0 0 var(--spacing-md) 0;font-size:2rem;font-family:var(--font-display)}.wizard-progress{max-width:900px;margin:0 auto var(--spacing-lg) auto;padding:0 var(--spacing-md)}.progress-label{color:var(--parchment-cream);font-size:.9rem;margin-bottom:var(--spacing-xs);text-align:center;font-family:var(--font-body)}.progress-bar{background:var(--cabin-icon-brown);height:8px;border-radius:var(--radius-sm);overflow:hidden}.progress-fill{background:var(--cabin-icon-green);height:100%;transition:width var(--transition-slow);position:relative}.questionnaire-content{max-width:900px;margin:0 auto;padding:0 var(--spacing-xl) var(--spacing-xl) var(--spacing-xl);min-height:60vh}.questionnaire-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80vh;color:var(--parchment-cream);font-family:var(--font-body)}.questionnaire-loading p{margin-top:var(--spacing-lg);font-size:1.1rem}.questionnaire-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80vh;color:var(--parchment-cream);font-family:var(--font-body)}.questionnaire-error p{margin-bottom:var(--spacing-lg);font-size:1.1rem}.questionnaire-error button{padding:var(--spacing-md) var(--spacing-xl);background:var(--cabin-icon-green);color:var(--cabin-dark-brown);border:none;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.questionnaire-error button:hover{background:var(--warm-earth-tan);transform:translateY(-2px);box-shadow:var(--shadow-md)}.error-message{background:#c85a541a;color:var(--alert-soft-red);padding:var(--spacing-md);border-radius:var(--radius-md);margin:var(--spacing-md) 0;border:2px solid var(--alert-soft-red);text-align:center;font-family:var(--font-body)}.wizard-navigation{position:fixed;bottom:0;left:0;right:0;background:var(--cabin-card-brown);padding:var(--spacing-lg) var(--spacing-xl);display:flex;justify-content:center;align-items:center;gap:var(--spacing-md);box-shadow:0 -4px 12px #0000004d;z-index:var(--z-sticky)}.wizard-btn{padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-md);font-family:var(--font-body);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);border:2px solid transparent;min-width:120px;text-align:center;display:inline-flex;align-items:center;justify-content:center}.btn-back{background:var(--cabin-dark-brown);color:var(--parchment-cream);border-color:var(--cabin-icon-brown)}.btn-back:hover:not(:disabled){background:var(--cabin-icon-brown);box-shadow:0 2px 8px #0003}.btn-back:disabled{opacity:.3;cursor:not-allowed}.btn-save{background:var(--artisan-wood-brown);color:var(--parchment-cream);border-color:var(--cabin-icon-brown)}.btn-save:hover:not(:disabled){background:var(--cabin-icon-green);color:var(--cabin-dark-brown);border-color:var(--cabin-icon-green);box-shadow:0 2px 8px #4a8b6f4d}.btn-save:disabled{opacity:.5;cursor:not-allowed}.btn-next{background:var(--cabin-icon-green);color:var(--cabin-dark-brown);border-color:var(--cabin-icon-green);font-weight:700}.btn-next:hover:not(:disabled){background:var(--warm-earth-tan);color:var(--cabin-dark-brown);border-color:var(--warm-earth-tan);box-shadow:0 2px 8px #d4a5744d}.save-status{position:fixed;bottom:90px;right:var(--spacing-xl);padding:var(--spacing-sm) var(--spacing-md);background:var(--cabin-card-brown);color:var(--parchment-cream);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border:2px solid var(--cabin-icon-brown);font-size:.85rem;animation:slideIn .3s ease-out;font-family:var(--font-body);z-index:var(--z-sticky)}@keyframes slideIn{0%{transform:translate(120%);opacity:0}to{transform:translate(0);opacity:1}}.spinner{width:40px;height:40px;border:4px solid var(--parchment-cream);border-top:4px solid var(--cabin-icon-green);border-radius:50%;animation:spin 1s linear infinite}@media(max-width:768px){.questionnaire-header h1{font-size:1.5rem}.questionnaire-content{padding:0 var(--spacing-md) var(--spacing-md) var(--spacing-md)}.wizard-navigation{padding:var(--spacing-md);gap:var(--spacing-sm)}.wizard-btn{padding:var(--spacing-sm) var(--spacing-md);min-width:80px;font-size:.9rem}.save-status{bottom:80px;right:var(--spacing-sm);font-size:.75rem}}@media(min-width:769px)and (max-width:1024px){.questionnaire-content{padding:0 var(--spacing-lg) var(--spacing-lg) var(--spacing-lg)}}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media(prefers-contrast:high){.wizard-btn{border-width:3px}.error-message{border-width:3px;font-weight:600}.progress-bar{border-width:2px}}.save-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--spacing-md);animation:fadeIn .2s ease-out}.save-modal{background:var(--cabin-card-brown);border-radius:var(--radius-lg);padding:var(--spacing-xl);max-width:500px;width:100%;box-shadow:0 20px 60px #0006;border:2px solid var(--cabin-icon-brown);animation:slideUp .3s ease-out}.save-modal h2{margin:0 0 var(--spacing-md) 0;color:var(--parchment-cream);font-family:var(--font-display);font-size:1.5rem;text-align:center}.modal-description{color:var(--parchment-cream);text-align:center;margin-bottom:var(--spacing-lg);font-family:var(--font-body);line-height:1.5}.modal-options{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.modal-options.single{grid-template-columns:1fr;max-width:280px;margin-left:auto;margin-right:auto}.modal-option{display:flex;flex-direction:column;align-items:center;text-align:center}.modal-btn{width:100%;padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);font-family:var(--font-body);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);border:2px solid transparent;margin-bottom:var(--spacing-sm)}.btn-draft{background:var(--cabin-dark-brown);color:var(--parchment-cream);border-color:var(--cabin-icon-brown)}.btn-draft:hover:not(:disabled){background:var(--cabin-icon-brown);transform:translateY(-2px)}.btn-complete{background:var(--cabin-icon-green);color:var(--cabin-dark-brown);border-color:var(--cabin-icon-green)}.btn-complete:hover:not(:disabled){background:var(--warm-earth-tan);border-color:var(--warm-earth-tan);transform:translateY(-2px)}.modal-btn:disabled{opacity:.5;cursor:not-allowed}.option-hint{color:var(--warm-earth-tan);font-size:.85rem;margin:0;font-family:var(--font-body)}.modal-hint{color:var(--warm-earth-tan);text-align:center;font-size:.9rem;margin:0 0 var(--spacing-lg) 0;padding:var(--spacing-sm) var(--spacing-md);background:#d4a57426;border-radius:var(--radius-md);font-family:var(--font-body)}.modal-close{display:block;width:100%;padding:var(--spacing-sm) var(--spacing-md);background:transparent;color:var(--parchment-cream);border:1px solid var(--cabin-icon-brown);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.9rem;cursor:pointer;transition:all var(--transition-fast)}.modal-close:hover{background:var(--cabin-dark-brown)}@media(max-width:768px){.save-modal{padding:var(--spacing-lg);margin:var(--spacing-md)}.modal-options{grid-template-columns:1fr}.modal-btn{padding:var(--spacing-md)}}.select-group-modal{width:450px;padding:var(--spacing-lg)}.select-group-content{display:flex;flex-direction:column;gap:var(--spacing-md)}.select-group-modal .modal-title{font-family:var(--font-display);font-size:1.5rem;color:var(--elf-forest-green);margin:0;text-align:center}.select-group-modal .modal-subtitle{font-family:var(--font-body);font-size:.875rem;color:var(--light-text-muted);margin:0;text-align:center}.select-group-modal .modal-loading{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-lg);color:var(--light-text-muted);font-family:var(--font-body);font-size:.875rem}.select-group-modal .loading-spinner{display:inline-block;width:1rem;height:1rem;border:2px solid var(--stone-300);border-radius:50%;border-top-color:var(--elf-forest-green);animation:spin .8s linear infinite}.select-group-modal .modal-error{padding:var(--spacing-sm) var(--spacing-md);background:var(--red-50);border:1px solid var(--alert-soft-red);border-radius:var(--radius-md);color:var(--burgundy-accent);font-size:.875rem;font-family:var(--font-body);text-align:center}.select-group-modal .modal-empty{padding:var(--spacing-lg);text-align:center;color:var(--light-text-muted);font-family:var(--font-body);font-size:.875rem}.select-group-modal .modal-empty p{margin:0 0 var(--spacing-sm) 0}.select-group-modal .modal-empty a{color:var(--elf-forest-green);font-weight:600;text-decoration:none}.select-group-modal .modal-empty a:hover{text-decoration:underline}.group-list{display:flex;flex-direction:column;gap:var(--spacing-sm);max-height:300px;overflow-y:auto;padding:var(--spacing-xs)}.group-list-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--stone-50);border:1px solid var(--stone-200);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%}.group-list-item:hover{background:var(--elf-forest-green);border-color:var(--elf-forest-green)}.group-list-item:hover .group-name,.group-list-item:hover .group-meta,.group-list-item:hover .group-arrow{color:var(--snow-white)}.group-info{display:flex;flex-direction:column;gap:2px}.group-name{font-family:var(--font-body);font-weight:600;font-size:.9375rem;color:var(--light-text);transition:color var(--transition-fast)}.group-meta{font-family:var(--font-body);font-size:.75rem;color:var(--light-text-muted);transition:color var(--transition-fast)}.group-arrow{font-size:1.25rem;color:var(--stone-400);transition:color var(--transition-fast)}.select-group-modal .modal-actions{display:flex;justify-content:center;margin-top:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid var(--stone-200)}.select-group-modal .btn-cancel{padding:var(--spacing-sm) var(--spacing-lg);background:transparent;color:var(--stone-600);border:1px solid var(--stone-300);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.select-group-modal .btn-cancel:hover{background:var(--stone-100);border-color:var(--stone-400)}@media(max-width:480px){.select-group-modal{width:100%;margin:var(--spacing-md)}.group-list{max-height:250px}}.create-group-container{min-height:100vh;background:var(--light-bg);padding:var(--spacing-lg)}.create-group-content{max-width:600px;margin:0 auto}.create-group-header{margin-bottom:var(--spacing-lg)}.create-group-header h1{font-family:var(--font-display);font-size:2rem;color:var(--elf-forest-green);margin:0}.create-group-card{background:var(--light-card-bg);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);border:1px solid var(--light-card-border)}.create-group-intro{margin-bottom:var(--spacing-lg)}.create-group-intro h2{font-size:1rem;font-weight:700;color:var(--light-text-dark);margin:0 0 var(--spacing-sm) 0;font-family:var(--font-body)}.create-group-intro p{color:var(--light-text-muted);font-family:var(--font-body);font-size:.875rem;margin:0}.create-group-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group{display:flex;flex-direction:column}.form-label{display:block;font-size:.875rem;font-weight:600;color:var(--light-text);margin-bottom:var(--spacing-sm);font-family:var(--font-body)}.form-label .required{color:var(--red-600)}.form-input,.form-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--stone-300);border-radius:var(--radius-md);font-size:.875rem;font-family:var(--font-body);background-color:var(--snow-white);color:var(--light-text);transition:border-color var(--transition-fast)}.form-input:focus,.form-select:focus{outline:none;border-color:var(--elf-forest-green);box-shadow:0 0 0 3px #4a5d351a}.form-input.error,.form-select.error{border-color:var(--red-600)}.form-error{margin-top:var(--spacing-xs);font-size:.75rem;color:var(--red-600);font-family:var(--font-body)}.form-hint{margin-top:var(--spacing-xs);font-size:.75rem;color:var(--light-text-muted);font-family:var(--font-body)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}@media(max-width:768px){.form-grid{grid-template-columns:1fr}}.radio-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.radio-group.horizontal{flex-direction:row;gap:var(--spacing-md)}@media(max-width:480px){.radio-group.horizontal{flex-direction:column}}.radio-option{display:flex;align-items:flex-start;cursor:pointer;padding:var(--spacing-md);border:1px solid var(--light-card-border);border-radius:var(--radius-md);background:var(--snow-white);transition:all var(--transition-fast)}.radio-option:hover{border-color:var(--stone-300);background:var(--stone-50)}.radio-input{margin-top:.25rem;margin-right:var(--spacing-md);accent-color:var(--elf-forest-green)}.radio-content{flex:1}.radio-label{font-weight:600;color:var(--light-text);display:block;margin-bottom:var(--spacing-xs);font-family:var(--font-body);font-size:.875rem}.radio-description{font-size:.75rem;color:var(--light-text-muted);font-family:var(--font-body)}.radio-option.compact{padding:var(--spacing-sm) var(--spacing-md);align-items:center}.radio-option.compact .radio-input{margin-top:0;margin-right:var(--spacing-sm)}.radio-option.compact .radio-label{margin-bottom:0}.info-alert{background-color:var(--workshop-dusty-blue-light, #e8f0f3);border:1px solid var(--workshop-dusty-blue);border-radius:var(--radius-md);padding:var(--spacing-md)}.info-alert p{color:var(--light-text);margin:0;font-family:var(--font-body);font-size:.875rem}.info-alert a{color:var(--elf-forest-green);font-weight:600}.form-input.placeholder{color:var(--light-text-muted)}select.form-input option{color:var(--light-text)}.checkbox-option{display:flex;align-items:flex-start;cursor:pointer;padding:var(--spacing-md);border:1px solid var(--light-card-border);border-radius:var(--radius-md);background:var(--snow-white);transition:all var(--transition-fast)}.checkbox-option:hover{border-color:var(--stone-300);background:var(--stone-50)}.checkbox-input{margin-top:.25rem;margin-right:var(--spacing-md);accent-color:var(--elf-forest-green);width:18px;height:18px;flex-shrink:0}.checkbox-content{flex:1}.checkbox-label{font-weight:600;color:var(--light-text);display:block;margin-bottom:var(--spacing-xs);font-family:var(--font-body);font-size:.875rem}.checkbox-description{font-size:.75rem;color:var(--light-text-muted);font-family:var(--font-body);margin:0}.error-alert{background-color:var(--red-100);border:1px solid var(--red-600);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.error-alert p{color:var(--red-600);margin:0;font-family:var(--font-body);font-size:.875rem}.form-footer{display:flex;justify-content:flex-end;padding-top:var(--spacing-md);margin-top:var(--spacing-md);border-top:1px solid var(--light-card-border);gap:var(--spacing-md)}.form-footer.two-buttons{justify-content:space-between}@media(max-width:480px){.form-footer.two-buttons{flex-direction:column-reverse;gap:var(--spacing-sm)}.form-footer.two-buttons .submit-button{width:100%}}.submit-button{padding:var(--spacing-sm) var(--spacing-lg);background:var(--elf-forest-green);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-weight:600;font-family:var(--font-body);font-size:.875rem;cursor:pointer;transition:all var(--transition-fast)}.submit-button:hover:not(:disabled){opacity:.9}.submit-button:disabled{background:var(--stone-300);cursor:not-allowed;opacity:.5}.submit-button.secondary{background:transparent;color:var(--elf-forest-green);border:1px solid var(--elf-forest-green)}.submit-button.secondary:hover:not(:disabled){background:var(--elf-forest-green);color:var(--snow-white);opacity:1}.loading-spinner{display:inline-block;width:1rem;height:1rem;border:2px solid var(--snow-white);border-radius:50%;border-top-color:transparent;animation:spin .8s linear infinite;margin-right:var(--spacing-sm)}.selected-group-display{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--stone-50);border:1px solid var(--elf-forest-green);border-radius:var(--radius-md)}.selected-group-info{display:flex;flex-direction:column;gap:2px}.selected-group-name{font-family:var(--font-body);font-weight:600;font-size:.9375rem;color:var(--light-text)}.selected-group-meta{font-family:var(--font-body);font-size:.75rem;color:var(--light-text-muted)}.btn-change-group{padding:var(--spacing-xs) var(--spacing-md);background:transparent;color:var(--elf-forest-green);border:1px solid var(--elf-forest-green);border-radius:var(--radius-md);font-size:.75rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.btn-change-group:hover{background:var(--elf-forest-green);color:var(--snow-white)}.btn-select-group{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--snow-white);border:1px solid var(--stone-300);border-radius:var(--radius-md);font-size:.875rem;font-family:var(--font-body);color:var(--light-text-muted);cursor:pointer;transition:all var(--transition-fast)}.btn-select-group:hover{border-color:var(--elf-forest-green);background:var(--stone-50)}.btn-select-group .btn-arrow{color:var(--stone-400);font-size:1rem}@media(max-width:768px){.create-group-container{padding:var(--spacing-md)}.create-group-header h1{font-size:1.5rem}.create-group-card{padding:var(--spacing-md)}}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-container{background:#fff;border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e9ecef}.modal-header h2{margin:0;font-size:1.5rem;color:#333;display:flex;align-items:center;gap:.5rem}.close-button{background:none;border:none;font-size:2rem;color:#6c757d;cursor:pointer;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.close-button:hover:not(:disabled){background:#f8f9fa;color:#333}.close-button:disabled{cursor:not-allowed;opacity:.5}.modal-body{padding:1.5rem}.warning-box{display:flex;gap:1rem;padding:1rem;background:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;margin-bottom:1.5rem}.warning-icon{font-size:1.5rem;flex-shrink:0}.warning-box p{margin:0;color:#856404;line-height:1.5}.warning-box strong{color:#705c08}.matching-method-section{margin-bottom:1.5rem}.matching-method-section h3{margin-bottom:1rem;color:#333;font-size:1.2rem}.matching-options{display:flex;gap:1rem}.matching-option{flex:1;display:block;padding:1rem;background:#f8f9fa;border:2px solid #e9ecef;border-radius:12px;cursor:pointer;transition:all .2s ease}.matching-option:hover:not(:has(input:disabled)){border-color:#667eea;background:#f5f7ff}.matching-option.selected{border-color:#667eea;background:linear-gradient(135deg,#f5f7ff,#efe5ff);box-shadow:0 4px 12px #667eea26}.matching-option input[type=radio]{display:none}.option-content{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.5rem}.option-icon{font-size:2rem}.option-title{font-weight:600;font-size:1.1rem;color:#333}.option-description{font-size:.85rem;color:#666;line-height:1.4}.matching-option.selected .option-title{color:#667eea}.stats-section{margin-bottom:1.5rem}.stats-section h3{margin-bottom:1rem;color:#333;font-size:1.2rem}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;padding:1rem;background:#f8f9fa;border-radius:8px}.stat-item{text-align:center;padding:1rem;background:#fff;border-radius:8px}.stat-number{display:block;font-size:2rem;font-weight:700;color:#667eea;margin-bottom:.5rem}.stat-number.complete{color:#28a745}.stat-number.incomplete{color:#ffc107}.stat-label{display:block;font-size:.85rem;color:#6c757d;text-transform:uppercase;letter-spacing:.5px}.policy-section{margin-bottom:1.5rem;padding:1rem;background:#f8f9fa;border-radius:8px}.policy-section h3{margin-bottom:1rem;color:#333;font-size:1.1rem}.policy-description{color:#666;margin-bottom:1rem;line-height:1.5}.policy-option{margin:1rem 0}.checkbox-label{display:flex;align-items:center;cursor:pointer;font-size:1rem}.checkbox-label input[type=checkbox]{margin-right:.75rem;width:18px;height:18px;cursor:pointer}.checkbox-label input[type=checkbox]:disabled{cursor:not-allowed}.checkbox-label span{color:#333}.error-text{color:#dc3545;font-weight:400;font-size:.9rem}.policy-result{margin-top:1rem;padding:.75rem;background:#fff;border-radius:6px}.info-text{margin:0;color:#333;display:flex;align-items:center;gap:.5rem}.final-summary{margin-bottom:1.5rem}.final-summary h3{margin-bottom:1rem;color:#333;font-size:1.1rem}.summary-box{padding:1rem;background:#e8f4ff;border:1px solid #b8e0ff;border-radius:8px}.summary-box p{margin:.5rem 0;color:#06c}.summary-box p:first-child{margin-top:0}.summary-box p:last-child{margin-bottom:0}.success-text{color:#155724;font-weight:500}.error-text{color:#dc3545;font-weight:500}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid #e9ecef}.btn-secondary,.btn-primary{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:transform .2s,box-shadow .2s;display:inline-flex;align-items:center;gap:.5rem}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background:#5a6268;transform:translateY(-1px)}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 15px #667eea4d}.btn-secondary:disabled,.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.spinner-small{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}@media(max-width:768px){.modal-container{margin:1rem;max-height:calc(100vh - 2rem)}.matching-options{flex-direction:column}.matching-option{padding:.75rem}.option-icon{font-size:1.5rem}.stats-grid{grid-template-columns:1fr;gap:.75rem}.stat-item{padding:.75rem}.modal-header,.modal-body{padding:1rem}.modal-footer{padding:1rem;flex-direction:column}.btn-secondary,.btn-primary{width:100%;justify-content:center}}.invite-participants{margin-top:2rem;padding-top:2rem;border-top:1px solid #e9ecef}.invite-header h3{margin-top:0;margin-bottom:.5rem;color:#333;font-size:1.2rem}.invite-instructions{color:#666;font-size:.9rem;margin-bottom:1.5rem}.invite-form,.email-input-container{display:flex;flex-direction:column;gap:1rem}.email-textarea{width:100%;padding:1rem;border:2px solid #e9ecef;border-radius:8px;font-size:1rem;font-family:inherit;resize:vertical;min-height:100px;transition:border-color .2s}.email-textarea:focus{outline:none;border-color:#667eea}.email-textarea:disabled{background:#f8f9fa;cursor:not-allowed}.email-textarea::placeholder{color:#adb5bd}.parsed-emails-preview{background:#f8f9fa;border-radius:8px;padding:1rem}.preview-header{margin-bottom:.75rem}.preview-count{font-size:.9rem;color:#666;font-weight:500}.email-chips{display:flex;flex-wrap:wrap;gap:.5rem}.email-chip{display:inline-flex;align-items:center;gap:.25rem;padding:.35rem .75rem;border-radius:20px;font-size:.85rem;transition:all .2s}.email-chip.valid{background:#d4edda;color:#155724}.email-chip.invalid{background:#f8d7da;color:#721c24}.error-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;background:#dc3545;color:#fff;border-radius:50%;font-size:.7rem;font-weight:700}.btn-send-invites{padding:var(--spacing-sm) var(--spacing-md);background:var(--elf-forest-green);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:opacity var(--transition-fast);align-self:flex-start}.btn-send-invites:hover:not(:disabled){opacity:.9}.btn-send-invites:disabled{opacity:.5;cursor:not-allowed}.invite-results{margin-top:1.5rem;padding:1rem;background:#f8f9fa;border-radius:8px}.results-summary{display:flex;gap:1rem;margin-bottom:1rem;font-weight:500}.success-summary{color:#155724}.fail-summary{color:#721c24}.results-list{display:flex;flex-direction:column;gap:.5rem}.result-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;border-radius:6px;font-size:.9rem}.result-item.success{background:#d4edda;color:#155724}.result-item.error{background:#f8d7da;color:#721c24}.result-message{font-size:.85rem;opacity:.9}.pending-invitations{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e9ecef}.pending-invitations h4{margin-top:0;margin-bottom:.5rem;color:#333;font-size:1.1rem}.pending-description{color:#666;font-size:.85rem;margin-bottom:1rem}.pending-list{display:flex;flex-direction:column;gap:.75rem}.pending-item{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1rem;background:#fff3cd;border-radius:8px;border:1px solid #ffc107}.pending-info{display:flex;flex-direction:column;gap:.25rem}.pending-name{font-weight:500;color:#333}.pending-email{font-size:.85rem;color:#666}.pending-meta{display:flex;align-items:center;gap:.75rem}.pending-date{font-size:.8rem;color:#856404}@media(max-width:768px){.invite-participants{padding-top:1.5rem;margin-top:1.5rem}.email-textarea{min-height:80px}.btn-send-invites{width:100%}.result-item{flex-direction:column;align-items:flex-start;gap:.25rem}.pending-item{flex-direction:column;align-items:flex-start;gap:.5rem}}.edit-modal{max-width:500px}.edit-modal .modal-body{padding:1.5rem}.edit-modal .form-group{margin-bottom:1.25rem}.edit-modal .form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#333;font-size:.95rem}.edit-modal .form-group input,.edit-modal .form-group select{width:100%;padding:.75rem 1rem;border:2px solid #e9ecef;border-radius:8px;font-size:1rem;transition:border-color .2s,box-shadow .2s;background:#fff}.edit-modal .form-group input:focus,.edit-modal .form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.edit-modal .form-group input:disabled,.edit-modal .form-group select:disabled{background:#f8f9fa;cursor:not-allowed;opacity:.7}.edit-modal .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.edit-modal .field-hint{margin-top:.5rem;font-size:.85rem;color:#666;font-style:italic}.edit-modal .error-message{background:#f8d7da;color:#721c24;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.95rem}@media(max-width:480px){.edit-modal .form-row{grid-template-columns:1fr}}.match-review-container{background:var(--light-card-bg);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--light-card-border)}.match-review-header{margin-bottom:var(--spacing-lg)}.match-review-header h2{font-family:var(--font-display);font-size:1.25rem;color:var(--elf-forest-green);margin:0 0 var(--spacing-sm) 0}.review-hint{color:var(--light-text-muted);font-size:.875rem;margin:0}.match-review-loading,.match-review-error{text-align:center;padding:var(--spacing-xl)}.match-review-loading .spinner{width:2rem;height:2rem;border:3px solid var(--stone-200);border-top-color:var(--elf-forest-green);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto var(--spacing-md)}.match-review-error p{color:var(--red-600);margin-bottom:var(--spacing-md)}.btn-retry{padding:var(--spacing-sm) var(--spacing-md);background:var(--stone-200);border:none;border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-body)}.matches-list{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.match-review-item{border:1px solid var(--light-card-border);border-radius:var(--radius-md);overflow:hidden;background:var(--snow-white)}.match-receiver-button{width:100%;display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:var(--snow-white);border:none;cursor:pointer;text-align:left;transition:background var(--transition-fast)}.match-receiver-button:hover{background:var(--stone-50)}.match-receiver-button.expanded{background:var(--stone-100);border-bottom:1px solid var(--light-card-border)}.receiver-info{display:flex;align-items:center;gap:var(--spacing-md)}.receiver-name{font-weight:600;font-size:.95rem;color:var(--light-text);font-family:var(--font-body)}.match-score{font-size:.75rem;font-weight:600;padding:.25rem .5rem;border-radius:var(--radius-sm)}.score-excellent{background:var(--green-100);color:var(--green-800)}.score-great{background:var(--blue-100);color:var(--blue-800)}.score-good{background:var(--yellow-100);color:var(--yellow-800)}.score-fair{background:var(--orange-100);color:var(--orange-800)}.score-low{background:var(--red-100);color:var(--red-600)}.expand-icon{font-size:.75rem;color:var(--light-text-muted)}.match-details{padding:var(--spacing-md);background:var(--stone-50)}.giver-section{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.giver-section label{font-size:.75rem;color:var(--light-text-muted);font-weight:500}.giver-name{font-weight:600;color:var(--elf-forest-green)}.method-badge{display:inline-block;font-size:.7rem;font-weight:600;padding:.2rem .5rem;border-radius:var(--radius-sm);margin-bottom:var(--spacing-sm);text-transform:uppercase;letter-spacing:.5px}.method-badge.ai{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.method-badge.random{background:var(--stone-300);color:var(--light-text)}.reasoning-section{margin-top:var(--spacing-sm)}.reasoning-section label{display:block;font-size:.75rem;color:var(--light-text-muted);font-weight:500;margin-bottom:var(--spacing-xs)}.reasoning-text{font-size:.875rem;color:var(--light-text);line-height:1.5;margin:0;padding:var(--spacing-sm);background:var(--snow-white);border-radius:var(--radius-sm);border-left:3px solid var(--elf-forest-green)}.match-review-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--light-card-border)}.btn-rematch{padding:var(--spacing-sm) var(--spacing-lg);background:var(--stone-200);color:var(--light-text);border:none;border-radius:var(--radius-md);font-weight:600;font-family:var(--font-body);font-size:.875rem;cursor:pointer;transition:background var(--transition-fast)}.btn-rematch:hover{background:var(--stone-300)}.btn-approve{padding:var(--spacing-sm) var(--spacing-lg);background:var(--elf-forest-green);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-weight:600;font-family:var(--font-body);font-size:.875rem;cursor:pointer;transition:opacity var(--transition-fast)}.btn-approve:hover:not(:disabled){opacity:.9}.btn-approve:disabled{background:var(--stone-300);cursor:not-allowed;opacity:.6}@media(max-width:768px){.match-review-container{padding:var(--spacing-md)}.match-review-actions{flex-direction:column}.btn-rematch,.btn-approve{width:100%;text-align:center}}.game-prompt-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.game-prompt-modal{background:var(--color-surface);border-radius:20px;padding:40px 32px;max-width:400px;width:100%;text-align:center;box-shadow:0 8px 32px #0003;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.celebration-icons{font-size:48px;margin-bottom:16px;letter-spacing:8px}.prompt-icon{font-size:56px;margin-bottom:16px}.game-prompt-modal h2{font-size:28px;color:var(--color-text);margin-bottom:12px}.game-prompt-modal p{font-size:18px;color:var(--color-text);margin-bottom:8px}.game-prompt-modal .subtext{color:var(--color-text-secondary);font-size:14px;margin-bottom:28px}.action-buttons{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.create-quiz-btn{font-size:18px;padding:16px 32px;background:var(--color-primary);color:#fff;border:none;border-radius:12px;cursor:pointer;font-weight:600;transition:all .2s}.create-quiz-btn:hover{background:var(--color-primary-dark, #243d26);transform:translateY(-2px)}.view-quiz-btn{display:inline-block;font-size:16px;padding:14px 28px;background:var(--color-primary);color:#fff;text-decoration:none;border-radius:12px;font-weight:600;transition:all .2s}.view-quiz-btn:hover{background:var(--color-primary-dark, #243d26);color:#fff}.game-prompt-modal .btn-secondary{padding:12px 24px;background:transparent;border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-secondary);cursor:pointer;font-size:16px;transition:all .2s}.game-prompt-modal .btn-secondary:hover{border-color:var(--color-text-secondary);color:var(--color-text)}.dont-show-again{display:flex;align-items:center;justify-content:center;gap:8px;color:var(--color-text-secondary);font-size:14px;cursor:pointer}.dont-show-again input[type=checkbox]{width:16px;height:16px;cursor:pointer}.existing-quiz{background:var(--color-bg)}@media(max-width:480px){.game-prompt-modal{padding:32px 24px}.celebration-icons{font-size:36px}.game-prompt-modal h2{font-size:24px}.game-prompt-modal p{font-size:16px}.create-quiz-btn{font-size:16px;padding:14px 24px}}.group-detail-container{min-height:100vh;background:var(--light-bg);padding:var(--spacing-lg)}.group-detail-loading,.group-detail-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--light-bg);color:var(--light-text)}.group-detail-loading .spinner{width:32px;height:32px;border:4px solid var(--elf-forest-green);border-top-color:transparent;border-radius:var(--radius-round);animation:spin 1s linear infinite;margin-bottom:var(--spacing-md)}.group-detail-error h2{margin-bottom:var(--spacing-md);font-size:1.5rem;color:var(--elf-forest-green);font-family:var(--font-display)}.group-detail-error button{margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-lg);background:var(--elf-forest-green);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-size:.875rem;font-family:var(--font-body);font-weight:600;cursor:pointer;transition:opacity var(--transition-fast)}.group-detail-error button:hover{opacity:.9}.group-detail-nav{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.back-button{padding:var(--spacing-sm) var(--spacing-md);background:var(--snow-white);color:var(--light-text);border:1px solid var(--light-card-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-size:.875rem;font-family:var(--font-body)}.back-button:hover{background:var(--stone-50);border-color:var(--stone-300)}.group-detail-nav h1{margin:0;font-size:2rem;font-weight:700;font-family:var(--font-display);color:var(--elf-forest-green)}.group-detail-content{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:var(--spacing-lg)}.detail-card{background:var(--light-card-bg);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);border:1px solid var(--light-card-border)}.detail-card h2{margin-top:0;margin-bottom:var(--spacing-md);color:var(--light-text-dark);font-size:1rem;font-family:var(--font-body);font-weight:700;display:flex;align-items:center;gap:var(--spacing-sm)}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.info-item label{font-size:.75rem;color:var(--light-text-muted);font-weight:500;font-family:var(--font-body);text-transform:uppercase;letter-spacing:.5px}.info-item span{font-size:.875rem;color:var(--light-text);font-weight:600;font-family:var(--font-body)}.status{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-xl);font-size:.75rem;font-weight:600;font-family:var(--font-body);text-align:center}.status.matched{background:var(--emerald-100);color:var(--emerald-600)}.status.pending{background:var(--amber-100);color:var(--amber-600)}.status.pending-approval{background:var(--blue-100);color:var(--blue-700)}.policy-item{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--light-card-border)}.policy-item label{font-size:.75rem;color:var(--light-text-muted);font-weight:500;font-family:var(--font-body);text-transform:uppercase;letter-spacing:.5px}.policy-item span{font-size:.875rem;color:var(--light-text);font-weight:600;font-family:var(--font-body)}.member-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:var(--stone-50);border-radius:var(--radius-md)}.stat{text-align:center;padding:var(--spacing-sm)}.stat-value{display:block;font-size:1.5rem;font-weight:700;color:var(--elf-forest-green);margin-bottom:var(--spacing-xs);font-family:var(--font-display)}.stat-label{display:block;font-size:.75rem;color:var(--light-text-muted);font-family:var(--font-body)}.members-list{display:flex;flex-direction:column;gap:var(--spacing-sm);max-height:300px;overflow-y:auto;padding:var(--spacing-xs)}.member-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:var(--light-card-bg-solid);border-radius:var(--radius-md);border:1px solid var(--light-card-border);transition:all var(--transition-fast)}.member-item:hover{box-shadow:var(--shadow-sm)}.member-name{font-weight:600;color:var(--light-text);font-family:var(--font-body);font-size:.875rem}.profile-status{font-size:1rem}.profile-status.complete{color:var(--emerald-600)}.profile-status.incomplete{color:var(--amber-600)}.matched-actions,.organizer-actions,.member-actions{text-align:center}.success-message{color:var(--emerald-600);font-size:.875rem;margin-bottom:var(--spacing-md);padding:var(--spacing-md);background:var(--emerald-100);border-radius:var(--radius-md);font-family:var(--font-body)}.ready-message{color:var(--emerald-600);background:var(--emerald-100);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-family:var(--font-body);font-size:.875rem}.warning-message{color:var(--amber-600);background:var(--amber-100);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);text-align:left;font-family:var(--font-body);font-size:.875rem}.info-message{color:var(--sky-600);background:var(--sky-100);padding:var(--spacing-md);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.875rem}.btn-primary,.btn-trigger-matching{padding:var(--spacing-sm) var(--spacing-lg);background:var(--elf-forest-green);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:opacity var(--transition-fast)}.btn-primary:hover,.btn-trigger-matching:hover{opacity:.9}.btn-disabled{padding:var(--spacing-sm) var(--spacing-lg);background:var(--stone-200);color:var(--stone-500);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;font-family:var(--font-body);cursor:not-allowed}.invite-section{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--light-card-border)}.invite-section h3{margin-top:0;margin-bottom:var(--spacing-md);color:var(--light-text-dark);font-size:.875rem;font-weight:700;font-family:var(--font-body)}.invite-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.invite-input-group{display:flex;gap:var(--spacing-md)}.invite-input{flex:1;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--stone-300);border-radius:var(--radius-md);font-size:.875rem;font-family:var(--font-body);background:var(--snow-white);color:var(--light-text);transition:border-color var(--transition-fast)}.invite-input:focus{outline:none;border-color:var(--elf-forest-green);box-shadow:0 0 0 3px #4a5d351a}.invite-input:disabled{background:var(--stone-100);cursor:not-allowed}.btn-invite{padding:var(--spacing-sm) var(--spacing-md);background:var(--elf-forest-green);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:opacity var(--transition-fast);white-space:nowrap}.btn-invite:hover:not(:disabled){opacity:.9}.btn-invite:disabled{opacity:.5;cursor:not-allowed}.error-message{color:var(--red-600);background:var(--red-100);padding:var(--spacing-md);border-radius:var(--radius-md);margin:0;font-size:.875rem;font-family:var(--font-body)}.status-badge{font-size:.75rem;color:var(--amber-600);background:var(--amber-100);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);margin-left:var(--spacing-sm);font-family:var(--font-body);font-weight:600}.card-header-with-action{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.card-header-with-action h2{margin:0}.btn-settings{padding:var(--spacing-sm) var(--spacing-md);background:var(--elf-forest-green);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:opacity var(--transition-fast)}.btn-settings:hover{opacity:.9}.countdown-timer{background:var(--sky-100);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md);text-align:center;font-size:.875rem;color:var(--sky-600);font-family:var(--font-body)}.countdown-timer strong{font-size:1rem;font-weight:700}.countdown-timer.urgent{background:var(--amber-100);color:var(--amber-600)}.countdown-timer.past{background:var(--red-100);color:var(--red-600)}.participation-banner{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-family:var(--font-body);font-size:.875rem}.participation-banner.invited{background:var(--sky-100);border:1px solid var(--sky-200);flex-direction:column;align-items:stretch}.participation-banner.accepted{background:var(--emerald-100);border:1px solid var(--emerald-200);color:var(--emerald-700)}.participation-banner.declined{background:var(--stone-100);border:1px solid var(--stone-200);color:var(--stone-600)}.participation-message{display:flex;align-items:center;gap:var(--spacing-sm)}.participation-icon{font-size:1.25rem}.participation-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.participation-actions .btn-accept{padding:var(--spacing-sm) var(--spacing-md);background:var(--elf-forest-green);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-weight:600;font-family:var(--font-body);font-size:.875rem;cursor:pointer;transition:opacity var(--transition-fast)}.participation-actions .btn-accept:hover:not(:disabled){opacity:.9}.participation-actions .btn-accept:disabled{opacity:.5;cursor:not-allowed}.participation-actions .btn-decline{padding:var(--spacing-sm) var(--spacing-md);background:transparent;color:var(--light-text-muted);border:1px solid var(--stone-300);border-radius:var(--radius-md);font-weight:500;font-family:var(--font-body);font-size:.875rem;cursor:pointer;transition:all var(--transition-fast)}.participation-actions .btn-decline:hover:not(:disabled){background:var(--stone-100);border-color:var(--stone-400)}.participation-actions .btn-decline:disabled{opacity:.5;cursor:not-allowed}.complete-profile-link{margin-left:auto;color:var(--elf-forest-green);font-weight:600;text-decoration:none}.complete-profile-link:hover{text-decoration:underline}.empty-state{text-align:center;padding:var(--spacing-xl);border:2px dashed var(--stone-300);border-radius:var(--radius-lg)}.empty-state p{margin:var(--spacing-sm) 0;color:var(--light-text);font-size:.875rem;font-family:var(--font-body)}.empty-state .empty-hint{color:var(--light-text-muted);font-size:.75rem}.member-info{display:flex;flex-direction:column;gap:var(--spacing-xs)}.member-joined{font-size:.75rem;color:var(--light-text-muted);font-family:var(--font-body)}.status-badge.invited{background:var(--amber-100);color:var(--amber-600)}.status-badge.organizer{background:var(--emerald-100);color:var(--emerald-600)}.member-actions-row{display:flex;align-items:center;gap:var(--spacing-md)}.member-action-buttons{display:flex;gap:var(--spacing-sm)}.btn-icon{width:28px;height:28px;border-radius:var(--radius-round);border:none;cursor:pointer;font-size:.875rem;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.btn-edit{background:#fef3c7;color:#d97706}.btn-edit:hover:not(:disabled){background:#d97706;color:var(--snow-white)}.btn-resend{background:var(--sky-100);color:var(--sky-600)}.btn-resend:hover:not(:disabled){background:var(--sky-600);color:var(--snow-white)}.btn-remove{background:var(--red-100);color:var(--red-600)}.btn-remove:hover:not(:disabled){background:var(--red-600);color:var(--snow-white)}.pending-invitations-section{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--light-card-border)}.pending-invitations-section h3{margin-top:0;margin-bottom:var(--spacing-sm);color:var(--light-text-dark);font-size:.875rem;font-weight:700;font-family:var(--font-body)}.section-hint{margin:0 0 var(--spacing-md) 0;color:var(--light-text-muted);font-size:.75rem;font-family:var(--font-body)}.pending-invitations-list{display:flex;flex-direction:column;gap:var(--spacing-sm);max-height:200px;overflow-y:auto;padding:var(--spacing-xs)}.pending-invitation-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:var(--amber-100);border-radius:var(--radius-md);transition:background var(--transition-fast)}.pending-invitation-item:hover{background:#fef3c7cc}.invitation-info{display:flex;flex-direction:column;gap:var(--spacing-xs)}.invitation-email{font-weight:600;color:var(--light-text);font-family:var(--font-body);font-size:.875rem}.invitation-date{font-size:.75rem;color:var(--light-text-muted);font-family:var(--font-body)}.expired-badge{color:var(--red-600);font-weight:600}.invitation-action-buttons{display:flex;gap:var(--spacing-sm)}.budget-distribution-section{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--light-card-border)}.budget-distribution-section h3{margin:0 0 var(--spacing-sm) 0;color:var(--light-text-dark);font-size:.875rem;font-weight:700;font-family:var(--font-body)}.budget-bars{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.budget-bar-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.budget-bar-label{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;font-family:var(--font-body)}.budget-range{font-weight:600;color:var(--light-text)}.budget-count{color:var(--light-text-muted)}.budget-bar-track{height:20px;background:var(--stone-100);border-radius:var(--radius-lg);overflow:hidden}.budget-bar-fill{height:100%;background:var(--elf-forest-green);border-radius:var(--radius-lg);transition:width var(--transition-slow);min-width:4px}.budget-summary{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);align-items:center;color:var(--light-text-muted);font-size:.75rem;padding:var(--spacing-md);background:var(--stone-50);border-radius:var(--radius-md);font-family:var(--font-body)}.no-preference-note{color:var(--amber-600)}@media(max-width:768px){.group-detail-container{padding:var(--spacing-md)}.group-detail-nav{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.group-detail-nav h1{font-size:1.5rem}.info-grid{grid-template-columns:1fr 1fr}.member-stats{grid-template-columns:1fr}.card-header-with-action{flex-direction:row;gap:var(--spacing-sm);align-items:center}.member-item{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.member-actions-row{width:100%;justify-content:space-between}.pending-invitation-item{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.invitation-action-buttons{width:100%;justify-content:flex-end}.invite-input-group{flex-direction:column}}.danger-zone{margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px dashed var(--light-border)}.btn-delete-group{width:100%;padding:var(--spacing-sm) var(--spacing-lg);background:transparent;color:#dc3545;border:2px solid #dc3545;border-radius:var(--radius-md);font-size:.875rem;font-family:var(--font-body);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-delete-group:hover:not(:disabled){background:#dc3545;color:#fff}.btn-delete-group:disabled{opacity:.6;cursor:not-allowed}.organizer-resend-actions{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--light-card-border);text-align:left}.organizer-resend-actions h4{margin:0 0 var(--spacing-md) 0;color:var(--light-text-muted);font-size:.75rem;font-weight:600;font-family:var(--font-body);text-transform:uppercase;letter-spacing:.5px}.resend-buttons{display:flex;flex-wrap:wrap;gap:var(--spacing-md)}.btn-secondary{padding:var(--spacing-sm) var(--spacing-md);background:var(--snow-white);color:var(--elf-forest-green);border:1px solid var(--elf-forest-green);border-radius:var(--radius-md);font-size:.875rem;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:all var(--transition-fast)}.btn-secondary:hover:not(:disabled){background:var(--elf-forest-green);color:var(--snow-white)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-rematch{background:#fff3cd;color:#856404;border-color:#ffc107}.btn-rematch:hover:not(:disabled){background:#ffc107;color:#000}.rematch-modal{max-width:500px}.rematch-modal h3{margin:0 0 var(--spacing-md) 0;color:var(--elf-forest-green)}.modal-description{color:var(--light-text-muted);margin-bottom:var(--spacing-lg);font-size:.875rem;line-height:1.5}.member-checklist{max-height:300px;overflow-y:auto;border:1px solid var(--light-card-border);border-radius:var(--radius-md);padding:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.member-checkbox-row{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.member-checkbox-row:hover{background:var(--light-hover)}.member-checkbox-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--elf-forest-green);cursor:pointer}.member-checkbox-row .member-name{font-weight:500;color:var(--light-text-primary)}.orphaned-members-warning{background:#f8d7da;border:1px solid #f5c6cb;border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);text-align:left}.orphaned-members-warning h4{color:#721c24;margin:0 0 var(--spacing-sm) 0;font-size:1rem}.orphaned-members-warning p{color:#721c24;margin:0 0 var(--spacing-md) 0;font-size:.875rem;line-height:1.5}.orphaned-list{list-style:none;padding:0;margin:0 0 var(--spacing-md) 0;max-height:150px;overflow-y:auto}.orphaned-list li{padding:var(--spacing-xs) 0;color:#721c24;font-size:.875rem;border-bottom:1px solid rgba(114,28,36,.2)}.orphaned-list li:last-child{border-bottom:none}.btn-fix-orphaned{background:#721c24;color:#fff;border:none;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-fix-orphaned:hover:not(:disabled){background:#5a161d}.btn-fix-orphaned:disabled{opacity:.6;cursor:not-allowed}.receiver-profile-container{min-height:100vh;background:var(--dark-bg)}.receiver-profile-loading,.receiver-profile-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:var(--dark-text)}.receiver-profile-loading .spinner{width:50px;height:50px;border:4px solid var(--dark-card-bg);border-top:4px solid var(--dark-accent);border-radius:50%;animation:spin 1s linear infinite}.receiver-profile-error h2{margin-bottom:var(--spacing-md);font-size:2rem;color:var(--dark-text);font-family:var(--font-display)}.receiver-profile-error button{margin-top:var(--spacing-md);padding:var(--spacing-md) var(--spacing-xl);background:var(--dark-accent);color:var(--dark-bg);border:none;border-radius:var(--radius-md);font-size:1rem;font-family:var(--font-body);cursor:pointer;transition:all var(--transition-base);font-weight:600}.receiver-profile-error button:hover{background:var(--warm-earth-tan);transform:translateY(-2px);box-shadow:var(--shadow-md)}.receiver-profile-nav{background:var(--dark-card-bg);border-bottom:2px solid var(--dark-card-border);padding:var(--spacing-md) var(--spacing-xl);display:flex;align-items:center;justify-content:space-between;color:var(--dark-text);box-shadow:0 4px 12px #0000004d}.receiver-profile-nav h1{margin:0;font-size:1.75rem;font-weight:700;font-family:var(--font-display);color:var(--dark-text)}.receiver-profile-content{max-width:1200px;margin:var(--spacing-xl) auto;padding:0 var(--spacing-xl) var(--spacing-xl)}.profile-card{background:var(--dark-card-bg);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:0 10px 40px #0000004d;margin-bottom:var(--spacing-lg);border:2px solid var(--dark-card-border)}.profile-card h3{margin-top:0;margin-bottom:var(--spacing-lg);color:var(--dark-text);font-size:1.4rem;font-family:var(--font-display);display:flex;align-items:center;gap:var(--spacing-sm)}.header-card{background:var(--dark-card-bg)}.recipient-header{margin-bottom:var(--spacing-lg)}.recipient-name{margin:0;font-size:2.2rem;color:var(--dark-text);font-family:var(--font-display)}.recipient-details{color:var(--dark-text-muted);font-size:1.1rem;margin-top:var(--spacing-sm);font-family:var(--font-body)}.gift-info{display:flex;gap:var(--spacing-xl)}.info-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.info-item .label{font-size:.85rem;color:var(--dark-text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.5px;font-family:var(--font-body)}.info-item .value{font-size:1.2rem;color:var(--dark-text);font-weight:600;font-family:var(--font-body)}.profile-notice{margin-top:var(--spacing-lg);padding:var(--spacing-md);background:#d4af371a;color:var(--success-warm-gold);border-radius:var(--radius-md);font-size:.95rem;font-family:var(--font-body);border:1px solid var(--success-warm-gold)}.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg)}.profile-field{display:flex;flex-direction:column}.profile-field.full-width{grid-column:1 / -1}.profile-field label{font-size:.9rem;color:var(--dark-text-muted);font-weight:600;margin-bottom:var(--spacing-sm);text-transform:uppercase;letter-spacing:.5px;font-family:var(--font-body)}.profile-field .value{font-size:1.1rem;color:var(--dark-text);font-weight:500;font-family:var(--font-body)}.tags-container{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.tag{display:inline-block;padding:var(--spacing-xs) var(--spacing-md);background:var(--elf-forest-green);color:var(--parchment-cream);border-radius:var(--radius-xl);font-size:.9rem;font-weight:500;font-family:var(--font-body)}.warning-tags .tag{background:#d4af3733;color:var(--success-warm-gold);border:1px solid var(--success-warm-gold)}.text-value{padding:var(--spacing-md);background:var(--dark-bg);border-radius:var(--radius-md);line-height:1.6;color:var(--dark-text);white-space:pre-wrap;font-family:var(--font-body);border:1px solid var(--dark-card-border)}.text-value.warning{background:#d4af371a;color:var(--success-warm-gold);border-left:3px solid var(--success-warm-gold)}.incomplete-profile{text-align:center;padding:var(--spacing-xl)}.incomplete-profile .icon{font-size:3rem;display:block;margin-bottom:var(--spacing-md)}.incomplete-profile h3{color:var(--success-warm-gold);margin-bottom:var(--spacing-md);font-family:var(--font-display)}.incomplete-profile p{color:var(--dark-text-muted);line-height:1.6;max-width:500px;margin:0 auto;font-family:var(--font-body)}@media(max-width:768px){.receiver-profile-content{padding:var(--spacing-md)}.profile-card{padding:var(--spacing-lg)}.recipient-name h2{font-size:1.8rem}.gift-info{flex-direction:column;gap:var(--spacing-md)}.profile-grid{grid-template-columns:1fr}.receiver-profile-nav{flex-direction:column;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md)}.receiver-profile-nav h1{font-size:1.4rem}}.my-match-container{min-height:100vh;background:var(--dark-bg)}.my-match-loading,.my-match-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:var(--dark-text)}.my-match-loading .spinner{width:50px;height:50px;border:4px solid var(--dark-card-bg);border-top:4px solid var(--dark-accent);border-radius:50%;animation:spin 1s linear infinite}.my-match-error h2{margin-bottom:var(--spacing-md);font-size:2rem;color:var(--dark-text);font-family:var(--font-display)}.my-match-error button{margin-top:var(--spacing-md);padding:var(--spacing-md) var(--spacing-xl);background:var(--dark-accent);color:var(--dark-bg);border:none;border-radius:var(--radius-md);font-size:1rem;font-family:var(--font-body);cursor:pointer;transition:all var(--transition-base);font-weight:600}.my-match-error button:hover{background:var(--warm-earth-tan);transform:translateY(-2px);box-shadow:var(--shadow-md)}.my-match-nav{background:var(--dark-card-bg);border-bottom:2px solid var(--dark-card-border);padding:var(--spacing-md) var(--spacing-xl);display:flex;align-items:center;justify-content:space-between;color:var(--dark-text);box-shadow:0 4px 12px #0000004d}.back-button{padding:var(--spacing-sm) var(--spacing-md);background:var(--dark-bg);color:var(--dark-text);border:2px solid var(--dark-card-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);font-size:.9rem;font-family:var(--font-body)}.back-button:hover{background:var(--dark-card-border);border-color:var(--dark-accent)}.my-match-nav h1{margin:0;font-size:1.75rem;font-weight:700;font-family:var(--font-display);color:var(--dark-text)}.my-match-content{max-width:800px;margin:var(--spacing-xxl) auto;padding:0 var(--spacing-xl)}.match-card{background:var(--dark-card-bg);border-radius:var(--radius-lg);padding:0;box-shadow:0 20px 60px #0006;overflow:hidden;border:2px solid var(--dark-card-border)}.match-header{background:var(--elf-forest-green);color:var(--parchment-cream);padding:var(--spacing-xl);text-align:center;position:relative}.match-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:4px;background:repeating-linear-gradient(90deg,var(--warm-earth-tan),var(--warm-earth-tan) 10px,transparent 10px,transparent 20px)}.match-icon{font-size:4rem;display:block;margin-bottom:var(--spacing-md)}.match-header h2{margin:0;font-size:2rem;font-weight:700;font-family:var(--font-display);color:var(--parchment-cream)}.match-info{padding:var(--spacing-xl)}.match-message{text-align:center;color:var(--dark-text-muted);font-size:1.1rem;margin-bottom:var(--spacing-lg);font-family:var(--font-body)}.receiver-box{background:var(--dark-bg);border:2px solid var(--dark-accent);border-radius:var(--radius-lg);padding:var(--spacing-lg);text-align:center;margin-bottom:var(--spacing-xl)}.receiver-name{margin:0;font-size:1.8rem;color:var(--dark-text);font-weight:700;font-family:var(--font-display)}.receiver-username{margin:var(--spacing-sm) 0 0 0;color:var(--dark-text-muted);font-size:1rem;font-family:var(--font-body)}.match-details{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);padding:var(--spacing-md);background:var(--dark-bg);border-radius:var(--radius-md);border:1px solid var(--dark-card-border)}.detail-label{color:var(--dark-text-muted);font-weight:500;font-family:var(--font-body)}.detail-value{color:var(--dark-text);font-weight:600;font-family:var(--font-body)}.notification-status{color:var(--dark-accent);font-weight:500}.score-excellent{color:#22c55e;font-weight:700}.score-great{color:#84cc16;font-weight:700}.score-good{color:var(--dark-accent);font-weight:700}.score-fair{color:#f59e0b;font-weight:700}.score-low{color:#ef4444;font-weight:700}.match-reasoning{background:linear-gradient(135deg,#2f523326,#5b7c8d26);border:1px solid var(--elf-forest-green);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.match-reasoning h4{margin:0 0 var(--spacing-sm) 0;color:var(--dark-accent);font-size:1rem;font-family:var(--font-display);display:flex;align-items:center;gap:var(--spacing-sm)}.match-reasoning h4:before{content:"✨"}.match-reasoning p{margin:0;color:var(--dark-text);font-size:.95rem;line-height:1.6;font-family:var(--font-body)}.btn-view-profile{width:100%;padding:var(--spacing-md);background:var(--dark-accent);color:var(--dark-bg);border:none;border-radius:var(--radius-md);font-size:1.1rem;font-weight:700;font-family:var(--font-body);cursor:pointer;transition:all var(--transition-base);margin-bottom:var(--spacing-xl)}.btn-view-profile:hover{background:var(--warm-earth-tan);transform:translateY(-2px);box-shadow:0 8px 24px #1dd1a14d}.match-tips{background:var(--dark-bg);border-radius:var(--radius-md);padding:var(--spacing-lg);border:1px solid var(--dark-card-border)}.match-tips h4{margin-top:0;margin-bottom:var(--spacing-md);color:var(--dark-text);font-size:1.1rem;font-family:var(--font-display)}.match-tips ul{margin:0;padding-left:var(--spacing-lg);color:var(--dark-text-muted);line-height:1.8;font-family:var(--font-body)}.match-tips li{margin-bottom:var(--spacing-sm)}.match-tips li:last-child{margin-bottom:0}@media(max-width:768px){.my-match-content{padding:var(--spacing-md);margin:var(--spacing-xl) auto}.match-header{padding:var(--spacing-lg)}.match-icon{font-size:3rem}.match-header h2,.receiver-name{font-size:1.5rem}.my-match-nav{flex-direction:column;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md)}.my-match-nav h1{font-size:1.4rem}.match-info{padding:var(--spacing-lg)}}.join-group-container{min-height:100vh;background:var(--light-bg);display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl)}.join-group-loading,.join-group-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--light-bg);color:var(--light-text)}.join-group-loading .spinner{width:32px;height:32px;border:4px solid var(--elf-forest-green);border-top-color:transparent;border-radius:var(--radius-round);animation:spin 1s linear infinite;margin-bottom:var(--spacing-md)}.join-group-error h2{margin-bottom:var(--spacing-md);font-size:1.5rem;color:var(--elf-forest-green);font-family:var(--font-display)}.join-group-error button{margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-lg);background:var(--elf-forest-green);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-size:.875rem;font-family:var(--font-body);font-weight:600;cursor:pointer;transition:opacity var(--transition-fast)}.join-group-error button:hover{opacity:.9}.join-group-card{background:var(--light-card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:500px;width:100%;overflow:hidden;border:1px solid var(--light-card-border)}.join-group-header{background:var(--elf-forest-green);color:var(--snow-white);padding:var(--spacing-xl);text-align:center}.join-group-header h1{margin:0;font-size:1.5rem;font-weight:700;font-family:var(--font-display);color:var(--snow-white)}.invite-emoji{font-size:3rem;margin:0;display:block;margin-bottom:var(--spacing-md)}.join-group-content{padding:var(--spacing-lg)}.invitation-message{font-size:.875rem;text-align:center;color:var(--light-text-muted);margin-bottom:var(--spacing-md);font-family:var(--font-body)}.group-name{text-align:center;color:var(--elf-forest-green);font-size:1.5rem;margin:var(--spacing-md) 0 var(--spacing-lg) 0;font-weight:700;font-family:var(--font-display)}.group-details{background:var(--stone-50);padding:var(--spacing-lg);border-radius:var(--radius-md);margin:var(--spacing-lg) 0}.group-details h3{margin:0 0 var(--spacing-md) 0;color:var(--light-text-dark);font-size:.875rem;font-weight:700;font-family:var(--font-body)}.detail-grid{display:flex;flex-direction:column;gap:var(--spacing-sm)}.detail-item{display:flex;justify-content:space-between;align-items:center}.detail-label{font-weight:500;color:var(--light-text-muted);font-family:var(--font-body);font-size:.875rem}.detail-value{font-weight:600;color:var(--light-text);font-family:var(--font-body);font-size:.875rem}.invitation-info{text-align:center;margin:var(--spacing-lg) 0;color:var(--light-text-muted);font-family:var(--font-body)}.invitation-info p{margin:var(--spacing-sm) 0;font-size:.875rem}.expires-at{font-size:.75rem;color:var(--amber-600);background:var(--amber-100);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);display:inline-block;margin-top:var(--spacing-md);font-weight:600}.login-prompt{text-align:center;color:var(--light-text-muted);font-size:.875rem;font-family:var(--font-body)}.login-prompt button{background:none;border:none;color:var(--elf-forest-green);font-weight:600;cursor:pointer;text-decoration:underline;padding:0;font-size:inherit;font-family:var(--font-body)}.login-prompt button:hover{opacity:.8}.error-message{color:var(--red-600);background:var(--red-100);padding:var(--spacing-md);border-radius:var(--radius-md);margin:var(--spacing-md) 0;font-size:.875rem;text-align:center;font-family:var(--font-body)}.success-message{text-align:center;padding:var(--spacing-lg);background:var(--emerald-100);border-radius:var(--radius-md);margin:var(--spacing-md) 0}.success-message p{margin:var(--spacing-sm) 0;color:var(--emerald-600);font-size:1rem;font-weight:600;font-family:var(--font-body)}.success-message .redirect-notice{font-size:.875rem;font-weight:400;color:var(--emerald-600);animation:pulse 1.5s ease-in-out infinite}@media(max-width:768px){.join-group-container{padding:var(--spacing-md)}.join-group-header{padding:var(--spacing-lg)}.join-group-header h1,.group-name{font-size:1.25rem}.invite-emoji{font-size:2.5rem}.join-group-content{padding:var(--spacing-md)}}.group-card{padding:var(--spacing-md);background:var(--light-card-bg);border-radius:var(--radius-lg);border:1px solid var(--light-card-border);box-shadow:var(--shadow-sm);transition:all var(--transition-fast);cursor:pointer}.group-card:hover{box-shadow:var(--shadow-md);border-color:var(--elf-forest-green)}.group-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.group-card-name{margin:0;font-family:var(--font-body);font-weight:700;font-size:1rem;color:var(--light-text-dark);transition:color var(--transition-fast)}.group-card:hover .group-card-name{color:var(--elf-forest-green)}.organizer-badge{padding:var(--spacing-xs) var(--spacing-sm);background:var(--emerald-100);color:var(--emerald-600);border-radius:var(--radius-xl);font-size:.75rem;font-weight:600;font-family:var(--font-body)}.group-card-meta{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.group-card-members{color:var(--light-text-muted);font-size:.875rem;font-family:var(--font-body)}.group-card-invited{color:var(--workshop-dusty-blue);font-size:.75rem;font-family:var(--font-body);font-style:italic;padding-left:var(--spacing-sm);border-left:1px solid var(--light-card-border)}.group-card-activity{display:flex;gap:var(--spacing-xs);font-size:.875rem;font-family:var(--font-body)}.activity-label{color:var(--light-text-muted)}.activity-date{color:var(--light-text);font-weight:500}.exchange-indicator{width:8px;height:8px;border-radius:var(--radius-round);margin-left:var(--spacing-xs)}.exchange-indicator.active{background:var(--emerald-500)}.group-card-title-row{display:flex;align-items:center;gap:var(--spacing-sm)}.group-card.archived{opacity:.7;background:var(--light-bg)}.group-card.archived:hover{opacity:.85}.archived-badge{padding:2px var(--spacing-xs);background:var(--light-text-muted);color:#fff;border-radius:var(--radius-sm);font-size:.625rem;font-weight:600;font-family:var(--font-body);text-transform:uppercase;letter-spacing:.5px}.group-card-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--light-card-border)}.action-btn{padding:var(--spacing-xs) var(--spacing-sm);font-size:.75rem;font-weight:600;font-family:var(--font-body);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:1px solid transparent}.clone-btn{background:var(--light-bg);color:var(--light-text);border-color:var(--light-card-border)}.clone-btn:hover{background:var(--light-card-bg);border-color:var(--elf-forest-green);color:var(--elf-forest-green)}.archive-btn{background:transparent;color:var(--light-text-muted);border-color:var(--light-card-border)}.archive-btn:hover{background:var(--red-50, #fef2f2);border-color:var(--red-400, #f87171);color:var(--red-600, #dc2626)}.unarchive-btn{background:var(--emerald-50);color:var(--emerald-600);border-color:var(--emerald-200)}.unarchive-btn:hover{background:var(--emerald-100);border-color:var(--emerald-400)}.edit-btn{background:var(--light-bg);color:var(--light-text);border-color:var(--light-card-border)}.edit-btn:hover{background:var(--emerald-50);border-color:var(--elf-forest-green);color:var(--elf-forest-green)}.manage-btn{background:var(--light-bg);color:var(--light-text);border-color:var(--light-card-border)}.manage-btn:hover{background:var(--workshop-dusty-blue-light, #e8f0f3);border-color:var(--workshop-dusty-blue);color:var(--workshop-dusty-blue)}.activity-group-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-title{font-family:var(--font-display);font-size:1.5rem;color:var(--elf-forest-green);margin:0;text-align:center}.form-error{padding:var(--spacing-sm) var(--spacing-md);background:var(--red-50);border:1px solid var(--alert-soft-red);border-radius:var(--radius-md);color:var(--burgundy-accent);font-size:.875rem;font-family:var(--font-body)}.form-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-label{font-family:var(--font-body);font-weight:600;font-size:.875rem;color:var(--light-text)}.form-label .required{color:var(--burgundy-accent)}.form-input{padding:var(--spacing-sm) var(--spacing-md);font-size:1rem;font-family:var(--font-body);border:1px solid var(--stone-300);border-radius:var(--radius-md);background:var(--snow-white);color:var(--light-text);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--elf-forest-green);box-shadow:0 0 0 3px #2f52331a}.form-input:disabled{background:var(--stone-100);cursor:not-allowed}.form-hint{font-size:.75rem;color:var(--light-text-muted);font-family:var(--font-body);text-align:right}.form-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;margin-top:var(--spacing-sm)}.btn-cancel{padding:var(--spacing-sm) var(--spacing-lg);background:transparent;color:var(--stone-600);border:1px solid var(--stone-300);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.btn-cancel:hover:not(:disabled){background:var(--stone-100);border-color:var(--stone-400)}.btn-submit{padding:var(--spacing-sm) var(--spacing-lg);background:var(--elf-forest-green);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity var(--transition-fast);font-family:var(--font-body)}.btn-submit:hover:not(:disabled){opacity:.9}.btn-submit:disabled{opacity:.5;cursor:not-allowed}.members-section{border-top:1px solid var(--stone-200);padding-top:var(--spacing-md)}.members-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--spacing-sm)}.members-bulk-actions{display:flex;align-items:center;gap:var(--spacing-xs)}.btn-link{background:none;border:none;color:var(--elf-forest-green);font-size:.75rem;font-family:var(--font-body);cursor:pointer;padding:0;text-decoration:underline}.btn-link:hover:not(:disabled){color:var(--workshop-dusty-blue)}.btn-link:disabled{color:var(--stone-400);cursor:not-allowed;text-decoration:none}.members-bulk-actions .separator{color:var(--stone-400);font-size:.75rem}.members-list{display:flex;flex-direction:column;gap:var(--spacing-xs);max-height:200px;overflow-y:auto;border:1px solid var(--stone-200);border-radius:var(--radius-md);padding:var(--spacing-sm);background:var(--stone-50)}.member-checkbox{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.member-checkbox:hover{background:var(--stone-100)}.member-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--elf-forest-green);cursor:pointer;flex-shrink:0}.member-info{display:flex;flex-direction:column;flex:1;min-width:0}.member-name{font-size:.875rem;font-weight:500;color:var(--light-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-role-badge{font-size:.625rem;font-weight:600;text-transform:uppercase;padding:2px 6px;background:var(--elf-forest-green);color:var(--snow-white);border-radius:var(--radius-sm);flex-shrink:0}.modal-container{background:var(--snow-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:100%;max-height:90vh;overflow-y:auto;position:relative}.create-group-modal{width:400px;padding:var(--spacing-lg)}.modal-close{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);width:32px;height:32px;background:transparent;border:none;font-size:1.5rem;color:var(--stone-400);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-round);transition:all var(--transition-fast)}.modal-close:hover:not(:disabled){background:var(--stone-100);color:var(--stone-600)}.modal-close:disabled{opacity:.5;cursor:not-allowed}@media(max-width:480px){.create-group-modal{width:100%;margin:var(--spacing-md)}}.groups-container{min-height:100vh;background:var(--light-bg);padding:var(--spacing-lg)}.groups-content{max-width:600px;margin:0 auto}.groups-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.groups-page-header h2{font-family:var(--font-display);font-size:2rem;color:var(--elf-forest-green);margin:0}.btn-create-group{padding:var(--spacing-sm) var(--spacing-md);background:var(--elf-forest-green);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity var(--transition-fast);font-family:var(--font-body)}.btn-create-group:hover{opacity:.9}.groups-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.groups-empty-state{text-align:center;padding:var(--spacing-xl);border:2px dashed var(--stone-300);border-radius:var(--radius-lg);background:var(--light-card-bg)}.groups-empty-state .empty-icon{font-size:3rem;color:var(--stone-400);margin-bottom:var(--spacing-sm);display:block}.groups-empty-state .empty-title{font-weight:700;font-size:1.125rem;color:var(--light-text);margin:0 0 var(--spacing-xs) 0;font-family:var(--font-body)}.groups-empty-state .empty-message{font-size:.875rem;color:var(--light-text-muted);line-height:1.5;font-family:var(--font-body);margin:0 0 var(--spacing-md) 0}.btn-create-first{padding:var(--spacing-sm) var(--spacing-lg);background:var(--elf-forest-green);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity var(--transition-fast);font-family:var(--font-body)}.btn-create-first:hover{opacity:.9}.groups-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);border:1px solid var(--light-card-border);border-radius:var(--radius-lg);background:var(--light-card-bg);min-height:60vh;max-width:600px;margin:0 auto}.groups-loading .spinner{width:32px;height:32px;border:4px solid var(--elf-forest-green);border-top-color:transparent;border-radius:var(--radius-round);animation:spin 1s linear infinite;margin-bottom:var(--spacing-md)}.groups-loading p{color:var(--stone-600);font-family:var(--font-body)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.groups-error{text-align:center;padding:var(--spacing-xl);border:1px solid var(--alert-soft-red);border-radius:var(--radius-lg);background:var(--light-card-bg)}.groups-error p{color:var(--burgundy-accent);font-family:var(--font-body);margin:0 0 var(--spacing-md) 0}.btn-retry{padding:var(--spacing-sm) var(--spacing-md);background:var(--stone-200);color:var(--stone-700);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.btn-retry:hover{background:var(--stone-300)}.archive-toggle-container{margin-bottom:var(--spacing-md)}.archive-toggle{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.875rem;color:var(--light-text-muted);cursor:pointer;font-family:var(--font-body)}.archive-toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer}.archive-toggle:hover{color:var(--light-text)}.confirm-modal{max-width:400px;padding:var(--spacing-lg)}.confirm-modal h3{margin:0 0 var(--spacing-md) 0;font-family:var(--font-display);color:var(--light-text-dark)}.confirm-modal p{margin:0 0 var(--spacing-lg) 0;font-size:.875rem;color:var(--light-text);line-height:1.5;font-family:var(--font-body)}.confirm-modal-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end}.confirm-modal .btn-cancel{padding:var(--spacing-sm) var(--spacing-md);background:var(--stone-200);color:var(--stone-700);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.confirm-modal .btn-cancel:hover{background:var(--stone-300)}.btn-archive-confirm{padding:var(--spacing-sm) var(--spacing-md);background:var(--red-600, #dc2626);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity var(--transition-fast);font-family:var(--font-body)}.btn-archive-confirm:hover{opacity:.9}@media(max-width:768px){.groups-container{padding:var(--spacing-md)}.groups-page-header{flex-direction:column;gap:var(--spacing-md);align-items:stretch}.groups-page-header h2{font-size:1.5rem;text-align:center}.btn-create-group{width:100%;text-align:center}.confirm-modal-actions{flex-direction:column}.confirm-modal .btn-cancel,.btn-archive-confirm{width:100%}}.edit-group-modal{max-width:400px}.edit-group-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.edit-group-form .form-title{font-family:var(--font-display);font-size:1.5rem;color:var(--elf-forest-green);margin:0;text-align:center}.edit-group-form .form-error{padding:var(--spacing-sm) var(--spacing-md);background:var(--red-50);border:1px solid var(--alert-soft-red);border-radius:var(--radius-md);color:var(--burgundy-accent);font-size:.875rem;font-family:var(--font-body)}.edit-group-form .form-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.edit-group-form .form-label{font-family:var(--font-body);font-weight:600;font-size:.875rem;color:var(--light-text)}.edit-group-form .form-label .required{color:var(--burgundy-accent)}.edit-group-form .form-input{padding:var(--spacing-sm) var(--spacing-md);font-size:1rem;font-family:var(--font-body);border:1px solid var(--stone-300);border-radius:var(--radius-md);background:var(--snow-white);color:var(--light-text);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.edit-group-form .form-input:focus{outline:none;border-color:var(--elf-forest-green);box-shadow:0 0 0 3px #2f52331a}.edit-group-form .form-input:disabled{background:var(--stone-100);cursor:not-allowed}.edit-group-form .form-hint{font-size:.75rem;color:var(--light-text-muted);font-family:var(--font-body);text-align:right}.edit-group-form .form-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;margin-top:var(--spacing-sm)}.edit-group-form .btn-cancel{padding:var(--spacing-sm) var(--spacing-lg);background:transparent;color:var(--stone-600);border:1px solid var(--stone-300);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.edit-group-form .btn-cancel:hover:not(:disabled){background:var(--stone-100);border-color:var(--stone-400)}.edit-group-form .btn-cancel:disabled{opacity:.5;cursor:not-allowed}.edit-group-form .btn-submit{padding:var(--spacing-sm) var(--spacing-lg);background:var(--elf-forest-green);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity var(--transition-fast);font-family:var(--font-body)}.edit-group-form .btn-submit:hover:not(:disabled){opacity:.9}.edit-group-form .btn-submit:disabled{opacity:.5;cursor:not-allowed}.add-members-modal{max-width:500px;width:90%}.add-members-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--stone-200)}.add-members-modal .modal-title{font-family:var(--font-display);font-size:1.25rem;color:var(--elf-forest-green);margin:0}.add-members-modal .modal-close{background:none;border:none;font-size:1.5rem;color:var(--light-text-muted);cursor:pointer;padding:0;line-height:1;transition:color var(--transition-fast)}.add-members-modal .modal-close:hover{color:var(--light-text)}.add-members-modal .modal-body{padding:var(--spacing-lg)}.add-instructions{color:var(--light-text-muted);font-size:.875rem;margin:0 0 var(--spacing-md) 0}.add-member-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.email-input-container{display:flex;flex-direction:column;gap:var(--spacing-sm)}.email-textarea{width:100%;padding:var(--spacing-sm);border:1px solid var(--stone-300);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.875rem;resize:vertical;min-height:100px}.email-textarea:focus{outline:none;border-color:var(--elf-forest-green);box-shadow:0 0 0 2px #2f52331a}.email-textarea:disabled{background:var(--stone-100);cursor:not-allowed}.parsed-emails-preview{background:var(--stone-50);border:1px solid var(--stone-200);border-radius:var(--radius-md);padding:var(--spacing-sm)}.preview-header{margin-bottom:var(--spacing-xs)}.preview-count{font-size:.75rem;color:var(--light-text-muted)}.email-chips{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.email-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-sm);font-size:.75rem;font-family:var(--font-body)}.email-chip.valid{background:var(--emerald-100);color:var(--emerald-700)}.email-chip.invalid{background:var(--red-100, #fee2e2);color:var(--red-700, #b91c1c)}.error-icon{font-weight:700}.add-results{background:var(--stone-50);border:1px solid var(--stone-200);border-radius:var(--radius-md);padding:var(--spacing-sm)}.results-summary{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-sm);font-size:.75rem;font-weight:600}.success-summary{color:var(--emerald-600)}.invited-summary{color:var(--workshop-dusty-blue)}.fail-summary{color:var(--red-600, #dc2626)}.results-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.result-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.75rem}.result-item.success{background:var(--emerald-50)}.result-item.invited{background:var(--workshop-dusty-blue-light, #e8f0f3)}.result-item.error{background:var(--red-50, #fef2f2)}.result-email{font-weight:500}.result-message{color:var(--light-text-muted)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid var(--stone-200)}.btn-cancel{padding:var(--spacing-sm) var(--spacing-lg);background:var(--snow-white);color:var(--light-text);border:1px solid var(--stone-300);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.btn-cancel:hover:not(:disabled){background:var(--stone-100)}.btn-cancel:disabled{opacity:.5;cursor:not-allowed}.btn-add-members{padding:var(--spacing-sm) var(--spacing-lg);background:var(--elf-forest-green);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity var(--transition-fast);font-family:var(--font-body)}.btn-add-members:hover:not(:disabled){opacity:.9}.btn-add-members:disabled{opacity:.5;cursor:not-allowed}.activity-group-detail-container{min-height:100vh;background:var(--parchment-cream);padding:var(--spacing-xl) var(--spacing-lg)}.activity-group-detail-content{max-width:900px;margin:0 auto}.activity-group-loading,.activity-group-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:var(--spacing-md);text-align:center}.activity-group-error p{color:var(--burgundy-accent);font-size:1rem}.btn-back{padding:var(--spacing-sm) var(--spacing-lg);background:var(--elf-forest-green);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity var(--transition-fast)}.btn-back:hover{opacity:.9}.activity-group-header{margin-bottom:var(--spacing-xl)}.btn-back-link{background:none;border:none;color:var(--elf-forest-green);font-size:.875rem;cursor:pointer;padding:0;margin-bottom:var(--spacing-md);display:inline-flex;align-items:center;gap:var(--spacing-xs);font-family:var(--font-body)}.btn-back-link:hover{text-decoration:underline}.header-content{margin-bottom:var(--spacing-md)}.header-title-row{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.header-title-row h1{font-family:var(--font-display);font-size:2rem;color:var(--elf-forest-green);margin:0}.archived-badge{font-size:.75rem;font-weight:600;text-transform:uppercase;padding:4px 10px;background:var(--stone-200);color:var(--stone-600);border-radius:var(--radius-sm)}.group-meta{font-size:.875rem;color:var(--light-text-muted);margin-top:var(--spacing-xs);display:flex;align-items:center;gap:var(--spacing-sm)}.organizer-badge{font-size:.625rem;font-weight:600;text-transform:uppercase;padding:2px 8px;background:var(--elf-forest-green);color:var(--snow-white);border-radius:var(--radius-sm)}.header-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.header-actions button{padding:var(--spacing-sm) var(--spacing-md);font-size:.875rem;font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.btn-edit{background:var(--snow-white);color:var(--elf-forest-green);border:1px solid var(--elf-forest-green)}.btn-edit:hover{background:var(--elf-forest-green);color:var(--snow-white)}.btn-add-members{background:var(--snow-white);color:var(--workshop-dusty-blue);border:1px solid var(--workshop-dusty-blue)}.btn-add-members:hover{background:var(--workshop-dusty-blue);color:var(--snow-white)}.btn-delete{background:var(--snow-white);color:var(--burgundy-accent);border:1px solid var(--burgundy-accent)}.btn-delete:hover{background:var(--burgundy-accent);color:var(--snow-white)}.activity-group-sections{display:flex;flex-direction:column;gap:var(--spacing-xl)}.activity-group-sections section h2{font-family:var(--font-display);font-size:1.25rem;color:var(--elf-forest-green);margin:0 0 var(--spacing-md) 0;padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--stone-200)}.members-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-md)}.member-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--snow-white);border:1px solid var(--stone-200);border-radius:var(--radius-md)}.member-avatar{width:40px;height:40px;border-radius:50%;background:var(--elf-forest-green);color:var(--snow-white);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem;text-transform:uppercase;flex-shrink:0}.member-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.member-name{font-weight:500;color:var(--light-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-email{font-size:.75rem;color:var(--light-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.role-badge{font-size:.625rem;font-weight:600;text-transform:uppercase;padding:2px 8px;background:var(--elf-forest-green);color:var(--snow-white);border-radius:var(--radius-sm);flex-shrink:0}.pending-invitations-header{font-family:var(--font-body);font-size:1rem;font-weight:600;color:var(--workshop-dusty-blue);margin:var(--spacing-lg) 0 var(--spacing-md) 0;padding-top:var(--spacing-md);border-top:1px dashed var(--stone-300)}.member-card.pending-invitation{background:var(--light-bg);border-style:dashed;border-color:var(--workshop-dusty-blue)}.member-avatar.pending{background:var(--workshop-dusty-blue);opacity:.7;font-style:italic}.member-name.pending-name{color:var(--light-text-muted);font-style:italic}.status-badge.pending{font-size:.625rem;font-weight:600;text-transform:uppercase;padding:2px 8px;background:var(--workshop-dusty-blue);color:var(--snow-white);border-radius:var(--radius-sm);flex-shrink:0;opacity:.8}.btn-remove-member{width:24px;height:24px;padding:0;background:transparent;border:1px solid var(--stone-300);border-radius:var(--radius-round);color:var(--light-text-muted);font-size:1rem;line-height:1;cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;display:flex;align-items:center;justify-content:center}.btn-remove-member:hover:not(:disabled){background:var(--red-50, #fef2f2);border-color:var(--red-400, #f87171);color:var(--red-600, #dc2626)}.btn-remove-member:disabled{opacity:.5;cursor:not-allowed}.agd-activities-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.agd-exchange-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--snow-white);border:1px solid var(--stone-200);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.agd-exchange-card:hover{border-color:var(--elf-forest-green);box-shadow:var(--shadow-sm)}.agd-exchange-icon{font-size:1.5rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--emerald-50);border-radius:var(--radius-md);flex-shrink:0}.agd-exchange-info{flex:1;min-width:0}.agd-exchange-name{margin:0 0 var(--spacing-xs) 0;font-family:var(--font-body);font-weight:600;font-size:1rem;color:var(--light-text)}.agd-exchange-meta{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.agd-exchange-type{font-size:.75rem;color:var(--light-text-muted)}.agd-exchange-status{font-size:.625rem;font-weight:600;text-transform:uppercase;padding:2px 6px;border-radius:var(--radius-sm)}.agd-exchange-status.matched{background:var(--emerald-100);color:var(--emerald-600)}.agd-exchange-date{margin:0;font-size:.875rem;color:var(--light-text-muted)}.agd-exchange-arrow{font-size:1.25rem;color:var(--light-text-muted);flex-shrink:0}.agd-exchange-card:hover .agd-exchange-arrow{color:var(--elf-forest-green)}.agd-activities-placeholder{padding:var(--spacing-xl);background:var(--snow-white);border:2px dashed var(--stone-300);border-radius:var(--radius-md);text-align:center;color:var(--light-text-muted)}.agd-activities-placeholder p{margin:0 0 var(--spacing-md) 0}.agd-btn-create-activity{padding:var(--spacing-sm) var(--spacing-lg);background:var(--stone-100);color:var(--stone-500);border:1px solid var(--stone-300);border-radius:var(--radius-md);font-size:.875rem;cursor:not-allowed}.agd-btn-add-activity{padding:var(--spacing-sm) var(--spacing-lg);background:var(--elf-forest-green);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity var(--transition-fast);font-family:var(--font-body)}.agd-btn-add-activity:hover{opacity:.9}.agd-add-activity-section{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md);flex-wrap:wrap}.agd-btn-add-activity-disabled{padding:var(--spacing-sm) var(--spacing-lg);background:var(--stone-100);color:var(--stone-400);border:1px solid var(--stone-300);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:not-allowed;font-family:var(--font-body)}.btn-delete-confirm{padding:var(--spacing-sm) var(--spacing-lg);background:var(--burgundy-accent);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity var(--transition-fast)}.btn-delete-confirm:hover:not(:disabled){opacity:.9}.btn-delete-confirm:disabled{opacity:.5;cursor:not-allowed}@media(max-width:600px){.activity-group-detail-container{padding:var(--spacing-md)}.header-title-row h1{font-size:1.5rem}.header-actions{width:100%}.header-actions button{flex:1}.members-grid{grid-template-columns:1fr}}.quiz-create-page{min-height:100vh;background:var(--parchment-cream)}.quiz-create-content{padding:var(--spacing-xl);max-width:800px;margin:0 auto}.quiz-create-container{background:var(--light-card-bg-solid);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-xl)}.quiz-create-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.page-title{font-family:var(--font-display);font-size:1.75rem;color:var(--elf-forest-green);margin:0}.selected-group-badge{font-family:var(--font-body);font-size:.875rem;padding:var(--spacing-xs) var(--spacing-md);background:var(--stone-100);border-radius:var(--radius-md);color:var(--stone-600)}.wizard-step{margin-bottom:var(--spacing-lg)}.step-title{font-family:var(--font-display);font-size:1.25rem;color:var(--elf-forest-green);margin:0 0 var(--spacing-xs) 0}.step-description{font-family:var(--font-body);font-size:.9375rem;color:var(--light-text-muted);margin:0 0 var(--spacing-lg) 0}.quiz-title-input{width:100%;padding:var(--spacing-md);font-size:1rem;font-family:var(--font-body);border:2px solid var(--stone-200);border-radius:var(--radius-md);background:var(--snow-white);color:var(--light-text);transition:border-color var(--transition-fast)}.quiz-title-input:focus{outline:none;border-color:var(--elf-forest-green)}.quiz-title-input::placeholder{color:var(--stone-400)}.group-selection-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.quiz-group-option{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--stone-50);border:2px solid var(--stone-200);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%}.quiz-group-option:hover{border-color:var(--elf-forest-green);background:var(--snow-white)}.quiz-group-option.selected{border-color:var(--elf-forest-green);background:#ecf5ed}.quiz-group-option-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--stone-200);border-radius:var(--radius-round);font-size:1.25rem;flex-shrink:0}.quiz-group-option.selected .quiz-group-option-icon{background:var(--elf-forest-green)}.quiz-group-option-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.quiz-group-option-name{font-family:var(--font-body);font-weight:600;font-size:.9375rem;color:var(--light-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.quiz-group-option-meta{font-family:var(--font-body);font-size:.8125rem;color:var(--light-text-muted)}.quiz-group-option-check{font-size:1.25rem;color:var(--elf-forest-green);font-weight:600;flex-shrink:0}.group-loading{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-xl);color:var(--light-text-muted);font-family:var(--font-body);font-size:.9375rem}.group-loading .loading-spinner{display:inline-block;width:1.25rem;height:1.25rem;border:2px solid var(--stone-300);border-radius:50%;border-top-color:var(--elf-forest-green);animation:spin .8s linear infinite}.group-error{padding:var(--spacing-md);background:var(--red-100);border:1px solid var(--alert-soft-red);border-radius:var(--radius-md);color:var(--burgundy-accent);font-size:.9375rem;font-family:var(--font-body);text-align:center}.no-groups{text-align:center;padding:var(--spacing-xl)}.no-groups p{font-family:var(--font-body);font-size:.9375rem;color:var(--light-text-muted);margin-bottom:var(--spacing-md)}.config-placeholder{padding:var(--spacing-lg);background:var(--stone-100);border-radius:var(--radius-md);text-align:center}.config-placeholder p{font-family:var(--font-body);font-size:.9375rem;color:var(--light-text);margin:var(--spacing-xs) 0}.wizard-actions{display:flex;justify-content:space-between;gap:var(--spacing-md);padding-top:var(--spacing-lg);border-top:1px solid var(--stone-200);margin-top:var(--spacing-lg)}.btn-back{padding:var(--spacing-sm) var(--spacing-lg);background:transparent;color:var(--stone-600);border:1px solid var(--stone-300);border-radius:var(--radius-md);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.btn-back:hover{background:var(--stone-100);border-color:var(--stone-400)}.btn-next{padding:var(--spacing-sm) var(--spacing-xl);background:var(--elf-forest-green);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.btn-next:hover:not(:disabled){opacity:.9}.btn-next:disabled{background:var(--stone-300);cursor:not-allowed}.edit-tabs{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);border-bottom:1px solid var(--stone-200);padding-bottom:var(--spacing-sm)}.edit-tab{padding:var(--spacing-sm) var(--spacing-lg);background:transparent;color:var(--stone-600);border:none;border-radius:var(--radius-md) var(--radius-md) 0 0;font-size:.9375rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.edit-tab:hover{background:var(--stone-100)}.edit-tab.active{background:var(--elf-forest-green);color:var(--snow-white)}.edit-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding-top:var(--spacing-lg);border-top:1px solid var(--stone-200);margin-top:var(--spacing-lg)}.btn-secondary{padding:var(--spacing-sm) var(--spacing-lg);background:var(--stone-200);color:var(--light-text);border:none;border-radius:var(--radius-md);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.btn-primary{padding:var(--spacing-sm) var(--spacing-xl);background:var(--elf-forest-green);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.btn-primary:hover:not(:disabled){opacity:.9}.btn-primary:disabled,.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.loading-state,.error-state{text-align:center;padding:var(--spacing-xl);font-family:var(--font-body)}.error-state p{color:var(--alert-soft-red);margin-bottom:var(--spacing-md)}.submit-error{padding:var(--spacing-md);background:var(--red-50);border:1px solid var(--red-200);border-radius:var(--radius-md);color:var(--alert-soft-red);font-family:var(--font-body);font-size:.9375rem;margin-top:var(--spacing-md)}@media(max-width:768px){.quiz-create-content,.quiz-create-container{padding:var(--spacing-md)}.quiz-create-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.group-selection-grid{grid-template-columns:1fr}}@media(max-width:480px){.page-title{font-size:1.5rem}.step-title{font-size:1.125rem}.wizard-actions{flex-direction:column;gap:var(--spacing-sm)}.btn-back,.btn-next{width:100%;text-align:center}}.quiz-status-badge{font-family:var(--font-body);font-size:.75rem;font-weight:600;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);text-transform:uppercase;letter-spacing:.025em}.quiz-status--completed{background:var(--stone-200);color:var(--stone-700)}.quiz-status--active{background:#e0f2e9;color:var(--elf-forest-green)}.quiz-status--cancelled{background:var(--red-100);color:var(--burgundy-accent)}.quiz-status--draft{background:var(--amber-100);color:var(--amber-700)}.quiz-info-grid{display:flex;flex-direction:column;gap:var(--spacing-sm)}.quiz-info-item{display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm) 0;border-bottom:1px solid var(--stone-100)}.quiz-info-item:last-child{border-bottom:none}.info-label{font-family:var(--font-body);font-size:.875rem;font-weight:600;color:var(--light-text-muted);min-width:80px}.info-value{font-family:var(--font-body);font-size:.875rem;color:var(--light-text)}.quiz-info-readonly{padding:var(--spacing-md);background:var(--stone-50);border-radius:var(--radius-md);border:1px solid var(--stone-200)}.quiz-info-readonly .info-value{font-size:1rem}.danger-zone{margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--stone-200)}.danger-title{color:var(--burgundy-accent)!important}.btn-danger{padding:var(--spacing-sm) var(--spacing-lg);background:var(--burgundy-accent);color:var(--snow-white);border:none;border-radius:var(--radius-md);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.btn-danger:hover:not(:disabled){opacity:.9}.delete-confirm{padding:var(--spacing-md);background:var(--red-50);border:1px solid var(--red-200);border-radius:var(--radius-md)}.delete-confirm p{font-family:var(--font-body);font-size:.9375rem;color:var(--burgundy-accent);margin:0 0 var(--spacing-md) 0}.delete-confirm-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end}.quiz-lobby-page{min-height:100vh;background:var(--parchment-cream)}.quiz-lobby-content{max-width:600px;margin:0 auto;padding:var(--spacing-xl) var(--spacing-md)}.quiz-lobby-container{display:flex;flex-direction:column;gap:var(--spacing-lg)}.quiz-lobby-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-xxl);color:var(--light-text-muted)}.loading-spinner{width:32px;height:32px;border:3px solid var(--stone-200);border-top-color:var(--elf-forest-green);border-radius:var(--radius-round);animation:spin 1s linear infinite}.quiz-lobby-error{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-xxl);text-align:center}.quiz-lobby-error p{color:var(--alert-soft-red);margin:0}.quiz-lobby-header{text-align:center}.quiz-title{font-family:var(--font-heading);font-size:1.75rem;font-weight:700;color:var(--light-text);margin:0 0 var(--spacing-xs)}.quiz-meta{font-family:var(--font-body);font-size:.9375rem;color:var(--light-text-muted);margin:0}.lobby-error-message{background:var(--red-50);border:1px solid var(--red-200);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);color:var(--alert-soft-red);text-align:center}.lobby-actions{display:flex;justify-content:center;gap:var(--spacing-md);flex-wrap:wrap}.btn-action{font-family:var(--font-body);font-size:1rem;font-weight:600;padding:var(--spacing-sm) var(--spacing-xl);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-action:disabled{opacity:.6;cursor:not-allowed}.btn-start{background:var(--elf-forest-green);color:var(--snow-white)}.btn-start:hover:not(:disabled){background:var(--emerald-700)}.btn-cancel,.btn-leave{background:var(--stone-200);color:var(--light-text)}.btn-cancel:hover:not(:disabled),.btn-leave:hover:not(:disabled){background:var(--stone-300)}.btn-edit{background:var(--workshop-dusty-blue);color:var(--snow-white)}.btn-edit:hover:not(:disabled){opacity:.9}.btn-delete{background:var(--alert-soft-red);color:var(--snow-white)}.btn-delete:hover:not(:disabled){background:var(--red-700)}.share-link-section{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md);background:var(--stone-50);border-radius:var(--radius-md)}.share-label{font-size:.75rem;color:var(--light-text-muted);text-transform:uppercase;letter-spacing:.05em}.share-url{font-family:var(--font-mono, monospace);font-size:.875rem;color:var(--light-text);background:var(--snow-white);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);border:1px solid var(--stone-200);word-break:break-all}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.modal-content{background:var(--snow-white);border-radius:var(--radius-lg);padding:var(--spacing-xl);max-width:400px;width:100%;box-shadow:var(--shadow-xl)}.modal-content h3{font-family:var(--font-heading);font-size:1.25rem;font-weight:700;color:var(--light-text);margin:0 0 var(--spacing-sm)}.modal-content p{font-family:var(--font-body);font-size:.9375rem;color:var(--light-text-muted);margin:0 0 var(--spacing-lg)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm)}.btn-secondary{font-family:var(--font-body);font-size:.9375rem;font-weight:600;padding:var(--spacing-sm) var(--spacing-md);background:var(--stone-200);color:var(--light-text);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-secondary:hover:not(:disabled){background:var(--stone-300)}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-danger{font-family:var(--font-body);font-size:.9375rem;font-weight:600;padding:var(--spacing-sm) var(--spacing-md);background:var(--alert-soft-red);color:var(--snow-white);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-danger:hover:not(:disabled){background:var(--red-700)}.btn-danger:disabled{opacity:.6;cursor:not-allowed}@media(max-width:480px){.quiz-lobby-content{padding:var(--spacing-lg) var(--spacing-sm)}.quiz-title{font-size:1.5rem}.lobby-actions{flex-direction:column;gap:var(--spacing-sm)}.btn-action{width:100%}}.quiz-play-page{min-height:100vh;background:var(--parchment-cream)}.quiz-play-content{padding:var(--spacing-lg);max-width:680px;margin:0 auto}.quiz-play-container{display:flex;flex-direction:column;gap:var(--spacing-lg)}.quiz-play-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md)}.answer-section{display:flex;flex-direction:column;gap:var(--spacing-sm)}.style-hint{font-family:var(--font-body);font-size:.875rem;color:var(--light-text-muted);font-style:italic;margin:0;text-align:center}.navigation-hint{padding:var(--spacing-md);background:var(--stone-100);border-radius:var(--radius-md);text-align:center}.hint-text{font-family:var(--font-body);font-size:.875rem;color:var(--light-text-muted);margin:0}.quiz-play-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-xxl);color:var(--light-text-muted);font-family:var(--font-body)}.loading-spinner{width:32px;height:32px;border:3px solid var(--stone-200);border-top-color:var(--elf-forest-green);border-radius:50%;animation:spin 1s linear infinite}.quiz-play-error{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-xxl);text-align:center}.quiz-play-error p{font-family:var(--font-body);font-size:1rem;color:var(--light-text-muted);margin:0}.quiz-completed{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-xxl);text-align:center;background:var(--snow-white);border-radius:var(--radius-lg);border:1px solid var(--stone-200)}.completed-icon{font-size:4rem}.quiz-completed h2{font-family:var(--font-display);font-size:1.75rem;font-weight:700;color:var(--elf-forest-green);margin:0}.quiz-completed p{font-family:var(--font-body);font-size:1rem;color:var(--light-text);margin:0}.awaiting-text{color:var(--light-text-muted);font-style:italic}.btn-action{padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--radius-md);font-family:var(--font-body);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-green{background:var(--elf-forest-green);color:var(--snow-white)}.btn-green:hover:not(:disabled){opacity:.9}.btn-green:disabled{opacity:.5;cursor:not-allowed}.submit-section{display:flex;justify-content:center;padding:var(--spacing-md) 0}.btn-submit{min-width:200px;min-height:48px;font-size:1rem}.quiz-confirmation{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-xxl);text-align:center;background:var(--snow-white);border-radius:var(--radius-lg);border:1px solid var(--stone-200)}.quiz-confirmation.correct{border-color:var(--emerald-300, #6ee7b7);background:linear-gradient(to bottom,var(--emerald-50, #ecfdf5),var(--snow-white))}.quiz-confirmation.incorrect{border-color:var(--red-300, #fca5a5);background:linear-gradient(to bottom,var(--red-50, #fef2f2),var(--snow-white))}.confirmation-icon{width:80px;height:80px;border-radius:50%;font-size:3rem;display:flex;align-items:center;justify-content:center;animation:scaleIn .3s ease-out}.confirmation-icon.correct{background:var(--emerald-500, #10b981);color:var(--snow-white)}.confirmation-icon.incorrect{background:var(--red-500, #ef4444);color:var(--snow-white)}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.quiz-confirmation h2{font-family:var(--font-display);font-size:1.75rem;font-weight:700;margin:0}.quiz-confirmation h2.correct-text{color:var(--emerald-600, #059669)}.quiz-confirmation h2.incorrect-text{color:var(--red-600, #dc2626)}.correct-answer-hint{font-family:var(--font-body);font-size:1rem;color:var(--light-text-muted);margin:0;padding:var(--spacing-sm) var(--spacing-md);background:var(--stone-100);border-radius:var(--radius-md)}.correct-answer-hint strong{color:var(--light-text)}.btn-next-question{min-width:180px;min-height:48px;font-size:1rem}.offline-indicator{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--amber-100, #fef3c7);border:1px solid var(--amber-300, #fcd34d);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.875rem;color:var(--amber-800, #92400e)}.offline-icon{font-size:1.25rem}.sync-indicator{display:flex;align-items:center;justify-content:center;padding:var(--spacing-xs) var(--spacing-md);background:var(--stone-100);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.875rem;color:var(--light-text-muted)}@media(max-width:480px){.quiz-play-content{padding:var(--spacing-md)}.quiz-play-header{flex-direction:column;gap:var(--spacing-sm)}}.character-voting-page{min-height:100vh;background:var(--color-bg)}.voting-content{max-width:600px;margin:0 auto;padding:20px}.character-voting{display:flex;flex-direction:column;gap:20px}.voting-header{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.voting-progress-text{font-size:18px;font-weight:600;color:var(--color-text);text-align:center}.voting-progress-bar{height:8px;background:var(--color-border);border-radius:4px;overflow:hidden}.voting-progress-fill{height:100%;background:var(--color-primary);border-radius:4px;transition:width .3s ease}.voting-timer{display:flex;align-items:center;justify-content:center;gap:8px;font-size:20px;font-weight:600;color:var(--color-text)}.voting-timer.warning{color:var(--color-error, #dc3545);animation:pulse 1s ease-in-out infinite}.timer-icon{font-size:24px}.character-card{background:var(--color-surface);border-radius:16px;padding:24px;text-align:center;box-shadow:0 4px 12px #0000001a;border:1px solid var(--color-border)}.movie-context{display:flex;align-items:center;justify-content:center;gap:8px;color:var(--color-text-secondary);font-size:14px;margin-bottom:16px}.movie-icon{font-size:20px}.character-info{display:flex;flex-direction:column;gap:12px}.character-name{font-size:28px;font-weight:700;color:var(--color-primary);margin:0}.character-description{font-style:italic;color:var(--color-text-secondary);font-size:18px;line-height:1.5;margin:0}.vote-prompt{text-align:center;font-size:20px;font-weight:600;color:var(--color-text);margin:8px 0}.participant-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:16px;margin:16px 0}.participant-btn{display:flex;flex-direction:column;align-items:center;padding:16px;border:2px solid var(--color-border);border-radius:12px;background:var(--color-surface);cursor:pointer;transition:all .2s ease}.participant-btn:hover:not(:disabled){border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.participant-btn:disabled{opacity:.6;cursor:not-allowed}.avatar{width:60px;height:60px;border-radius:50%;background:var(--color-accent);display:flex;align-items:center;justify-content:center;margin-bottom:8px}.initials{font-size:24px;font-weight:700;color:#fff}.participant-btn .name{font-size:14px;font-weight:500;color:var(--color-text);text-align:center;word-break:break-word}.skip-btn{width:100%;padding:12px 24px;background:transparent;border:2px solid var(--color-border);border-radius:8px;color:var(--color-text-secondary);font-size:16px;cursor:pointer;transition:all .2s ease}.skip-btn:hover:not(:disabled){border-color:var(--color-text-secondary);color:var(--color-text)}.skip-btn:disabled{opacity:.6;cursor:not-allowed}.voting-waiting{text-align:center;padding:60px 20px}.waiting-icon{font-size:64px;animation:pulse 2s infinite}.voting-waiting h2{font-size:24px;color:var(--color-text);margin:24px 0 8px}.voting-waiting p{color:var(--color-text-secondary);font-size:18px}.ready-message{margin-top:24px;padding:16px;background:var(--color-success-bg, #d4edda);border-radius:8px;display:flex;align-items:center;justify-content:center;gap:8px;color:var(--color-success, #155724);font-weight:500}.checkmark{font-size:20px;color:var(--color-success, #28a745)}.loading-spinner{font-size:18px;color:var(--color-text-secondary)}.error-message{color:var(--color-error, #dc3545);font-size:18px;margin-bottom:16px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media(max-width:480px){.voting-content{padding:12px}.character-card{padding:16px}.character-name{font-size:24px}.character-description{font-size:16px}.participant-grid{grid-template-columns:repeat(2,1fr);gap:12px}.avatar{width:50px;height:50px}.initials{font-size:20px}}.results-flow-page{min-height:100vh;background:var(--color-bg)}.results-flow{max-width:800px;margin:0 auto;padding:20px;min-height:calc(100vh - 80px);display:flex;flex-direction:column}.results-header{display:flex;justify-content:center;align-items:center;gap:24px;margin-bottom:24px}.page-indicator{display:flex;justify-content:center;gap:8px}.dot{width:12px;height:12px;border-radius:50%;background:var(--color-border);border:none;cursor:pointer;transition:all .2s ease;padding:0}.dot:hover{background:var(--color-text-secondary);transform:scale(1.1)}.dot.active{background:var(--color-primary);transform:scale(1.3)}.auto-advance{position:relative;width:40px;height:40px;display:flex;align-items:center;justify-content:center}.progress-ring{position:absolute;width:100%;height:100%;border-radius:50%;background:conic-gradient(var(--color-primary) calc(var(--progress) * 1%),var(--color-border) 0)}.time-left{position:relative;font-size:12px;font-weight:600;color:var(--color-text);z-index:1}.page-container{flex:1;display:flex;flex-direction:column}.page-transition{animation:fadeSlideIn .3s ease-out}@keyframes fadeSlideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.results-page{flex:1}.page-content{background:var(--color-surface);border-radius:16px;padding:32px;box-shadow:0 4px 12px #0000001a;text-align:center}.winner-page .page-content{background:linear-gradient(135deg,var(--color-surface) 0%,var(--color-accent-light, #f8f4ef) 100%)}.winner-announcement{text-align:center;padding:40px 20px;background:linear-gradient(135deg,gold,#fff3c4,gold);border-radius:20px;margin-bottom:32px;box-shadow:0 4px 20px #ffd7004d}.sparkles{font-size:36px;margin-bottom:8px}.crown-icon{font-size:80px;animation:crownBounce 1s ease infinite}@keyframes crownBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.winner-title{font-size:32px;color:var(--color-primary);margin:16px 0;text-transform:uppercase;letter-spacing:2px}.winner-name{font-size:48px;font-weight:700;color:var(--color-text);margin-bottom:8px}.tied-winners{display:flex;flex-wrap:wrap;justify-content:center;gap:8px}.tied-winners .winner-name{font-size:36px}.winner-score{font-size:48px;font-weight:700;color:var(--color-primary);margin-top:16px}.leaderboard{background:#fff;border-radius:16px;padding:24px;margin-bottom:24px}.leaderboard h3{text-align:center;margin-bottom:16px;font-size:20px;color:var(--color-text)}.leaderboard-table{width:100%;border-collapse:collapse}.leaderboard-table th{padding:12px 8px;text-align:left;font-weight:600;color:var(--color-text-secondary);border-bottom:2px solid var(--color-border);font-size:14px}.leaderboard-table tr{border-bottom:1px solid var(--color-border)}.leaderboard-table tr:last-child{border-bottom:none}.leaderboard-table tr.current-user{background:var(--color-accent-light, #f8f4ef)}.leaderboard-table tr.biggest-loser{background:#fff3e0}.leaderboard-table td{padding:12px 8px}.rank-cell{font-size:20px;width:50px}.name-cell{font-weight:500}.score-cell{font-weight:600;color:var(--color-primary)}.time-cell{color:var(--color-text-secondary)}.biggest-loser-callout{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px 24px;background:#fff3e0;border-radius:12px;margin-bottom:24px}.jester-icon{font-size:32px}.loser-text{font-size:16px;color:var(--color-text)}.speed-callouts{display:flex;justify-content:center;flex-wrap:wrap;gap:16px;margin-bottom:24px}.speed-callout{display:flex;align-items:center;gap:8px;padding:12px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d}.speed-callout .speed-icon{font-size:24px}.speed-callout .speed-label{color:var(--color-text-secondary);font-size:14px}.speed-callout .speed-name{font-weight:600;color:var(--color-text)}.speed-callout .speed-time{color:var(--color-text-secondary);font-size:14px}.your-result{margin-top:24px;padding:16px;background:var(--color-accent);border-radius:8px;color:#fff;font-size:18px}.stats-page h2{margin-bottom:24px;color:var(--color-text)}.stats-cards{display:flex;flex-direction:column;gap:24px;margin-bottom:32px}.question-stat-card{background:#fff;border-radius:16px;padding:24px;border-left:4px solid;box-shadow:0 2px 8px #0000001a;text-align:left}.question-stat-card.missed{border-left-color:#dc3545}.question-stat-card.aced{border-left-color:#28a745}.question-stat-card.divisive{border-left-color:#ffc107}.question-stat-card .card-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.question-stat-card .stat-emoji{font-size:32px}.question-stat-card h3{font-size:18px;text-transform:uppercase;letter-spacing:1px;margin:0;color:var(--color-text)}.question-stat-card .question-text{font-size:18px;font-style:italic;color:var(--color-text);margin-bottom:8px;line-height:1.4}.question-stat-card .correct-answer{font-size:14px;color:var(--color-text-secondary);margin-bottom:12px}.question-stat-card .correct-answer strong{color:#28a745}.question-stat-card .stat-message{font-weight:600;font-size:16px;color:var(--color-text);margin-bottom:16px}.answer-distribution{margin-top:16px}.distribution-row{display:flex;align-items:center;gap:12px;margin-bottom:10px}.answer-label{width:120px;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--color-text-secondary)}.answer-label.correct{font-weight:600;color:#28a745}.bar-container{flex:1;height:24px;background:#e9ecef;border-radius:4px;overflow:hidden}.bar{height:100%;background:#a0a0a0;border-radius:4px;transition:width .6s ease-out;animation:barGrow .6s ease-out}.bar.correct{background:#28a745}@keyframes barGrow{0%{width:0%}}.percentage{width:45px;text-align:right;font-size:14px;font-weight:600;color:var(--color-text)}.all-questions-section{margin-top:24px}.toggle-questions-btn{width:100%;padding:16px;background:#fff;border:1px solid var(--color-border);border-radius:8px;cursor:pointer;font-size:16px;font-weight:500;color:var(--color-text);transition:all .2s}.toggle-questions-btn:hover{background:var(--color-bg);border-color:var(--color-text-secondary)}.questions-list{margin-top:16px;max-height:500px;overflow-y:auto;border:1px solid var(--color-border);border-radius:8px;background:#fff}.question-item{padding:16px;border-bottom:1px solid var(--color-border)}.question-item:last-child{border-bottom:none}.question-item .question-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.question-number{font-weight:700;color:var(--color-primary);font-size:14px}.rate-badge{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:600}.rate-badge.good{background:#d4edda;color:#155724}.rate-badge.medium{background:#fff3cd;color:#856404}.rate-badge.bad{background:#f8d7da;color:#721c24}.question-item .question-text{font-size:15px;color:var(--color-text);margin-bottom:6px;line-height:1.4}.question-item .answer-text{font-size:14px;color:var(--color-text-secondary)}.question-item .answer-text strong{color:#28a745}.character-page .page-content{max-width:500px;margin:0 auto}.movie-badge{display:inline-block;padding:8px 16px;background:var(--color-primary);color:#fff;border-radius:20px;font-size:14px;font-weight:500;margin-bottom:24px}.character-reveal-card{padding:24px}.character-reveal-card .character-name{font-size:32px;color:var(--color-primary);margin:0 0 12px}.character-reveal-card .character-desc{font-style:italic;color:var(--color-text-secondary);font-size:18px;margin-bottom:32px}.reveal-section{padding:24px;background:var(--color-bg);border-radius:12px}.reveal-section .reveal-label{font-size:20px;color:var(--color-text-secondary);margin-bottom:16px}.winner-reveal-container{min-height:180px;display:flex;align-items:center;justify-content:center}.suspense-dots{display:flex;gap:8px}.suspense-dots span{font-size:48px;font-weight:700;color:var(--color-primary);animation:blink 1s infinite}.suspense-dots span:nth-child(2){animation-delay:.2s}.suspense-dots span:nth-child(3){animation-delay:.4s}@keyframes blink{0%,to{opacity:.2}50%{opacity:1}}.winner-display{text-align:center;animation:revealIn .5s ease-out}@keyframes revealIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.winner-display .sparkles{font-size:40px;margin-bottom:8px}.revealed-winner-name{font-size:36px;font-weight:700;color:var(--color-primary);margin:8px 0 16px}.winner-avatar{width:80px;height:80px;border-radius:50%;background:var(--color-accent);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:28px;font-weight:700;color:#fff}.winner-display .vote-count{font-size:16px;color:var(--color-text-secondary)}.no-votes-display{text-align:center;animation:revealIn .5s ease-out}.shrug-icon{font-size:56px;margin-bottom:16px}.no-votes-text{font-size:20px;font-weight:600;color:var(--color-text-secondary);margin-bottom:8px}.no-votes-subtext{font-size:14px;color:var(--color-text-secondary)}.no-votes{color:var(--color-text-secondary);font-style:italic}.results-navigation{display:flex;justify-content:center;gap:16px;margin-top:32px;padding:20px 0;flex-wrap:wrap}.results-navigation button{padding:12px 24px;font-size:16px;border-radius:8px;cursor:pointer;transition:all .2s ease}.nav-next{min-width:120px}.nav-skip{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border)}.nav-skip:hover{border-color:var(--color-text-secondary);color:var(--color-text)}.nav-prev{background:transparent;color:var(--color-text-secondary)}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;padding:20px}.loading-spinner{width:40px;height:40px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:600px){.results-flow{padding:12px}.page-content{padding:20px}.winner-announcement{padding:24px 16px}.crown-icon{font-size:60px}.winner-title{font-size:24px}.winner-name{font-size:32px}.tied-winners .winner-name{font-size:28px}.winner-score{font-size:36px}.leaderboard{padding:16px}.leaderboard-table th,.leaderboard-table td{padding:8px 4px;font-size:14px}.rank-cell{font-size:18px;width:40px}.speed-callouts{flex-direction:column}.speed-callout{justify-content:center}.stats-grid{grid-template-columns:1fr}.results-navigation{flex-direction:column;align-items:stretch}.results-navigation button{width:100%}.nav-prev{order:3}}html{scroll-padding-top:80px}.app{min-height:100vh;display:flex;flex-direction:column;background-color:var(--parchment-cream);margin:0;padding:0}.landing-nav{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background-color:var(--parchment-cream);position:fixed;top:0;left:0;right:0;z-index:var(--z-sticky);height:60px;box-sizing:border-box}.nav-logo{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--elf-forest-green);cursor:pointer}.nav-signin{color:var(--text-dark-soil);text-decoration:none;font-family:var(--font-body);font-weight:500;padding:var(--spacing-sm) var(--spacing-lg);border:2px solid transparent;transition:all var(--transition-base)}.nav-signin:hover{color:var(--burgundy-accent);text-decoration:underline}.hero-section{min-height:70vh;display:flex;align-items:flex-start;justify-content:center;position:relative;margin-top:60px;background:var(--cabin-dark-brown);overflow:hidden}.hero-background{position:absolute;inset:0;z-index:1;background:linear-gradient(135deg,#2a1e17b3,#2f52334d,#2a1e17b3)}.hero-elf-image{position:absolute;top:0;left:0;width:100%;height:100%;opacity:.6;object-fit:cover;object-position:top center}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.hero-content{position:relative;z-index:2;text-align:center;padding:var(--spacing-xxl) var(--spacing-xl);max-width:800px}.hero-title{font-family:var(--font-display);font-weight:700;color:var(--success-warm-gold);text-shadow:2px 2px 4px rgba(0,0,0,.5);margin-top:var(--spacing-lg);margin-bottom:var(--spacing-lg);line-height:1.2}.hero-subtitle{font-family:var(--font-display);font-size:1.5rem;color:var(--parchment-cream);text-shadow:2px 2px 4px rgba(0,0,0,.5);margin-bottom:var(--spacing-xxl);line-height:1.25}.hero-buttons{display:flex;gap:var(--spacing-md);justify-content:center;align-items:center}.btn-get-started{background:var(--elf-forest-green);color:var(--parchment-cream);padding:12px 16px;border-radius:16px;text-decoration:none;font-family:var(--font-body);font-weight:500;font-size:1rem;transition:all var(--transition-base);border:none;cursor:pointer;box-shadow:0 2px 4px #00000026;width:160px;text-align:center}.btn-get-started:hover{background:#254228;transform:translateY(-1px);box-shadow:0 4px 6px #0003}.btn-learn-more{background:transparent;color:var(--parchment-cream);padding:12px 16px;border-radius:16px;border:2px solid var(--parchment-cream);text-decoration:none;font-family:var(--font-body);font-weight:500;font-size:1rem;transition:all var(--transition-base);cursor:pointer;width:160px;text-align:center}.btn-learn-more:hover{background:#f5ebd71a;border-color:var(--parchment-cream)}.steps-section{padding:var(--spacing-xl) var(--spacing-xl);background:var(--parchment-cream)}.steps-title{text-align:center;font-family:var(--font-display);font-size:2rem;color:var(--text-dark-soil);margin-bottom:var(--spacing-lg);font-weight:700}.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-md);max-width:1200px;margin:0 auto}.step-card{background:var(--elf-forest-green);padding:var(--spacing-lg);border-radius:var(--radius-lg);text-align:left;box-shadow:var(--shadow-lg);transition:transform var(--transition-base);position:relative;overflow:hidden}.step-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.step-card-with-image{min-height:175px;display:flex;flex-direction:column;justify-content:flex-end}.step-card-overlay-image{position:absolute;top:0;right:0;width:100%;height:100%;object-fit:contain;object-position:top right;opacity:1;z-index:1}.step-card-content{z-index:2}.step-icon{font-size:2rem;margin-bottom:var(--spacing-md);display:inline-block;background:var(--artisan-wood-brown);width:50px;height:50px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.step-card h3{font-family:var(--font-display);font-size:1.25rem;color:var(--parchment-cream);margin-bottom:var(--spacing-xl);font-weight:700}.step-card p{font-family:var(--font-body);font-size:.95rem;color:var(--parchment-cream);line-height:1.6;opacity:.95}.landing-footer{background:var(--parchment-cream);padding:var(--spacing-xl);text-align:center;border-top:1px solid var(--border-grey);margin-top:auto}.footer-elf{margin-bottom:var(--spacing-lg)}.footer-elf-icon{font-size:2.5rem;opacity:.8}.footer-links{display:flex;gap:var(--spacing-xl);justify-content:center;margin-bottom:var(--spacing-lg);flex-wrap:wrap}.footer-links a{color:var(--text-dark-soil);text-decoration:none;font-family:var(--font-body);font-weight:500;transition:color var(--transition-fast)}.footer-links a:hover{color:var(--burgundy-accent);text-decoration:underline}.footer-social{display:flex;gap:var(--spacing-md);justify-content:center;margin-bottom:var(--spacing-lg)}.social-icon{font-size:1.5rem;cursor:pointer;opacity:.7;transition:opacity var(--transition-fast)}.social-icon:hover{opacity:1}.footer-copyright{font-family:var(--font-body);font-size:.9rem;color:var(--text-medium-gray)}.app-header,.app-main,.app-footer{display:none}@media(max-width:768px){.landing-nav{padding:var(--spacing-sm) var(--spacing-md)}.nav-logo{font-size:1.25rem}.hero-section{min-height:60vh}.hero-elf-image{opacity:.4}.hero-title{font-size:2.25rem}.hero-subtitle{font-size:1.1rem}.hero-buttons{flex-direction:row;gap:var(--spacing-sm)}.btn-get-started,.btn-learn-more{width:140px;text-align:center;padding:10px 12px;font-size:.9rem}.steps-title{font-size:1.5rem}.steps-grid{grid-template-columns:1fr}.footer-links{flex-direction:column;gap:var(--spacing-md)}}
