.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;position:relative;overflow:hidden}.login-background{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#667eea,#764ba2);z-index:0}.bg-shape{position:absolute;border-radius:50%;opacity:.1;background:#fff}.bg-shape-1{width:600px;height:600px;top:-200px;right:-100px}.bg-shape-2{width:400px;height:400px;bottom:-150px;left:-100px}.bg-shape-3{width:200px;height:200px;top:50%;left:20%}.login-container{position:relative;z-index:1;width:100%;max-width:440px}.login-card{background:#fff;border-radius:var(--radius-xl);padding:40px;box-shadow:var(--shadow-xl)}.login-header{text-align:center;margin-bottom:32px}.login-logo{font-size:64px;margin-bottom:16px;animation:pulse 2s infinite}.login-header h1{font-size:28px;color:var(--text-primary);margin-bottom:8px}.login-header p{color:var(--text-secondary);font-size:15px}.login-form{margin-bottom:24px}.input-wrapper{position:relative}.input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.input-wrapper .input{padding-left:46px;padding-right:46px}.password-toggle{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center}.password-toggle:hover{color:var(--text-secondary)}.divider{display:flex;align-items:center;margin:24px 0}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--border)}.divider span{padding:0 16px;color:var(--text-muted);font-size:14px;text-transform:uppercase;letter-spacing:1px}.google-btn{gap:12px}.google-btn:hover{background:var(--bg-tertiary)}.login-footer{text-align:center;margin-top:24px;color:var(--text-secondary);font-size:15px}.login-footer button{background:none;border:none;color:var(--primary);font-weight:700;cursor:pointer;font-size:inherit;font-family:inherit}.login-footer button:hover{text-decoration:underline}.invite-link{text-align:center;margin-top:24px;color:#fffc;font-size:15px}.invite-link a{color:#fff;font-weight:700}.invite-link a:hover{text-decoration:underline}@media (max-width: 480px){.login-card{padding:30px 24px}.login-header h1{font-size:24px}.login-logo{font-size:48px}}.setup-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;position:relative;overflow:hidden}.setup-background{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#667eea,#764ba2);z-index:0}.setup-container{position:relative;z-index:1;width:100%;max-width:480px}.setup-card{background:#fff;border-radius:var(--radius-xl);padding:40px;box-shadow:var(--shadow-xl);position:relative}.back-btn{position:absolute;top:20px;left:20px;display:flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-secondary);font-size:14px;font-weight:600;cursor:pointer;font-family:inherit}.back-btn:hover{color:var(--text-primary)}.setup-header{text-align:center;margin-bottom:32px}.setup-icon{font-size:64px;margin-bottom:16px}.success-icon{animation:pulse 1s ease-out}.setup-header h1{font-size:24px;color:var(--text-primary);margin-bottom:8px}.setup-header p{color:var(--text-secondary);font-size:15px}.mode-options{display:flex;flex-direction:column;gap:16px}.mode-card{display:flex;flex-direction:column;align-items:flex-start;gap:8px;padding:24px;background:var(--bg-tertiary);border:2px solid transparent;border-radius:var(--radius-lg);cursor:pointer;transition:all .2s;text-align:left;font-family:inherit;position:relative}.mode-card:hover{background:var(--bg-secondary);border-color:var(--primary);transform:translateY(-2px);box-shadow:var(--shadow)}.mode-icon{width:56px;height:56px;background:linear-gradient(135deg,var(--primary),var(--secondary));border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:#fff}.mode-card h3{font-size:18px;color:var(--text-primary);margin:0}.mode-card p{font-size:14px;color:var(--text-secondary);margin:0}.mode-arrow{position:absolute;right:20px;top:50%;transform:translateY(-50%);color:var(--text-muted);transition:all .2s}.mode-card:hover .mode-arrow{color:var(--primary);transform:translateY(-50%) translate(4px)}.invite-code-display{margin-bottom:24px}.code-box{display:flex;align-items:center;justify-content:space-between;background:var(--bg-tertiary);border:2px dashed var(--border);border-radius:var(--radius);padding:16px 20px;margin-top:8px}.code-box span{font-size:20px;font-weight:700;font-family:monospace;letter-spacing:2px;color:var(--primary)}.copy-btn{background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);padding:8px 16px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .2s}.copy-btn:hover{background:var(--primary-dark)}.invite-code-input{font-family:monospace;font-size:18px;letter-spacing:2px;text-align:center;text-transform:uppercase}.progress-dots{display:flex;justify-content:center;gap:8px;margin-top:32px}.dot{width:10px;height:10px;border-radius:50%;background:var(--border);transition:all .2s}.dot.active{background:var(--primary);transform:scale(1.2)}.error-message{background:#ef44441a;color:var(--danger);padding:12px 16px;border-radius:var(--radius);margin-bottom:20px;font-size:14px;font-weight:600}@media (max-width: 480px){.setup-card{padding:30px 24px}.setup-header h1{font-size:22px}.setup-icon{font-size:48px}.code-box{flex-direction:column;gap:12px;text-align:center}.code-box span{font-size:18px}}.on-this-day{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:var(--radius-xl);padding:24px;box-shadow:var(--shadow)}.on-this-day.loading{display:flex;align-items:center;justify-content:center;min-height:150px}.otd-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px}.otd-title{display:flex;align-items:center;gap:12px}.otd-title svg{color:#92400e}.otd-title h2{font-size:18px;color:#78350f;margin-bottom:2px}.otd-title p{font-size:14px;color:#92400e;font-weight:600}.year-selector{display:flex;align-items:center;gap:8px}.year-nav{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#78350f1a;border:none;border-radius:50%;color:#92400e;cursor:pointer;transition:all .2s}.year-nav:hover:not(:disabled){background:#78350f33}.year-nav:disabled{opacity:.3;cursor:not-allowed}.current-year{font-weight:700;font-size:14px;color:#78350f;min-width:50px;text-align:center}.otd-subtitle{margin-bottom:16px}.years-ago{display:inline-block;background:#78350f26;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:700;color:#78350f;text-transform:uppercase;letter-spacing:.5px}.memories-list{display:flex;flex-direction:column;gap:12px}.memory-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:0 2px 8px #78350f1a}.memory-photo{width:100%;height:120px;overflow:hidden}.memory-photo img{width:100%;height:100%;object-fit:cover}.memory-content{padding:14px}.memory-type{display:flex;align-items:center;gap:6px;margin-bottom:6px}.memory-type svg{color:#d97706}.memory-type span{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#d97706}.memory-content h4{font-size:15px;color:#1f2937;margin-bottom:6px;line-height:1.3}.memory-content p{font-size:13px;color:#6b7280;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.memory-meta{font-size:12px;color:#9ca3af;margin-top:6px}.memory-footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding-top:10px;border-top:1px solid #f3f4f6}.memory-author{font-size:12px;font-weight:600;color:#6b7280}.memory-card{animation:memorySlide .4s ease backwards}.memory-card:nth-child(1){animation-delay:0s}.memory-card:nth-child(2){animation-delay:.1s}.memory-card:nth-child(3){animation-delay:.2s}@keyframes memorySlide{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 480px){.on-this-day{padding:16px}.otd-header{flex-direction:column;gap:12px}}.dashboard-page{padding:30px;max-width:1400px;margin:0 auto}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;gap:16px;color:var(--text-muted)}.dashboard-header{margin-bottom:30px}.welcome-section h1{font-size:28px;margin-bottom:4px;display:flex;align-items:center;gap:8px}.wave{display:inline-block;animation:wave 1.5s ease-in-out infinite;transform-origin:70% 70%}@keyframes wave{0%,to{transform:rotate(0)}25%{transform:rotate(20deg)}75%{transform:rotate(-10deg)}}.stats-row{display:flex;gap:16px;margin-top:24px}.stat-card{display:flex;align-items:center;gap:12px;background:var(--bg-secondary);padding:16px 20px;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.stat-icon{width:44px;height:44px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center}.stat-value{font-size:24px;font-weight:800;color:var(--text-primary);line-height:1}.stat-label{font-size:13px;color:var(--text-muted);font-weight:600}.dashboard-section{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm);margin-bottom:24px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.section-header h2{display:flex;align-items:center;gap:10px;font-size:20px;color:var(--text-primary)}.section-header h2 svg{color:var(--primary)}.section-header .text-muted{margin-left:auto;margin-right:16px}.view-all{font-size:14px;font-weight:600;color:var(--primary)}.view-all:hover{text-decoration:underline}.story-types-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.story-type-card{display:flex;align-items:center;gap:14px;padding:16px;background:var(--bg-tertiary);border-radius:var(--radius);transition:all .2s;border:2px solid transparent}.story-type-card:hover{background:var(--bg-secondary);border-color:var(--type-color);transform:translateY(-2px);box-shadow:var(--shadow)}.type-icon{width:48px;height:48px;border-radius:var(--radius);background:var(--type-color);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.type-info{flex:1;display:flex;flex-direction:column}.type-label{font-weight:700;color:var(--text-primary);font-size:15px}.type-desc{font-size:13px;color:var(--text-muted)}.type-arrow{color:var(--text-muted);transition:all .2s}.story-type-card:hover .type-arrow{color:var(--type-color);transform:translate(4px)}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}.edition-card{background:var(--bg-tertiary);border-radius:var(--radius);padding:20px}.edition-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.edition-header h3{font-size:18px;color:var(--text-primary)}.edition-date{color:var(--text-secondary);font-size:14px;margin-bottom:12px}.edition-stats{font-size:13px;color:var(--text-muted);margin-bottom:16px}.edition-actions{display:flex;gap:10px}.edition-actions .btn{flex:1}.empty-edition,.empty-stories{text-align:center;padding:40px 20px}.empty-icon{font-size:48px;margin-bottom:12px}.empty-edition h3{margin-bottom:8px;color:var(--text-primary)}.empty-edition p{color:var(--text-muted);margin-bottom:20px}.stories-list{display:flex;flex-direction:column;gap:12px}.story-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-tertiary);border-radius:var(--radius)}.story-type-badge{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.story-info{flex:1;min-width:0}.story-headline{display:block;font-weight:600;color:var(--text-primary);font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.story-meta{font-size:12px;color:var(--text-muted)}@media (max-width: 900px){.dashboard-page{padding:20px}.stats-row{flex-wrap:wrap}.stat-card{flex:1;min-width:140px}.dashboard-grid,.story-types-grid{grid-template-columns:1fr}}@media (max-width: 480px){.welcome-section h1{font-size:22px}.stat-card{padding:12px 14px}.stat-value{font-size:20px}}.submit-page{padding:30px;max-width:900px;margin:0 auto}.submit-header{margin-bottom:30px}.back-btn{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-secondary);font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;padding:8px 12px;margin:-8px -12px 16px;border-radius:var(--radius);transition:all .2s}.back-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.submit-header h1{font-size:28px;margin-bottom:8px}.type-selection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}.type-select-card{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px 16px;background:var(--bg-secondary);border:3px solid transparent;border-radius:var(--radius-lg);cursor:pointer;transition:all .2s;font-family:inherit}.type-select-card:hover{border-color:var(--type-color);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.type-icon-large{width:64px;height:64px;border-radius:var(--radius);background:var(--type-color);color:#fff;display:flex;align-items:center;justify-content:center}.type-name{font-weight:700;color:var(--text-primary);font-size:14px;text-align:center}.current-type{display:inline-flex;align-items:center;gap:10px;padding:8px 16px 8px 8px;background:var(--bg-secondary);border-radius:50px;box-shadow:var(--shadow-sm)}.type-badge{width:36px;height:36px;border-radius:50%;background:var(--type-color);color:#fff;display:flex;align-items:center;justify-content:center}.current-type span{font-weight:700;color:var(--text-primary)}.story-editor{background:var(--bg-secondary);border-radius:var(--radius-xl);box-shadow:var(--shadow);overflow:hidden}.editor-main{padding:30px}.headline-input{width:100%;font-size:28px;font-weight:700;border:none;background:transparent;color:var(--text-primary);padding:0;margin-bottom:8px;font-family:var(--font-display)}.headline-input:focus{outline:none}.headline-input::placeholder{color:var(--text-muted)}.char-count{font-size:12px;color:var(--text-muted);text-align:right;display:block;margin-bottom:20px}.content-input{width:100%;min-height:200px;font-size:16px;line-height:1.7;border:2px solid var(--border);border-radius:var(--radius);padding:16px;resize:vertical;font-family:inherit;color:var(--text-primary);background:var(--bg-primary)}.content-input:focus{outline:none;border-color:var(--primary)}.content-input::placeholder{color:var(--text-muted)}.photo-section{margin-top:24px;padding-top:24px;border-top:1px solid var(--border)}.photo-section h3{display:flex;align-items:center;gap:8px;font-size:16px;margin-bottom:16px;color:var(--text-primary)}.photo-section h3 .text-muted{font-weight:400;font-size:14px}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.photo-preview{position:relative;aspect-ratio:1;border-radius:var(--radius);overflow:hidden}.photo-preview img{width:100%;height:100%;object-fit:cover}.remove-photo{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;background:#0009;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.remove-photo:hover{background:var(--danger)}.photo-upload-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;aspect-ratio:1;background:var(--bg-tertiary);border:2px dashed var(--border);border-radius:var(--radius);cursor:pointer;transition:all .2s;color:var(--text-muted)}.photo-upload-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--bg-primary)}.photo-upload-btn span{font-size:13px;font-weight:600}.extra-fields{margin-top:24px;padding-top:24px;border-top:1px solid var(--border)}.extra-fields h3{display:flex;align-items:center;gap:8px;font-size:16px;margin-bottom:16px;color:var(--text-primary)}.fields-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.star-rating{display:flex;gap:4px}.star-btn{background:none;border:none;font-size:24px;cursor:pointer;opacity:.3;transition:all .2s}.star-btn:hover,.star-btn.active{opacity:1;transform:scale(1.2)}.editor-actions{display:flex;gap:12px;padding:20px 30px;background:var(--bg-tertiary);border-top:1px solid var(--border)}.editor-actions .btn{flex:1}@media (max-width: 768px){.submit-page{padding:20px}.type-selection-grid{grid-template-columns:repeat(2,1fr)}.headline-input{font-size:22px}.editor-main{padding:20px}.fields-grid{grid-template-columns:1fr}.editor-actions{flex-direction:column}}.flip-card{perspective:1000px;cursor:pointer;position:relative}.flip-card-inner{position:relative;width:100%;height:100%;transition:transform .6s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}.flip-card.flipped .flip-card-inner{transform:rotateY(180deg)}.flip-card-front,.flip-card-back{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:16px;overflow:hidden}.flip-card-back{transform:rotateY(180deg)}.flip-hint{position:absolute;bottom:-24px;left:0;right:0;text-align:center;font-size:11px;color:var(--text-muted);opacity:0;transition:opacity .2s}.flip-card:hover .flip-hint{opacity:1}.fish-card{width:260px;height:380px;perspective:1000px;cursor:pointer}.fish-card-inner{position:relative;width:100%;height:100%;transition:transform .6s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}.fish-card.flipped .fish-card-inner{transform:rotateY(180deg)}.fish-card-front,.fish-card-back{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:16px;overflow:hidden;box-shadow:0 4px 6px #0000001a,0 10px 20px #00000026,inset 0 1px #ffffff1a}.fish-card-front{background:linear-gradient(145deg,#0ea5e9,#0284c7,#0369a1);display:flex;flex-direction:column;border:3px solid #0369a1}.fish-card-front .card-header{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;background:#0003}.fish-card-front .card-type{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;color:#fff}.fish-card-front .card-date{font-size:12px;font-weight:600;color:#fffc}.fish-card-front .card-image-area{flex:1;position:relative;margin:10px;border-radius:10px;overflow:hidden;background:#0003}.fish-card-front .card-image-area img{width:100%;height:100%;object-fit:cover}.fish-card-front .no-photo{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:64px;background:linear-gradient(180deg,#ffffff1a,#0000001a)}.fish-card-front .card-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000c);padding:20px 12px 12px}.fish-card-front .species-name{font-size:18px;font-weight:800;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.3)}.fish-card-front .card-stats{padding:12px 14px;background:#00000026}.fish-card-front .stat-row{display:flex;justify-content:space-around;margin-bottom:10px}.fish-card-front .stat{display:flex;align-items:center;gap:6px}.fish-card-front .stat-icon{font-size:16px}.fish-card-front .stat-value{font-size:16px;font-weight:700;color:#fff}.fish-card-front .rating-row{display:flex;justify-content:center;align-items:center;gap:8px}.fish-card-front .stars{display:flex;gap:2px}.fish-card-front .star{font-size:16px;color:#ffffff4d}.fish-card-front .star.filled{color:#fbbf24;text-shadow:0 0 8px rgba(251,191,36,.5)}.fish-card-front .rating-label{font-size:12px;font-weight:700;color:#fbbf24;text-transform:uppercase;letter-spacing:.5px}.fish-card-front .card-footer{padding:10px 14px;background:#00000040}.fish-card-front .angler{display:flex;align-items:center;gap:6px}.fish-card-front .angler-label{font-size:11px;color:#fff9}.fish-card-front .angler-name{font-size:14px;font-weight:700;color:#fff}.fish-card-front .tap-hint,.fish-card-back .tap-hint{position:absolute;bottom:8px;left:0;right:0;text-align:center;font-size:10px;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px}.fish-card-back{transform:rotateY(180deg);background:linear-gradient(145deg,#f8fafc,#e2e8f0);display:flex;flex-direction:column;border:3px solid #0369a1}.fish-card-back .back-header{padding:14px;background:linear-gradient(145deg,#0ea5e9,#0284c7);color:#fff;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:1px;text-align:center}.fish-card-back .back-content{flex:1;padding:16px;overflow-y:auto}.fish-card-back .detail-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid #e2e8f0}.fish-card-back .detail-row:last-child{border-bottom:none}.fish-card-back .detail-label{font-size:12px;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.fish-card-back .detail-value{font-size:14px;color:#1e293b;font-weight:600;text-align:right}.fish-card-back .detail-notes{margin-top:12px;padding-top:12px;border-top:2px dashed #e2e8f0}.fish-card-back .detail-notes p{margin-top:6px;font-size:13px;color:#475569;line-height:1.5;font-style:italic}.fish-card-back .back-footer{padding:12px;background:#f1f5f9;text-align:center}.fish-card-back .caught-by{font-size:12px;color:#64748b}.fish-card-back .caught-by strong{color:#0284c7}.recipe-card{width:260px;height:380px;perspective:1000px;cursor:pointer}.recipe-card-inner{position:relative;width:100%;height:100%;transition:transform .6s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}.recipe-card.flipped .recipe-card-inner{transform:rotateY(180deg)}.recipe-card-front,.recipe-card-back{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:16px;overflow:hidden;box-shadow:0 4px 6px #0000001a,0 10px 20px #00000026}.recipe-card-front{background:linear-gradient(145deg,#10b981,#059669);display:flex;flex-direction:column;border:3px solid #047857}.recipe-card-front .card-header{padding:12px 14px;background:#0003}.recipe-card-front .card-type{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;color:#fff}.recipe-card-front .card-image-area{flex:1;position:relative;margin:10px;border-radius:10px;overflow:hidden;background:#0003}.recipe-card-front .card-image-area img{width:100%;height:100%;object-fit:cover}.recipe-card-front .recipe-placeholder{display:flex;align-items:center;justify-content:center;font-size:64px;height:100%}.recipe-card-front .card-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000c);padding:20px 12px 12px}.recipe-card-front .recipe-name{font-size:16px;font-weight:800;color:#fff}.recipe-card-front .card-stats{padding:14px;background:#00000026}.recipe-card-front .stat-row{display:flex;justify-content:space-around}.recipe-card-front .stat{display:flex;flex-direction:column;align-items:center;gap:2px}.recipe-card-front .stat-icon{font-size:18px}.recipe-card-front .stat-value{font-size:14px;font-weight:700;color:#fff}.recipe-card-front .stat-label{font-size:10px;color:#ffffffb3;text-transform:uppercase}.recipe-card-front .card-footer{padding:10px 14px;background:#00000040}.recipe-card-front .author{font-size:13px;color:#fff;text-align:center}.recipe-card-back{transform:rotateY(180deg);background:#fffbeb;border:3px solid #047857;display:flex;flex-direction:column}.recipe-card-back .back-header{padding:12px;background:linear-gradient(145deg,#10b981,#059669);color:#fff;font-size:12px;font-weight:700;text-align:center}.recipe-card-back .back-content{flex:1;padding:14px;overflow-y:auto}.recipe-card-back .back-content.scrollable{overflow-y:auto}.recipe-card-back .recipe-section{margin-bottom:14px}.recipe-card-back .recipe-section h4{font-size:12px;color:#047857;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.recipe-card-back .recipe-section p{font-size:13px;color:#374151;line-height:1.5;white-space:pre-wrap}.achievement-card{width:260px;height:380px;perspective:1000px;cursor:pointer}.achievement-card-inner{position:relative;width:100%;height:100%;transition:transform .6s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}.achievement-card.flipped .achievement-card-inner{transform:rotateY(180deg)}.achievement-card-front,.achievement-card-back{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:16px;overflow:hidden;box-shadow:0 4px 6px #0000001a,0 10px 20px #00000026}.achievement-card-front{background:linear-gradient(145deg,#fbbf24,#f59e0b,#d97706);display:flex;flex-direction:column;align-items:center;justify-content:center;border:3px solid #b45309;position:relative}.achievement-card-front .trophy-glow{position:absolute;width:150px;height:150px;background:radial-gradient(circle,rgba(255,255,255,.4) 0%,transparent 70%);border-radius:50%;animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(1.2);opacity:.8}}.achievement-card-front .card-header{position:absolute;top:0;left:0;right:0;padding:12px;background:#0003;text-align:center}.achievement-card-front .card-type{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;color:#fff}.achievement-card-front .achievement-icon{font-size:80px;margin-bottom:20px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3));animation:trophy-bounce 2s ease-in-out infinite}@keyframes trophy-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.achievement-card-front .achievement-title{font-size:18px;font-weight:800;color:#fff;text-align:center;padding:0 20px;text-shadow:0 2px 4px rgba(0,0,0,.2)}.achievement-card-front .card-footer{position:absolute;bottom:0;left:0;right:0;padding:12px;background:#00000040;text-align:center}.achievement-card-front .achiever{font-size:14px;font-weight:600;color:#fff}.achievement-card-back{transform:rotateY(180deg);background:linear-gradient(145deg,#fffbeb,#fef3c7);border:3px solid #b45309;display:flex;flex-direction:column}.achievement-card-back .back-header{padding:14px;background:linear-gradient(145deg,#fbbf24,#f59e0b);color:#fff;font-size:13px;font-weight:700;text-align:center}.achievement-card-back .back-content{flex:1;padding:16px;overflow-y:auto}.achievement-card-back .back-content h3{font-size:16px;color:#92400e;margin-bottom:10px}.achievement-card-back .back-content p{font-size:14px;color:#78350f;line-height:1.6}.achievement-card-back .achievement-photo{margin-top:12px;border-radius:8px;overflow:hidden}.achievement-card-back .achievement-photo img{width:100%;height:auto}.achievement-card-back .back-footer{padding:12px;background:#fef3c7;text-align:center;font-size:13px;color:#92400e}.joke-card{width:260px;height:340px;perspective:1000px;cursor:pointer}.joke-card-inner{position:relative;width:100%;height:100%;transition:transform .6s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}.joke-card.flipped .joke-card-inner{transform:rotateY(180deg)}.joke-card-front,.joke-card-back{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:16px;overflow:hidden;box-shadow:0 4px 6px #0000001a,0 10px 20px #00000026}.joke-card-front{background:linear-gradient(145deg,#ec4899,#db2777);display:flex;flex-direction:column;border:3px solid #be185d}.joke-card-front .card-header{padding:12px 14px;background:#0003}.joke-card-front .card-type{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;color:#fff}.joke-card-front .joke-setup{flex:1;display:flex;align-items:center;justify-content:center;padding:24px}.joke-card-front .joke-setup p{font-size:20px;font-weight:700;color:#fff;text-align:center;line-height:1.4}.joke-card-front .card-footer{padding:12px;background:#00000040;text-align:center;font-size:13px;color:#fffc}.joke-card-back{transform:rotateY(180deg);background:linear-gradient(145deg,#fdf4ff,#fae8ff);border:3px solid #be185d;display:flex;flex-direction:column}.joke-card-back .back-header{padding:12px;background:linear-gradient(145deg,#ec4899,#db2777);color:#fff;font-size:13px;font-weight:700;text-align:center}.joke-card-back .joke-punchline{flex:1;display:flex;align-items:center;justify-content:center;padding:24px}.joke-card-back .joke-punchline p{font-size:22px;font-weight:800;color:#be185d;text-align:center;line-height:1.4}.joke-card-back .laugh-reaction{text-align:center;font-size:32px;padding-bottom:20px;animation:laugh-shake .5s ease-in-out infinite}@keyframes laugh-shake{0%,to{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}.pet-card{width:260px;height:380px;perspective:1000px;cursor:pointer}.pet-card-inner{position:relative;width:100%;height:100%;transition:transform .6s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}.pet-card.flipped .pet-card-inner{transform:rotateY(180deg)}.pet-card-front,.pet-card-back{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:16px;overflow:hidden;box-shadow:0 4px 6px #0000001a,0 10px 20px #00000026}.pet-card-front{background:linear-gradient(145deg,#f59e0b,#d97706);display:flex;flex-direction:column;border:3px solid #b45309}.pet-card-front .card-header{padding:12px 14px;background:#0003}.pet-card-front .card-type{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;color:#fff}.pet-card-front .card-image-area{flex:1;position:relative;margin:10px;border-radius:10px;overflow:hidden}.pet-card-front .card-image-area img{width:100%;height:100%;object-fit:cover}.pet-card-front .pet-placeholder{display:flex;align-items:center;justify-content:center;font-size:64px;height:100%;background:#0000001a}.pet-card-front .card-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000c);padding:20px 12px 12px}.pet-card-front .pet-headline{font-size:16px;font-weight:800;color:#fff}.pet-card-front .card-footer{padding:12px;background:#00000040;text-align:center;font-size:13px;color:#fff}.pet-card-back{transform:rotateY(180deg);background:linear-gradient(145deg,#fffbeb,#fef3c7);border:3px solid #b45309;display:flex;flex-direction:column}.pet-card-back .back-header{padding:12px;background:linear-gradient(145deg,#f59e0b,#d97706);color:#fff;font-size:12px;font-weight:700;text-align:center}.pet-card-back .back-content{flex:1;padding:16px;overflow-y:auto}.pet-card-back .back-content p{font-size:14px;color:#78350f;line-height:1.6}.tap-hint{position:absolute;bottom:8px;left:0;right:0;text-align:center;font-size:10px;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px}.cards-grid{display:flex;flex-wrap:wrap;gap:24px;justify-content:center;padding:20px}@media (max-width: 600px){.fish-card,.recipe-card,.achievement-card,.joke-card,.pet-card{width:100%;max-width:300px}}.fishing-page{padding:30px;max-width:1400px;margin:0 auto}.fishing-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:30px}.fishing-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:30px}.fishing-stats .stat-card{display:flex;align-items:center;gap:16px;background:var(--bg-secondary);padding:20px;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.fishing-stats .stat-icon{color:var(--primary)}.fishing-stats .stat-value{font-size:28px;font-weight:800;color:var(--text-primary);display:block}.fishing-stats .stat-label{font-size:14px;color:var(--text-muted)}.fishing-content{display:grid;grid-template-columns:280px 1fr;gap:30px}.leaderboard-section{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm);height:fit-content;position:sticky;top:90px}.leaderboard-section h2{display:flex;align-items:center;gap:10px;font-size:18px;margin-bottom:20px}.leaderboard-section h2 svg{color:var(--accent)}.leaderboard{display:flex;flex-direction:column;gap:10px}.leader-row{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-tertiary);border-radius:var(--radius);transition:all .2s}.leader-row.top-three{background:linear-gradient(135deg,#fbbf241a,#f59e0b1a)}.leader-row:hover{transform:translate(4px)}.rank{font-size:20px;width:32px;text-align:center;flex-shrink:0}.leader-info{flex:1;min-width:0}.leader-name{display:block;font-weight:700;color:var(--text-primary);font-size:14px}.leader-stats{font-size:12px;color:var(--text-secondary)}.leader-stats .biggest{color:var(--text-muted);margin-left:4px}.catches-section{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm)}.catches-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.catches-header h2{display:flex;align-items:center;gap:10px;font-size:18px;margin:0}.catches-header h2 svg{color:var(--primary)}.view-toggle{display:flex;background:var(--bg-tertiary);border-radius:var(--radius);padding:4px}.toggle-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all .2s}.toggle-btn:hover{color:var(--text-primary)}.toggle-btn.active{background:var(--bg-secondary);color:var(--primary);box-shadow:var(--shadow-sm)}.catches-cards{display:flex;flex-wrap:wrap;gap:24px;justify-content:flex-start}.catches-list{display:flex;flex-direction:column;gap:12px}.catch-list-item{display:flex;align-items:center;gap:16px;padding:16px;background:var(--bg-tertiary);border-radius:var(--radius);transition:all .2s}.catch-list-item:hover{background:var(--bg-primary);box-shadow:var(--shadow)}.catch-thumb{width:60px;height:60px;border-radius:var(--radius);overflow:hidden;background:linear-gradient(135deg,#0ea5e9,#0284c7);display:flex;align-items:center;justify-content:center;flex-shrink:0}.catch-thumb img{width:100%;height:100%;object-fit:cover}.catch-thumb span{font-size:28px}.catch-list-item .catch-info{flex:1;min-width:0}.catch-list-item .catch-info h4{font-size:16px;margin-bottom:4px;color:var(--text-primary)}.catch-list-item .catch-details{display:flex;flex-wrap:wrap;gap:12px}.catch-list-item .catch-details span{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--text-secondary)}.catch-angler{font-size:14px;font-weight:600;color:var(--primary);white-space:nowrap}.modal{background:var(--bg-secondary);border-radius:var(--radius-xl);width:100%;max-width:520px;max-height:90vh;overflow:auto;animation:modalSlideIn .3s ease}.catch-modal{max-width:560px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-secondary);z-index:10}.modal-header h2{display:flex;align-items:center;gap:10px;font-size:20px;margin:0}.modal-header h2 svg{color:var(--primary)}.modal-header .close-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-sm);transition:all .2s}.modal-header .close-btn:hover{color:var(--text-primary);background:var(--bg-tertiary)}.photo-upload-section{margin-bottom:24px}.photo-upload-area{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;height:180px;background:linear-gradient(135deg,#0ea5e91a,#06b6d41a);border:3px dashed #0ea5e9;border-radius:var(--radius-lg);cursor:pointer;color:#0ea5e9;transition:all .2s}.photo-upload-area:hover{background:linear-gradient(135deg,#0ea5e926,#06b6d426);border-color:#0284c7}.photo-upload-area span{font-weight:700;font-size:16px}.photo-upload-area small{font-size:13px;color:var(--text-muted)}.photo-preview-large{position:relative;height:200px;border-radius:var(--radius-lg);overflow:hidden}.photo-preview-large img{width:100%;height:100%;object-fit:cover}.photo-preview-large .remove-photo{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;background:#0009;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.photo-preview-large .remove-photo:hover{background:var(--danger);transform:scale(1.1)}.quick-species{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.species-chip{padding:6px 12px;font-size:12px;font-weight:600;background:var(--bg-tertiary);border:2px solid transparent;border-radius:20px;cursor:pointer;font-family:inherit;color:var(--text-secondary);transition:all .2s}.species-chip:hover{border-color:var(--primary);color:var(--primary)}.species-chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.modal-actions{display:flex;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border)}.modal-actions .btn{flex:1}@media (max-width: 1100px){.fishing-content{grid-template-columns:1fr}.leaderboard-section{position:static}.catches-cards{justify-content:center}}@media (max-width: 768px){.fishing-header{flex-direction:column;gap:16px}.fishing-stats{grid-template-columns:1fr}}@media (max-width: 480px){.fishing-page{padding:20px}.form-grid{grid-template-columns:1fr}.catches-cards{justify-content:center}}.feed-page{padding:30px;max-width:1400px;margin:0 auto}.feed-header{margin-bottom:24px}.filter-bar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:30px;padding:16px;background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.filter-btn{display:flex;align-items:center;gap:8px;padding:10px 18px;background:var(--bg-tertiary);border:2px solid transparent;border-radius:50px;font-size:14px;font-weight:600;color:var(--text-secondary);cursor:pointer;font-family:inherit;transition:all .2s}.filter-btn:hover{border-color:var(--primary);color:var(--primary)}.filter-btn.active{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;border-color:transparent}.cards-feed{display:flex;flex-wrap:wrap;gap:28px;justify-content:center}.empty-state{text-align:center;padding:80px 20px;background:var(--bg-secondary);border-radius:var(--radius-xl)}@media (max-width: 768px){.filter-bar{justify-content:center}.filter-btn span{display:none}.filter-btn{padding:12px}}@media (max-width: 480px){.feed-page{padding:20px}}.editions-page{padding:30px;max-width:1200px;margin:0 auto}.editions-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:30px}.editions-section{margin-bottom:40px}.editions-section h2{display:flex;align-items:center;gap:10px;font-size:18px;margin-bottom:20px;color:var(--text-primary)}.editions-section h2 svg{color:var(--text-muted)}.editions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.edition-card{background:var(--bg-secondary);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:all .2s}.edition-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.edition-card.draft{border:2px dashed var(--accent)}.edition-preview{aspect-ratio:8.5/11;max-height:200px;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center}.preview-placeholder{font-size:48px;opacity:.3}.edition-info{padding:16px}.edition-meta{display:flex;align-items:center;gap:12px;margin-bottom:8px}.edition-date{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--text-muted)}.edition-info h3{font-size:18px;margin-bottom:4px;color:var(--text-primary)}.edition-stats{font-size:14px;color:var(--text-secondary);margin-bottom:12px}.edition-actions{display:flex;gap:8px}.btn-sm{padding:8px 14px;font-size:13px}.empty-state p{color:var(--text-muted);margin-bottom:20px}@media (max-width: 768px){.editions-header{flex-direction:column;gap:16px}.editions-grid{grid-template-columns:1fr}}.builder-page{height:100vh;display:flex;flex-direction:column;background:var(--bg-primary)}.loading-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-muted)}.builder-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0}.header-left{display:flex;align-items:center;gap:16px}.builder-header .back-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius);color:var(--text-secondary);transition:all .2s}.builder-header .back-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.header-info h1{font-size:20px;margin-bottom:2px}.edition-status{font-size:12px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.5px}.header-actions{display:flex;gap:10px}.builder-content{flex:1;display:flex;overflow:hidden}.builder-sidebar{width:320px;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.sidebar-tabs{display:flex;border-bottom:1px solid var(--border)}.tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:14px 12px;background:none;border:none;font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;font-family:inherit;border-bottom:2px solid transparent;transition:all .2s}.tab-btn:hover{color:var(--text-primary);background:var(--bg-tertiary)}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.sidebar-content{flex:1;overflow-y:auto;padding:20px}.stories-panel h3{font-size:14px;margin-bottom:4px}.panel-hint{font-size:12px;color:var(--text-muted);margin-bottom:16px}.available-stories{display:flex;flex-direction:column;gap:8px}.story-chip{display:flex;align-items:center;gap:10px;padding:12px;background:var(--bg-tertiary);border-radius:var(--radius);cursor:pointer;transition:all .2s}.story-chip:hover{background:var(--bg-primary);box-shadow:var(--shadow)}.story-chip svg:first-child{color:var(--primary);flex-shrink:0}.story-chip-title{flex:1;font-weight:600;font-size:13px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.story-chip-author{font-size:11px;color:var(--text-muted);white-space:nowrap}.story-chip .add-icon{color:var(--success);opacity:0;transition:opacity .2s}.story-chip:hover .add-icon{opacity:1}.no-stories{text-align:center;padding:40px 20px;color:var(--text-muted);font-size:14px}.design-panel{display:flex;flex-direction:column;gap:24px}.panel-section h3{display:flex;align-items:center;gap:8px;font-size:14px;margin-bottom:12px}.panel-section h3 svg{color:var(--text-muted)}.layout-options{display:grid;grid-template-columns:1fr 1fr;gap:10px}.layout-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:14px 10px;background:var(--bg-tertiary);border:2px solid transparent;border-radius:var(--radius);cursor:pointer;font-family:inherit;transition:all .2s}.layout-option:hover{border-color:var(--border)}.layout-option.active{border-color:var(--primary);background:#6366f11a}.layout-preview{display:flex;gap:4px;width:48px;height:32px}.layout-col{flex:1;background:var(--text-muted);border-radius:2px;opacity:.3}.layout-option.active .layout-col{background:var(--primary);opacity:.6}.layout-option span{font-size:11px;font-weight:600;color:var(--text-secondary)}.theme-options{display:grid;grid-template-columns:1fr 1fr;gap:10px}.theme-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;background:var(--bg-tertiary);border:2px solid transparent;border-radius:var(--radius);cursor:pointer;font-family:inherit;transition:all .2s}.theme-option:hover{border-color:var(--border)}.theme-option.active{border-color:var(--primary)}.theme-preview{display:flex;gap:6px}.theme-swatch{width:20px;height:20px;border-radius:50%;box-shadow:inset 0 0 0 1px #0000001a}.theme-option span{font-size:11px;font-weight:600;color:var(--text-secondary)}.font-options{display:flex;flex-direction:column;gap:8px}.font-option{padding:12px 14px;background:var(--bg-tertiary);border:2px solid transparent;border-radius:var(--radius);cursor:pointer;font-size:14px;text-align:left;transition:all .2s}.font-option:hover{border-color:var(--border)}.font-option.active{border-color:var(--primary);background:#6366f11a}.settings-panel{display:flex;flex-direction:column;gap:16px}.builder-canvas{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-tertiary)}.canvas-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:var(--bg-secondary);border-bottom:1px solid var(--border)}.canvas-header h2{font-size:16px}.story-count{font-size:13px;color:var(--text-muted);background:var(--bg-tertiary);padding:4px 12px;border-radius:20px}.selected-stories{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:10px}.selected-story{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-secondary);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:all .2s;cursor:grab}.selected-story:active{cursor:grabbing}.selected-story.drag-over{border:2px dashed var(--primary);background:#6366f10d}.drag-handle{color:var(--text-muted);cursor:grab}.story-number{width:28px;height:28px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}.story-type-icon{color:var(--text-muted)}.story-details{flex:1;min-width:0}.story-details h4{font-size:14px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.story-details p{font-size:12px;color:var(--text-muted)}.story-actions{display:flex;gap:4px}.story-actions button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all .2s}.story-actions button:hover:not(:disabled){background:var(--bg-primary);color:var(--text-primary)}.story-actions button:disabled{opacity:.3;cursor:not-allowed}.story-actions .remove-btn:hover{background:#ef44441a;color:var(--danger)}.empty-canvas{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;text-align:center}.empty-canvas .empty-icon{font-size:64px;margin-bottom:16px}.empty-canvas h3{margin-bottom:8px;color:var(--text-primary)}.empty-canvas p{color:var(--text-muted)}.preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.preview-modal{background:var(--bg-secondary);border-radius:var(--radius-xl);width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.preview-header h2{font-size:18px}.preview-actions{display:flex;align-items:center;gap:12px}.preview-header .close-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius)}.preview-header .close-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.preview-scroll{flex:1;overflow-y:auto;padding:20px;background:#e5e5e5}.newsletter-preview{background:var(--nl-bg, white);max-width:8.5in;margin:0 auto;padding:.75in;box-shadow:0 4px 20px #00000026;min-height:11in}.nl-header{text-align:center;border-bottom:3px double var(--nl-primary, #6366f1);padding-bottom:20px;margin-bottom:30px}.nl-header h1{font-size:36px;color:var(--nl-primary, #6366f1);margin-bottom:8px}.nl-subtitle{font-size:14px;color:#666;font-style:italic;margin-bottom:8px}.nl-date{font-size:12px;color:#999;text-transform:uppercase;letter-spacing:2px}.newsletter-preview.layout-classic .nl-body{column-count:2;column-gap:30px}.newsletter-preview.layout-magazine .nl-body{column-count:1}.newsletter-preview.layout-grid .nl-body{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.newsletter-preview.layout-scrapbook .nl-body{column-count:2;column-gap:20px}.nl-story{break-inside:avoid;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid #eee}.nl-story h2{font-size:20px;color:var(--nl-primary, #6366f1);margin-bottom:6px;line-height:1.3}.nl-byline{font-size:12px;color:#888;margin-bottom:12px;font-style:italic}.nl-image{margin-bottom:12px;border-radius:4px;overflow:hidden}.nl-image img{width:100%;height:auto;display:block}.nl-content{font-size:14px;line-height:1.7;color:#333;white-space:pre-wrap}.nl-footer{margin-top:40px;padding-top:20px;border-top:1px solid #ddd;text-align:center;font-size:12px;color:#888}@media (max-width: 1000px){.builder-sidebar{width:280px}}@media (max-width: 768px){.builder-content{flex-direction:column}.builder-sidebar{width:100%;max-height:40vh}.builder-canvas{flex:1}.header-actions .btn span{display:none}.preview-modal{max-width:100%;max-height:100%;border-radius:0}}.family-page{padding:30px;max-width:1000px;margin:0 auto}.family-header{margin-bottom:30px}.invite-section{margin-bottom:30px}.invite-card{display:flex;gap:24px;background:linear-gradient(135deg,var(--primary),var(--secondary));border-radius:var(--radius-xl);padding:30px;color:#fff}.invite-icon{width:64px;height:64px;background:#fff3;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0}.invite-content h3{font-size:20px;margin-bottom:8px}.invite-content>p{opacity:.9;margin-bottom:16px}.invite-code-box{display:inline-flex;align-items:center;gap:12px;background:#fff3;border-radius:var(--radius);padding:12px 16px;margin-bottom:12px}.invite-code{font-family:monospace;font-size:20px;font-weight:700;letter-spacing:2px}.copy-btn{display:flex;align-items:center;gap:6px;background:#fff;color:var(--primary);border:none;border-radius:var(--radius-sm);padding:8px 14px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .2s}.copy-btn:hover{transform:scale(1.05)}.invite-link-hint{font-size:13px;opacity:.8}.invite-link-hint code{background:#fff3;padding:2px 6px;border-radius:4px}.members-section{margin-bottom:30px}.members-section h2{display:flex;align-items:center;gap:10px;font-size:20px;margin-bottom:20px}.members-section h2 svg{color:var(--primary)}.members-grid{display:flex;flex-direction:column;gap:12px}.member-card{display:flex;align-items:center;gap:16px;background:var(--bg-secondary);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm)}.member-avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:20px;flex-shrink:0;overflow:hidden}.member-avatar img{width:100%;height:100%;object-fit:cover}.member-info{flex:1}.member-info h4{font-size:16px;margin-bottom:2px}.member-info .nickname{font-weight:400;color:var(--text-muted);font-style:italic;margin-left:6px}.member-email{font-size:13px;color:var(--text-muted);margin-bottom:4px}.member-role{display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:600;text-transform:capitalize}.member-stats{display:flex;gap:20px}.member-stats .stat{text-align:center}.member-stats .stat-value{display:block;font-size:20px;font-weight:800;color:var(--text-primary)}.member-stats .stat-label{font-size:12px;color:var(--text-muted)}.member-actions{margin-left:auto}.role-select{padding:8px 12px;border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary);font-size:13px;font-family:inherit;cursor:pointer}.role-select:focus{outline:none;border-color:var(--primary)}.roles-section{margin-bottom:30px}.roles-section h2{display:flex;align-items:center;gap:10px;font-size:20px;margin-bottom:20px}.roles-section h2 svg{color:var(--text-muted)}.roles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.role-card{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:20px;text-align:center}.role-icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 12px}.role-card h4{margin-bottom:8px;color:var(--text-primary)}.role-card p{font-size:14px;color:var(--text-secondary)}@media (max-width: 768px){.invite-card{flex-direction:column;text-align:center}.invite-icon{margin:0 auto}.member-card{flex-wrap:wrap}.member-stats{width:100%;justify-content:center;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.member-actions{width:100%;margin-left:0;margin-top:12px}.role-select{width:100%}.roles-grid{grid-template-columns:1fr}}.profile-page{padding:30px;max-width:800px;margin:0 auto}.profile-header{margin-bottom:30px}.profile-header h1{display:flex;align-items:center;gap:12px;font-size:28px;margin-bottom:4px}.profile-header h1 svg{color:var(--primary)}.profile-card{background:var(--bg-secondary);border-radius:var(--radius-xl);padding:30px;margin-bottom:30px;box-shadow:var(--shadow-sm)}.avatar-section{display:flex;justify-content:center;margin-bottom:24px}.avatar-large{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:700;position:relative;overflow:hidden}.avatar-large img{width:100%;height:100%;object-fit:cover}.avatar-upload{position:absolute;bottom:0;left:0;right:0;height:40px;background:#0009;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.avatar-upload:hover{background:#000c}.profile-form{max-width:400px;margin:0 auto}.stats-section{margin-bottom:30px}.stats-section h2{display:flex;align-items:center;gap:10px;font-size:20px;margin-bottom:20px}.stats-section h2 svg{color:var(--accent)}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.stat-card{display:flex;align-items:center;gap:16px;background:var(--bg-secondary);padding:20px;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.stat-icon{width:56px;height:56px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:28px;font-weight:800;color:var(--text-primary);line-height:1}.stat-label{font-size:14px;color:var(--text-muted);margin-top:4px}.family-info-section h2{font-size:20px;margin-bottom:16px}.family-info-card{display:flex;justify-content:space-between;align-items:center;background:var(--bg-secondary);padding:20px;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.family-name{font-weight:700;font-size:18px;color:var(--text-primary)}.family-code{font-family:monospace;color:var(--text-muted);background:var(--bg-tertiary);padding:6px 12px;border-radius:var(--radius-sm)}@media (max-width: 600px){.stats-grid{grid-template-columns:1fr}.family-info-card{flex-direction:column;gap:12px;text-align:center}}.management-page{padding:30px;max-width:1200px;margin:0 auto}.loading-state,.access-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;height:50vh;gap:16px;color:var(--text-muted)}.access-denied svg{color:var(--danger)}.management-header{margin-bottom:24px}.status-tabs{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.status-tab{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--bg-secondary);border:2px solid transparent;border-radius:var(--radius);font-size:14px;font-weight:600;color:var(--text-secondary);cursor:pointer;font-family:inherit;transition:all .2s}.status-tab:hover{border-color:var(--border)}.status-tab.active{border-color:var(--primary);color:var(--primary);background:#6366f11a}.tab-count{padding:2px 8px;border-radius:10px;font-size:12px;background:var(--bg-tertiary)}.tab-count.submitted{background:#f59e0b33;color:#d97706}.tab-count.approved{background:#10b98133;color:#059669}.tab-count.rejected{background:#ef444433;color:#dc2626}.search-bar{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-secondary);border-radius:var(--radius);margin-bottom:20px}.search-bar svg{color:var(--text-muted);flex-shrink:0}.search-bar input{flex:1;border:none;background:transparent;font-size:14px;color:var(--text-primary);font-family:inherit}.search-bar input:focus{outline:none}.search-bar input::placeholder{color:var(--text-muted)}.stories-table{background:var(--bg-secondary);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.table-header{display:grid;grid-template-columns:60px 1fr 120px 120px 120px 140px;gap:16px;padding:14px 20px;background:var(--bg-tertiary);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.table-row{display:grid;grid-template-columns:60px 1fr 120px 120px 120px 140px;gap:16px;padding:16px 20px;border-bottom:1px solid var(--border);align-items:center;transition:background .2s}.table-row:hover{background:var(--bg-tertiary)}.table-row:last-child{border-bottom:none}.type-icon{width:40px;height:40px;border-radius:var(--radius);background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--primary)}.col-title{min-width:0}.story-title{display:block;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.story-preview{display:block;font-size:13px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.col-author{font-size:14px;color:var(--text-secondary)}.col-date{font-size:13px;color:var(--text-muted)}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;background:color-mix(in srgb,var(--status-color) 15%,transparent);color:var(--status-color)}.col-actions{display:flex;gap:6px}.action-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all .2s}.action-btn:hover{background:var(--bg-primary)}.action-btn.preview:hover{color:var(--primary)}.action-btn.approve:hover{background:#10b98126;color:#10b981}.action-btn.reject:hover,.action-btn.delete:hover{background:#ef444426;color:#ef4444}.empty-state{text-align:center;padding:80px 20px;background:var(--bg-secondary);border-radius:var(--radius-lg)}.empty-state p{color:var(--text-muted)}.preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.preview-modal{background:var(--bg-secondary);border-radius:var(--radius-xl);width:100%;max-width:600px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;animation:modalSlideIn .3s ease}.preview-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.preview-type{display:flex;align-items:center;gap:8px;color:var(--primary);font-weight:600;text-transform:capitalize}.preview-header .close-btn{background:none;border:none;color:var(--text-muted);cursor:pointer}.preview-header .close-btn:hover{color:var(--text-primary)}.preview-body{flex:1;padding:24px;overflow-y:auto}.preview-body h1{font-size:24px;margin-bottom:8px}.preview-byline{color:var(--text-muted);font-size:14px;margin-bottom:20px}.preview-photos{display:flex;gap:12px;margin-bottom:20px;overflow-x:auto}.preview-photos img{max-height:200px;border-radius:var(--radius)}.preview-content{font-size:15px;line-height:1.7;color:var(--text-secondary);white-space:pre-wrap}.preview-actions{display:flex;gap:12px;padding:16px 24px;border-top:1px solid var(--border);background:var(--bg-tertiary)}.preview-actions .btn{flex:1}.btn-success{background:#10b981;color:#fff}.btn-success:hover{background:#059669}.btn-danger{background:transparent;border:2px solid var(--danger);color:var(--danger)}.btn-danger:hover{background:#ef44441a}@media (max-width: 900px){.table-header{display:none}.table-row{display:flex;flex-wrap:wrap;gap:12px}.col-type{order:1}.col-title{order:2;flex:1;min-width:200px}.col-status{order:3}.col-author,.col-date{font-size:12px;order:4}.col-actions{order:5;width:100%;justify-content:flex-end;padding-top:12px;border-top:1px solid var(--border)}}.settings-page{padding:30px;max-width:900px;margin:0 auto}.access-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;height:50vh;gap:16px;color:var(--text-muted)}.access-denied svg{color:var(--text-muted)}.access-denied h2{color:var(--text-primary)}.settings-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:30px}.settings-content{display:flex;flex-direction:column;gap:24px}.settings-section{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm)}.settings-section .section-header{margin-bottom:20px}.settings-section .section-header h2{display:flex;align-items:center;gap:10px;font-size:18px}.settings-section .section-header h2 svg{color:var(--text-muted)}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.settings-grid .full-width{grid-column:1 / -1}.toggle-settings{display:flex;flex-direction:column;gap:16px}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:16px;background:var(--bg-tertiary);border-radius:var(--radius)}.toggle-info h4{font-size:15px;margin-bottom:4px;color:var(--text-primary)}.toggle-info p{font-size:13px;color:var(--text-muted)}.toggle{position:relative;display:inline-block;width:52px;height:28px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--border);transition:.3s;border-radius:28px}.toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 2px 4px #0003}.toggle input:checked+.toggle-slider{background-color:var(--primary)}.toggle input:checked+.toggle-slider:before{transform:translate(24px)}.danger-zone{border:2px solid rgba(239,68,68,.3)}.danger-zone .section-header h2{color:var(--danger)}.danger-actions{display:flex;flex-direction:column;gap:12px}.danger-item{display:flex;align-items:center;justify-content:space-between;padding:16px;background:#ef44440d;border-radius:var(--radius);border:1px solid rgba(239,68,68,.2)}.danger-info h4{font-size:15px;margin-bottom:4px;color:var(--text-primary)}.danger-info p{font-size:13px;color:var(--text-muted)}.btn-outline-danger{background:transparent;border:2px solid var(--danger);color:var(--danger);padding:10px 20px;font-weight:600}.btn-outline-danger:hover{background:var(--danger);color:#fff}@media (max-width: 768px){.settings-header{flex-direction:column;gap:16px}.settings-grid{grid-template-columns:1fr}.toggle-row,.danger-item{flex-direction:column;align-items:flex-start;gap:12px}.danger-item .btn-outline-danger{width:100%}}.rook-game{min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e);color:#fff;display:flex;flex-direction:column}.game-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:#0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.game-status{display:flex;align-items:center;gap:16px}.phase{background:#6366f14d;padding:8px 16px;border-radius:20px;font-weight:600;font-size:14px}.trump-indicator{padding:8px 16px;border-radius:20px;font-weight:700;font-size:14px}.trump-red{background:#ef4444}.trump-green{background:#10b981}.trump-black{background:#374151}.trump-yellow{background:#f59e0b;color:#1a1a2e}.waiting-content{text-align:center;max-width:500px}.waiting-content h2{font-size:28px;margin-bottom:8px}.waiting-content>p{color:#fff9;margin-bottom:32px}.players-waiting{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.waiting-player{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px;background:#ffffff1a;border-radius:16px;position:relative}.waiting-player.empty{opacity:.4;border:2px dashed rgba(255,255,255,.3);background:transparent}.waiting-player .player-avatar{width:56px;height:56px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700}.waiting-player .player-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.waiting-player .player-name{font-weight:600}.waiting-player .host-icon{position:absolute;top:12px;right:12px;color:#f59e0b}.waiting-player .team-label{font-size:12px;background:#fff3;padding:4px 12px;border-radius:10px}.team-note{font-size:14px;color:#ffffff80;margin-bottom:24px}.game-table{flex:1;display:flex;flex-direction:column;padding:20px;position:relative}.score-board{display:flex;justify-content:center;align-items:center;gap:40px;padding:16px;background:#0000004d;border-radius:16px;margin-bottom:20px}.team-score{display:flex;flex-direction:column;align-items:center}.team-name{font-size:14px;color:#fff9;margin-bottom:4px}.score{font-size:32px;font-weight:800}.bid-info{font-size:14px;color:#fff9}.table-area{flex:1;position:relative;min-height:300px;background:radial-gradient(ellipse at center,#2d5a27,#1a3a15);border-radius:50%/30%;border:8px solid #4a2c0a;box-shadow:inset 0 0 60px #00000080;margin:0 auto;max-width:700px;width:100%}.table-player{position:absolute;display:flex;flex-direction:column;align-items:center;gap:4px}.position-bottom{bottom:-80px;left:50%;transform:translate(-50%)}.position-top{top:-80px;left:50%;transform:translate(-50%)}.position-left{left:-100px;top:50%;transform:translateY(-50%)}.position-right{right:-100px;top:50%;transform:translateY(-50%)}.table-player .player-info{display:flex;align-items:center;gap:8px;background:#00000080;padding:8px 12px;border-radius:20px}.table-player.active .player-info{background:var(--primary);box-shadow:0 0 20px #6366f180}.table-player .player-avatar{width:32px;height:32px;border-radius:50%;background:#6366f1;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}.table-player .player-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.table-player .player-name{font-size:13px;font-weight:600}.table-player .turn-indicator{color:#fbbf24;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.cards-count{font-size:11px;color:#fff9}.trick-area{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:200px;height:150px}.played-card{position:absolute;width:50px;height:70px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;box-shadow:0 4px 8px #0000004d;border:2px solid white}.played-card.position-bottom{bottom:0;left:50%;transform:translate(-50%)}.played-card.position-top{top:0;left:50%;transform:translate(-50%)}.played-card.position-left{left:20px;top:50%;transform:translateY(-50%)}.played-card.position-right{right:20px;top:50%;transform:translateY(-50%)}.color-red{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#dc2626}.color-green{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#059669}.color-black{background:linear-gradient(135deg,#e5e7eb,#d1d5db);color:#1f2937}.color-yellow{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#d97706}.color-rook{background:linear-gradient(135deg,#a855f7,#7c3aed);color:#fff}.bidding-panel,.trump-panel,.discard-panel{position:fixed;bottom:200px;left:50%;transform:translate(-50%);background:#000000e6;padding:20px 30px;border-radius:16px;text-align:center;z-index:100}.bidding-panel h3,.trump-panel h3,.discard-panel h3{margin-bottom:16px;font-size:16px}.bid-buttons,.trump-buttons{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.trump-btn{padding:12px 24px;border-radius:8px;font-weight:700;border:none;cursor:pointer;font-family:inherit;font-size:14px}.trump-btn.trump-red{background:#ef4444;color:#fff}.trump-btn.trump-green{background:#10b981;color:#fff}.trump-btn.trump-black{background:#374151;color:#fff}.trump-btn.trump-yellow{background:#f59e0b;color:#1a1a2e}.trump-btn:hover{transform:scale(1.05)}.my-hand{display:flex;justify-content:center;gap:4px;padding:20px;background:#0000004d;border-radius:16px;margin-top:80px;overflow-x:auto}.hand-card{width:60px;height:90px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;cursor:pointer;border:3px solid white;transition:all .2s;flex-shrink:0}.hand-card:hover:not(:disabled){transform:translateY(-20px);box-shadow:0 10px 20px #0006}.hand-card:disabled{opacity:.6;cursor:not-allowed}.hand-card.selected{transform:translateY(-20px);border-color:#fbbf24;box-shadow:0 0 20px #fbbf2480}.game-message{position:fixed;bottom:300px;left:50%;transform:translate(-50%);background:#ef4444e6;padding:12px 24px;border-radius:8px;font-weight:600}.game-over-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:200}.game-over-content{background:linear-gradient(135deg,#1a1a2e,#16213e);padding:40px 60px;border-radius:24px;text-align:center;border:2px solid rgba(255,255,255,.2)}.game-over-content svg{color:#fbbf24;margin-bottom:16px}.game-over-content h2{font-size:32px;margin-bottom:24px}.final-scores{display:flex;gap:40px;justify-content:center;margin-bottom:20px}.final-team{display:flex;flex-direction:column;align-items:center}.final-score{font-size:48px;font-weight:800}.winner{font-size:24px;color:#fbbf24;margin-bottom:24px}@media (max-width: 768px){.game-header{flex-wrap:wrap;gap:12px}.table-area{max-width:100%;border-radius:16px;min-height:250px}.table-player{transform:scale(.8)}.position-left{left:-40px}.position-right{right:-40px}.my-hand{margin-top:100px;gap:2px}.hand-card{width:45px;height:70px;font-size:16px}}.trivia-game{min-height:100vh;background:linear-gradient(135deg,#7c3aed,#4f46e5);color:#fff;display:flex;flex-direction:column}.question-counter{font-size:14px;background:#fff3;padding:8px 16px;border-radius:20px}.trivia-icon{font-size:80px;margin-bottom:16px}.trivia-content{flex:1;display:flex;flex-direction:column;align-items:center;padding:24px;gap:24px}.question-card{background:#fff;color:#1f2937;border-radius:24px;padding:32px;max-width:700px;width:100%;text-align:center;box-shadow:0 20px 60px #0000004d}.category-badge{display:inline-block;background:linear-gradient(135deg,#7c3aed,#4f46e5);color:#fff;padding:6px 16px;border-radius:20px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:16px}.question-text{font-size:24px;margin-bottom:32px;line-height:1.4}.answers-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}.answer-btn{display:flex;align-items:center;gap:12px;padding:16px 20px;background:#f3f4f6;border:3px solid transparent;border-radius:12px;font-size:16px;cursor:pointer;transition:all .2s;font-family:inherit;text-align:left}.answer-btn:hover:not(:disabled){background:#e5e7eb;border-color:#7c3aed}.answer-btn:disabled{cursor:default}.answer-btn.selected{background:#eef2ff;border-color:#6366f1}.answer-btn.correct{background:#d1fae5;border-color:#10b981}.answer-btn.incorrect{background:#fee2e2;border-color:#ef4444}.answer-letter{width:32px;height:32px;border-radius:50%;background:#e5e7eb;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.answer-btn.selected .answer-letter{background:#6366f1;color:#fff}.answer-btn.correct .answer-letter{background:#10b981;color:#fff}.answer-btn.incorrect .answer-letter{background:#ef4444;color:#fff}.answer-text{flex:1}.result-icon{flex-shrink:0}.answer-btn.correct .result-icon{color:#10b981}.answer-btn.incorrect .result-icon{color:#ef4444}.answered-count{color:#6b7280;font-size:14px;margin-bottom:16px}.final-avatar{width:48px;height:48px;border-radius:50%;background:#6366f1;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700}@media (max-width: 600px){.answers-grid{grid-template-columns:1fr}.question-text{font-size:20px}.game-header h1{display:none}}.word-game{min-height:100vh;background:linear-gradient(135deg,#10b981,#059669);color:#fff;display:flex;flex-direction:column}.round-counter{font-size:14px;background:#fff3;padding:8px 16px;border-radius:20px}.word-icon{font-size:80px;margin-bottom:16px}.player-badge .player-avatar{width:32px;height:32px;border-radius:50%;background:#059669;display:flex;align-items:center;justify-content:center;font-weight:700}.btn-lg{padding:16px 32px;font-size:18px}.word-content{flex:1;display:flex;flex-direction:column;align-items:center;padding:24px;gap:24px}.mini-scoreboard{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.score-item{display:flex;align-items:center;gap:8px;background:#0003;padding:8px 14px;border-radius:20px;font-size:13px}.score-item.you{background:#ffffff4d;font-weight:700}.score-item .rank{background:#fff3;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px}.score-item .score{font-weight:700;color:#fbbf24}.timer{display:flex;align-items:center;gap:8px;font-size:28px;font-weight:800;background:#0000004d;padding:12px 24px;border-radius:16px}.timer.warning{background:#ef4444;animation:pulse .5s infinite}.word-card{background:#fff;color:#1f2937;border-radius:24px;padding:40px;max-width:600px;width:100%;text-align:center;box-shadow:0 20px 60px #0000004d}.hint-text{font-size:16px;color:#6b7280;margin-bottom:24px}.hint-label{font-weight:700;color:#10b981}.scrambled-word{display:flex;justify-content:center;gap:8px;margin-bottom:32px;flex-wrap:wrap}.letter-tile{width:50px;height:60px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:800;box-shadow:0 4px 8px #0003}.guess-input{display:flex;gap:12px;max-width:400px;margin:0 auto 24px}.guess-input input{flex:1;padding:16px 20px;font-size:20px;font-weight:700;text-align:center;border:3px solid #e5e7eb;border-radius:12px;text-transform:uppercase;letter-spacing:4px;font-family:inherit}.guess-input input:focus{outline:none;border-color:#10b981}.guess-input .btn{padding:16px 20px}.result-message{font-size:18px;font-weight:700;margin-bottom:16px;padding:12px 24px;border-radius:12px;background:#fee2e2;color:#dc2626}.result-message.success{background:#d1fae5;color:#059669}.solved-by{display:flex;align-items:center;justify-content:center;gap:8px;font-size:16px;color:#059669;margin-bottom:16px}.solved-by svg{color:#fbbf24}.correct-word{font-size:18px;color:#6b7280;margin-bottom:24px}.correct-word strong{color:#10b981}.game-over{flex:1;display:flex;align-items:center;justify-content:center;padding:40px}.game-over-content{text-align:center}.trophy-icon{color:#fbbf24;margin-bottom:16px}.game-over-content h2{font-size:36px;margin-bottom:32px}.final-leaderboard{display:flex;flex-direction:column;gap:12px;margin-bottom:32px}.final-player{display:flex;align-items:center;gap:12px;background:#ffffff1a;padding:16px 24px;border-radius:16px}.final-player.rank-1{background:#fbbf244d;border:2px solid #fbbf24}.final-rank{font-size:24px;width:40px;text-align:center}.final-avatar{width:48px;height:48px;border-radius:50%;background:#059669;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700}.final-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.final-name{flex:1;text-align:left;font-size:18px;font-weight:600}.final-score{font-size:24px;font-weight:800;color:#fbbf24}@media (max-width: 600px){.scrambled-word{gap:6px}.letter-tile{width:40px;height:50px;font-size:22px}.game-header h1{display:none}.guess-input{flex-direction:column}.guess-input input{letter-spacing:2px}}.tictactoe-game{min-height:100vh;background:linear-gradient(135deg,#ec4899,#8b5cf6);color:#fff;display:flex;flex-direction:column}.symbol-btn{background:#ffffffe6;color:#8b5cf6;border:none;padding:12px 24px;border-radius:12px;font-size:24px;cursor:pointer;font-family:inherit;font-weight:700;transition:all .2s}.symbol-option:hover:not(:disabled){border-color:#8b5cf6;background:#8b5cf61a}.symbol-option.selected{border-color:#8b5cf6;background:#8b5cf633}.turn-indicator{font-size:24px;font-weight:700;padding:12px 24px;background:#0003;border-radius:16px}.turn-indicator .draw-text{color:#fffc}.board{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;background:#0000004d;padding:8px;border-radius:16px}.cell{width:100px;height:100px;background:#ffffffe6;border:none;border-radius:12px;font-size:48px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.cell:hover:not(:disabled){background:#fff;transform:scale(1.02)}.cell.filled{cursor:default}.cell.winning{background:#fbbf24;animation:pulse .5s ease infinite}@media (max-width: 600px){.cell{width:80px;height:80px;font-size:36px}.players-setup{flex-direction:column}.game-header h1{display:none}}.ultimate-game{min-height:100vh;background:linear-gradient(135deg,#0ea5e9,#6366f1);color:#fff;display:flex;flex-direction:column}.game-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:#0003}.help-btn{background:#fff3;border:none;color:#fff;padding:8px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}.help-btn:hover{background:#ffffff4d}.scores{display:flex;gap:16px}.score{background:#fff3;padding:8px 16px;border-radius:20px;font-weight:700;font-size:18px}.score.you{background:#fff6}.rules-modal{max-width:500px;padding:24px}.rules-modal h3{text-align:center;margin-bottom:16px;color:var(--text-primary)}.rules-content{color:var(--text-secondary);line-height:1.6}.rules-content p{margin-bottom:12px}.rules-content ul{padding-left:20px;margin-bottom:20px}.rules-content li{margin-bottom:8px}.players-setup{display:flex;gap:24px;justify-content:center;margin-bottom:32px}.player-setup-card{display:flex;flex-direction:column;align-items:center;gap:12px;background:#ffffff26;padding:24px 32px;border-radius:16px;min-width:150px;position:relative}.player-setup-card.empty{opacity:.5;border:2px dashed rgba(255,255,255,.3);background:transparent}.player-setup-card .player-avatar{width:64px;height:64px;border-radius:50%;background:#ffffff4d;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700}.player-setup-card .player-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.player-setup-card .player-name{font-weight:600}.symbol-btn{background:#ffffffe6;color:#6366f1;border:none;padding:12px 24px;border-radius:12px;font-size:24px;cursor:pointer;font-family:inherit;font-weight:700;transition:all .2s}.symbol-btn:hover{transform:scale(1.05)}.symbol-display{font-size:32px;padding:8px}.ready-check{position:absolute;top:12px;right:12px;color:#10b981;background:#fff;border-radius:50%;padding:2px}.symbol-picker-modal{max-width:400px;padding:24px}.symbol-picker-modal h3{text-align:center;margin-bottom:20px;color:var(--text-primary)}.symbol-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.symbol-option{display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 8px;background:var(--bg-tertiary);border:2px solid transparent;border-radius:12px;cursor:pointer;font-family:inherit;transition:all .2s}.symbol-option:hover:not(:disabled){border-color:#6366f1;background:#6366f61a}.symbol-option.selected{border-color:#6366f1;background:#6366f633}.symbol-option.used{opacity:.4;cursor:not-allowed}.symbol-option .symbol{font-size:32px}.symbol-option .symbol-name{font-size:11px;color:var(--text-muted)}.game-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;gap:24px}.turn-indicator{font-size:20px;font-weight:700;padding:12px 24px;background:#0003;border-radius:16px}.turn-indicator .your-turn{color:#fbbf24}.turn-indicator .winner-text{display:flex;align-items:center;gap:8px;color:#fbbf24}.ultimate-board{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;background:#0006;padding:8px;border-radius:16px}.small-board{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;background:#fff3;padding:6px;border-radius:8px;transition:all .2s}.small-board.active{background:#fbbf2466;box-shadow:0 0 20px #fbbf2480}.small-board.won{display:flex;align-items:center;justify-content:center}.board-winner{font-size:64px}.small-board .cell{width:36px;height:36px;background:#ffffffe6;border:none;border-radius:4px;font-size:20px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.small-board .cell:hover:not(:disabled){background:#fff;transform:scale(1.05)}.small-board .cell:disabled{cursor:default}.small-board:not(.active) .cell:not(.filled){opacity:.6}.game-over-actions{display:flex;gap:16px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:var(--bg-secondary);border-radius:16px;width:100%;max-height:90vh;overflow:auto}@media (max-width: 500px){.small-board .cell{width:28px;height:28px;font-size:16px}.board-winner{font-size:48px}.players-setup{flex-direction:column}.game-header h1{display:none}.ultimate-board{gap:4px;padding:4px}.small-board{gap:2px;padding:4px}}.minesweeper-game{min-height:100vh;background:linear-gradient(135deg,#475569,#1e293b);color:#fff;display:flex;flex-direction:column}.loading-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}.game-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:#0000004d}.game-title{display:flex;align-items:center;gap:12px}.game-emoji{font-size:32px}.game-title h1{font-size:24px;margin:0}.game-stats{display:flex;gap:16px}.stat{display:flex;align-items:center;gap:6px;background:#ffffff1a;padding:8px 16px;border-radius:20px;font-weight:700}.waiting-room{flex:1;display:flex;align-items:center;justify-content:center;padding:40px}.waiting-content{text-align:center}.mine-icon{font-size:80px;margin-bottom:16px}.waiting-content h2{font-size:32px;margin-bottom:8px}.waiting-content>p{color:#ffffffb3;margin-bottom:32px}.players-list{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:32px}.player-badge{display:flex;align-items:center;gap:8px;background:#fff3;padding:8px 16px;border-radius:30px}.player-badge .player-avatar{width:32px;height:32px;border-radius:50%;background:#6366f1;display:flex;align-items:center;justify-content:center;font-weight:700}.player-badge .player-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.difficulty-selection h3{margin-bottom:16px;font-size:18px}.difficulty-buttons{display:flex;flex-direction:column;gap:12px}.difficulty-btn{display:flex;flex-direction:column;padding:16px 24px;min-width:200px}.diff-name{font-size:18px;font-weight:700}.diff-info{font-size:12px;opacity:.8}.waiting-text{color:#fff9;font-style:italic}.game-content{flex:1;display:flex;flex-direction:column;align-items:center;padding:24px;gap:16px}.last-move{background:#ffffff1a;padding:8px 20px;border-radius:20px;font-size:14px}.controls{display:flex;gap:8px}.mode-btn{padding:12px 24px;background:#ffffff1a;border:2px solid transparent;border-radius:12px;color:#fff;font-family:inherit;font-size:16px;cursor:pointer;transition:all .2s}.mode-btn:hover{background:#fff3}.mode-btn.active{background:#6366f180;border-color:#6366f1}.game-over-banner{display:flex;align-items:center;gap:12px;padding:16px 32px;border-radius:16px;font-size:20px;font-weight:700}.game-over-banner.won{background:#10b9814d;color:#34d399}.game-over-banner.lost{background:#ef44444d;color:#f87171}.board{display:grid;gap:2px;background:#374151;padding:8px;border-radius:8px;box-shadow:inset 0 2px 4px #0000004d}.cell{width:32px;height:32px;background:linear-gradient(135deg,#64748b,#475569);border:1px solid #94a3b8;border-radius:4px;font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .1s;font-family:inherit;color:#fff}.cell:hover:not(:disabled){background:linear-gradient(135deg,#94a3b8,#64748b)}.cell:disabled{cursor:default}.cell.revealed{background:#e2e8f0;border-color:#cbd5e1;cursor:default}.cell.mine{background:#fecaca}.cell.num-1{color:#3b82f6}.cell.num-2{color:#22c55e}.cell.num-3{color:#ef4444}.cell.num-4{color:#8b5cf6}.cell.num-5{color:#a855f7}.cell.num-6{color:#06b6d4}.cell.num-7{color:#1f2937}.cell.num-8{color:#6b7280}@media (max-width: 600px){.cell{width:24px;height:24px;font-size:12px}.board{padding:4px}.game-header h1{display:none}.controls{flex-wrap:wrap;justify-content:center}}@media (max-width: 400px){.cell{width:20px;height:20px;font-size:10px}}.game-room-page{padding:30px;max-width:1200px;margin:0 auto}.game-room-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:30px}.active-games-section,.games-section{margin-bottom:40px}.active-games-section h2,.games-section h2{display:flex;align-items:center;gap:10px;font-size:20px;margin-bottom:20px}.active-games-section h2 svg{color:var(--success)}.games-section h2 svg{color:var(--primary)}.active-games-list{display:flex;flex-direction:column;gap:12px}.active-game-card{display:flex;align-items:center;gap:16px;padding:20px;background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border-left:4px solid var(--success)}.active-game-card .game-icon{font-size:40px;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:var(--radius)}.active-game-card .game-info{flex:1}.active-game-card .game-info h3{font-size:18px;margin-bottom:6px}.active-game-card .game-meta{display:flex;flex-wrap:wrap;gap:16px;font-size:13px;color:var(--text-secondary);margin-bottom:10px}.active-game-card .game-meta span{display:flex;align-items:center;gap:4px}.active-game-card .host{color:var(--accent)}.active-game-card .status{padding:2px 8px;border-radius:10px;font-weight:600;font-size:11px;text-transform:uppercase}.status-waiting{background:#f59e0b26;color:#d97706}.status-playing{background:#10b98126;color:#059669}.player-avatars{display:flex;gap:-8px}.player-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;border:2px solid var(--bg-secondary);margin-left:-8px}.player-avatar:first-child{margin-left:0}.player-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.games-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.game-card{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;align-items:center;text-align:center;transition:all .2s}.game-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}.game-card-icon{font-size:56px;margin-bottom:16px}.game-card-info h3{font-size:20px;margin-bottom:8px}.game-card-info p{font-size:14px;color:var(--text-secondary);margin-bottom:12px}.player-range{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted);background:var(--bg-tertiary);padding:4px 12px;border-radius:20px;margin-bottom:16px}.create-game-modal{max-width:600px}.game-select-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}.game-select-card{display:flex;flex-direction:column;align-items:center;padding:24px 16px;background:var(--bg-tertiary);border:2px solid transparent;border-radius:var(--radius-lg);cursor:pointer;font-family:inherit;text-align:center;transition:all .2s}.game-select-card:hover{border-color:var(--primary);background:#6366f10d}.game-select-card .game-emoji{font-size:48px;margin-bottom:12px}.game-select-card h4{font-size:16px;margin-bottom:6px;color:var(--text-primary)}.game-select-card p{font-size:12px;color:var(--text-muted);margin-bottom:8px}.game-select-card .player-info{font-size:11px;color:var(--text-secondary);background:var(--bg-secondary);padding:4px 10px;border-radius:10px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--bg-secondary);border-radius:var(--radius-xl);width:100%;max-height:90vh;overflow:auto;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.modal-header h2{font-size:20px}.modal-header .close-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px}.modal-body{padding:24px}@media (max-width: 768px){.game-room-header{flex-direction:column;gap:16px}.active-game-card{flex-direction:column;text-align:center}.active-game-card .game-meta,.player-avatars{justify-content:center}.games-grid{grid-template-columns:1fr}}.drafts-page{padding:30px;max-width:900px;margin:0 auto}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:50vh;gap:16px;color:var(--text-muted)}.drafts-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:30px}.header-content h1{display:flex;align-items:center;gap:12px;font-size:28px;margin-bottom:4px}.header-content h1 svg{color:var(--primary)}.drafts-list{display:flex;flex-direction:column;gap:16px}.draft-card{display:flex;gap:16px;padding:20px;background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all .2s}.draft-card:hover{box-shadow:var(--shadow)}.draft-type-indicator{width:48px;height:48px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.draft-content{flex:1;min-width:0}.draft-meta{display:flex;align-items:center;gap:16px;margin-bottom:8px}.draft-type{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.draft-time{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-muted)}.draft-title{font-size:18px;margin-bottom:6px;color:var(--text-primary)}.draft-preview{font-size:14px;color:var(--text-secondary);line-height:1.5;margin-bottom:8px}.draft-photos{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted)}.draft-actions{display:flex;flex-direction:column;gap:8px;flex-shrink:0}.btn-icon{width:40px;height:40px;padding:0;display:flex;align-items:center;justify-content:center}.btn-danger-ghost{background:transparent;border:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius);transition:all .2s}.btn-danger-ghost:hover{background:#ef44441a;color:var(--danger)}.spinner-small{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.empty-state{text-align:center;padding:60px 20px;background:var(--bg-secondary);border-radius:var(--radius-lg)}.empty-icon{font-size:64px;margin-bottom:16px}.empty-state h3{margin-bottom:8px;color:var(--text-primary)}.empty-state p{color:var(--text-muted);margin-bottom:24px;max-width:400px;margin-left:auto;margin-right:auto}.drafts-tip{display:flex;align-items:flex-start;gap:12px;margin-top:30px;padding:16px 20px;background:#6366f11a;border-radius:var(--radius);border-left:4px solid var(--primary)}.drafts-tip svg{color:var(--primary);flex-shrink:0;margin-top:2px}.drafts-tip p{font-size:14px;color:var(--text-secondary);margin:0}.drafts-tip strong{color:var(--text-primary)}@media (max-width: 768px){.drafts-header{flex-direction:column;gap:16px}.draft-card{flex-direction:column}.draft-type-indicator{width:40px;height:40px}.draft-actions{flex-direction:row;width:100%}.draft-actions .btn-primary{flex:1}}.app-layout{display:flex;min-height:100vh}.sidebar{width:280px;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform .3s ease}.sidebar-header{padding:20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.sidebar-logo{display:flex;align-items:center;gap:12px}.logo-icon{font-size:32px}.logo-text-group{display:flex;flex-direction:column}.logo-text{font-size:18px;font-weight:700;color:var(--text-primary)}.logo-subtext{font-size:12px;color:var(--text-muted)}.close-btn{display:none;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.nav-section{margin-bottom:24px}.nav-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);padding:8px 16px 12px}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius);color:var(--text-secondary);font-weight:600;transition:all .2s;margin-bottom:4px}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item.active{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff}.sidebar-footer{padding:16px;border-top:1px solid var(--border)}.user-info{display:flex;align-items:center;gap:12px;margin-bottom:12px}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;overflow:hidden}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-details{display:flex;flex-direction:column}.user-name{font-weight:700;color:var(--text-primary);font-size:14px}.user-role{font-size:12px;color:var(--text-muted);text-transform:capitalize}.user-actions{display:flex;gap:8px}.user-action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;background:var(--bg-tertiary);border:none;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s}.user-action-btn:hover{background:var(--border);color:var(--text-primary)}.logout-btn:hover{background:#ef44441a;color:var(--danger)}.main-content{flex:1;margin-left:280px;min-height:100vh;background:var(--bg-primary)}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:60px;background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:0 16px;align-items:center;justify-content:space-between;z-index:90}.menu-btn{background:none;border:none;color:var(--text-primary);cursor:pointer;padding:8px;margin:-8px}.mobile-logo{display:flex;align-items:center;gap:8px}.mobile-logo .logo-icon{font-size:24px}.mobile-logo .logo-text{font-size:16px;font-weight:700;color:var(--text-primary)}.header-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;cursor:pointer;overflow:hidden}.header-avatar img{width:100%;height:100%;object-fit:cover}.user-menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:95}.user-menu-dropdown{position:fixed;top:70px;right:16px;background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);min-width:220px;z-index:100;overflow:hidden;animation:fadeIn .2s ease}.user-menu-header{display:flex;align-items:center;gap:12px;padding:16px;border-bottom:1px solid var(--border)}.user-menu-items{padding:8px}.user-menu-item{display:flex;align-items:center;gap:10px;padding:12px;border-radius:var(--radius);color:var(--text-secondary);font-weight:600;font-size:14px;width:100%;background:none;border:none;cursor:pointer;font-family:inherit;transition:all .2s}.user-menu-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.user-menu-item.logout:hover{background:#ef44441a;color:var(--danger)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99}@media (max-width: 900px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay,.close-btn{display:block}.main-content{margin-left:0;padding-top:60px}.mobile-header{display:flex}}:root{--primary: #6366f1;--primary-dark: #4f46e5;--primary-light: #a5b4fc;--secondary: #8b5cf6;--accent: #f59e0b;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--border: #e2e8f0;--border-focus: #6366f1;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 25px -5px rgba(0, 0, 0, .15);--shadow-xl: 0 20px 40px -10px rgba(0, 0, 0, .2);--radius-sm: 6px;--radius: 12px;--radius-lg: 16px;--radius-xl: 24px;--font-body: "Nunito", -apple-system, sans-serif;--font-display: "Playfair Display", Georgia, serif;--font-handwriting: "Patrick Hand", cursive}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.3}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}a{color:var(--primary);text-decoration:none;transition:color .2s}a:hover{color:var(--primary-dark)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;font-family:var(--font-body);font-size:1rem;font-weight:700;border:none;border-radius:var(--radius);cursor:pointer;transition:all .2s}.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary)}.btn-success{background:linear-gradient(135deg,var(--success),#059669);color:#fff}.btn-danger{background:linear-gradient(135deg,var(--danger),#dc2626);color:#fff}.btn-outline{background:transparent;border:2px solid var(--border);color:var(--text-primary)}.btn-outline:hover{border-color:var(--primary);color:var(--primary)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-lg{padding:16px 32px;font-size:1.125rem}.btn-sm{padding:8px 16px;font-size:.875rem}.btn-block{width:100%}.btn-icon{padding:12px;border-radius:50%}.input,.textarea,.select{width:100%;padding:12px 16px;font-family:var(--font-body);font-size:1rem;color:var(--text-primary);background:var(--bg-secondary);border:2px solid var(--border);border-radius:var(--radius);transition:border-color .2s,box-shadow .2s}.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #6366f126}.input::placeholder,.textarea::placeholder{color:var(--text-muted)}.textarea{min-height:120px;resize:vertical}.label{display:block;font-weight:600;color:var(--text-secondary);margin-bottom:6px;font-size:.9rem}.form-group{margin-bottom:20px}.card{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.card-header{padding:20px 24px;border-bottom:1px solid var(--border)}.card-body{padding:24px}.card-footer{padding:16px 24px;background:var(--bg-tertiary);border-top:1px solid var(--border)}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:.75rem;font-weight:700;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}.badge-primary{background:#6366f126;color:var(--primary)}.badge-success{background:#10b98126;color:var(--success)}.badge-warning{background:#f59e0b26;color:var(--warning)}.badge-danger{background:#ef444426;color:var(--danger)}.avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;overflow:hidden}.avatar img{width:100%;height:100%;object-fit:cover}.avatar-sm{width:32px;height:32px;font-size:.875rem}.avatar-lg{width:64px;height:64px;font-size:1.5rem}.avatar-xl{width:96px;height:96px;font-size:2rem}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-primary{color:var(--primary)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.font-display{font-family:var(--font-display)}.font-handwriting{font-family:var(--font-handwriting)}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:1rem}.mt-4{margin-top:1.5rem}.mt-5{margin-top:2rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:1rem}.mb-4{margin-bottom:1.5rem}.mb-5{margin-bottom:2rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:1rem}.gap-4{gap:1.5rem}.grid{display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fade-in{animation:fadeIn .3s ease-out}.animate-slide-in{animation:slideIn .3s ease-out}.animate-pulse{animation:pulse 2s infinite}.animate-spin{animation:spin 1s linear infinite}.spinner{width:40px;height:40px;border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.empty-state{text-align:center;padding:60px 20px}.empty-state-icon{font-size:4rem;margin-bottom:1rem}.empty-state h3{margin-bottom:.5rem;color:var(--text-primary)}.empty-state p{color:var(--text-muted);margin-bottom:1.5rem}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-tertiary)}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}
