:root{font-family:Segoe UI,-apple-system,BlinkMacSystemFont,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;--font-heading: "Segoe UI", sans-serif;--font-body: "Segoe UI", sans-serif;line-height:1.6;font-weight:400;color-scheme:light dark;color:#1a1a1a;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--accent-primary: #4f46e5;--accent-secondary: #9333ea;--text-main: #1a1a1a;--text-muted: #64748b;--bg-main: #f8f9ff;--glass-bg: rgba(255, 255, 255, .7)}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);letter-spacing:-.02em}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;height:100vh;margin:0;padding:0}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.modal-overlay{position:fixed;inset:0;background:#000000a6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:5000;padding:2rem;animation:fadeIn .3s cubic-bezier(.16,1,.3,1)}.modal-content{background:#fff;border-radius:40px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 40px 100px #00000040;border:1px solid rgba(255,255,255,.1);animation:scaleIn .4s cubic-bezier(.16,1,.3,1)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.close-btn{background:#f1f5f9;border:none;width:50px;height:50px;border-radius:16px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:#64748b}.close-btn:hover{background:#e2e8f0;color:#1e293b;transform:rotate(90deg)}.glass-panel{background:#ffffffe6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}@keyframes scaleIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.navigation{background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;height:100%;width:80px;transition:all .3s ease}.nav-content{display:flex;flex-direction:column;gap:.5rem;padding:1rem .5rem}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.75rem .5rem;background:transparent;border:none;border-radius:.75rem;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;position:relative}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--accent-primary);color:#fff}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:#fff;border-radius:0 2px 2px 0}.nav-icon{flex-shrink:0}.nav-label{font-size:.65rem;font-weight:500;text-align:center;line-height:1.2}@media(max-width:768px){.navigation{width:100%;height:auto;border-right:none;border-top:1px solid var(--border-color);position:fixed;bottom:0;left:0;right:0;z-index:100}.nav-content{flex-direction:row;justify-content:space-around;padding:.5rem}.nav-item{flex:1;padding:.5rem}.nav-item.active:before{left:50%;top:0;transform:translate(-50%);width:60%;height:3px;border-radius:0 0 2px 2px}.nav-label{font-size:.7rem}}.companion-section{background:var(--bg-primary)}.companion-section .section-header{padding:1.5rem;border-bottom:1px solid var(--border-color)}.companion-section .section-header h1{font-size:1.5rem;font-weight:600;color:var(--text-primary);background:linear-gradient(to right,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.chat-area{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;scrollbar-width:thin;scrollbar-color:var(--border-color) transparent;-webkit-overflow-scrolling:touch}.chat-area::-webkit-scrollbar{width:4px}.chat-area::-webkit-scrollbar-thumb{background-color:var(--border-color);border-radius:10px}.messages{display:flex;flex-direction:column;gap:1rem;padding-bottom:1rem}.message-card{width:100%;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:1rem;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);animation:slideUp .3s ease-out}.message-card.expanded{background:var(--bg-hover);border-color:var(--accent-primary);box-shadow:0 8px 24px #6366f126}.message-card.processing{background:var(--bg-secondary);border:1px dashed var(--border-color)}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;cursor:pointer;transition:background .2s}.message-header:hover{background:var(--bg-hover)}.message-preview{flex:1;font-size:.9rem;color:var(--text-secondary);line-height:1.5}.expand-btn{background:none;border:none;color:var(--accent-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:.25rem;transition:transform .2s}.expand-btn:hover{transform:scale(1.1)}.message-body{padding:0 1.25rem 1.25rem;display:flex;flex-direction:column;gap:1rem;animation:expandContent .3s ease-out}@keyframes expandContent{0%{opacity:0;max-height:0}to{opacity:1;max-height:1000px}}.message-text{font-size:.95rem;line-height:1.6;color:var(--text-primary);white-space:pre-wrap}.message-image{width:100%;max-height:200px;border-radius:.75rem;overflow:hidden;background:#0000001a;border:1px solid var(--border-color);cursor:pointer;position:relative;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.message-image:hover{border-color:var(--accent-primary);box-shadow:0 4px 16px #6366f133}.message-image img{width:100%;height:auto;max-height:200px;display:block;object-fit:contain}.image-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);color:#fff;padding:.75rem;font-size:.75rem;text-align:center;opacity:0;transition:opacity .3s ease}.message-image:hover .image-overlay{opacity:1}.message-card.processing .message-content{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;color:var(--text-secondary);font-size:.875rem}.fullscreen-modal{position:fixed;inset:0;background:#000000f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:2rem;animation:fadeIn .3s ease;cursor:pointer}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fullscreen-modal img{max-width:100%;max-height:100%;object-fit:contain;border-radius:.5rem;box-shadow:0 20px 60px #00000080}.close-fullscreen{position:absolute;top:1.5rem;right:1.5rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;z-index:1001}.close-fullscreen:hover{background:#fff3;transform:rotate(90deg)}.controls-area{padding:1rem;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--bg-secondary);border-top:1px solid var(--border-color);display:flex;flex-direction:column;align-items:center;gap:.5rem;flex-shrink:0}.status-text{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em}.record-button{width:64px;height:64px;border-radius:50%;border:none;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 20px #6366f14d;position:relative}.record-button:disabled{opacity:.5;cursor:not-allowed;filter:grayscale(1)}.record-button:not(:disabled):hover{transform:scale(1.05);box-shadow:0 6px 25px #6366f166}.record-button.recording{background:#ef4444;animation:pulse 1.5s infinite;box-shadow:0 0 #ef4444b3}@keyframes pulse{0%{transform:scale(1);box-shadow:0 0 #ef4444b3}70%{transform:scale(1.05);box-shadow:0 0 0 15px #ef444400}to{transform:scale(1);box-shadow:0 0 #ef444400}}.spin{animation:spin 1s linear infinite}@media(max-width:768px){.chat-area{padding:1rem}.controls-area{padding-bottom:env(safe-area-inset-bottom,2rem)}.message-image,.message-image img{max-height:150px}.fullscreen-modal{padding:1rem}}.album-container{display:flex;flex-direction:column;height:100%;background:var(--bg-main);position:relative;font-family:var(--font-body)}.album-tabs{display:flex;padding:1.25rem 2rem;gap:1.5rem;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(0,0,0,.05);position:sticky;top:0;z-index:100}.tab-btn{padding:.8rem 1.75rem;border:none;background:transparent;color:var(--text-muted);font-weight:700;font-size:.95rem;border-radius:14px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;gap:.6rem}.tab-btn:hover{background:#6366f114;color:var(--accent-primary);transform:translateY(-1px)}.tab-btn.active{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;box-shadow:0 10px 20px -5px #6366f166}.album-content{flex:1;overflow-y:auto;padding:3rem 2rem}.ai-studio-centered{max-width:1000px;margin:0 auto;width:100%}.studio-main{display:flex;flex-direction:column;gap:3.5rem}.studio-title{font-size:3.5rem;font-weight:950;color:var(--text-main);letter-spacing:-.04em;line-height:1;margin-bottom:.5rem;font-family:var(--font-heading)}.studio-subtitle{font-size:1.25rem;color:var(--text-muted);line-height:1.6;font-weight:500}.prompt-box-luxury{background:#fff;border-radius:40px;padding:3.5rem;border:1px solid rgba(0,0,0,.05);box-shadow:0 30px 80px #0000000f;display:flex;flex-direction:column;gap:2.5rem;position:relative;overflow:hidden}.prompt-box-luxury:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary))}.sidebar-section-title{font-size:.9rem;font-weight:900;color:var(--text-main);text-transform:uppercase;letter-spacing:.15em;margin-bottom:1rem}.prompt-footer{display:flex;flex-direction:column;align-items:center;gap:1.5rem;margin-top:1rem}.inline-archive-browser{background:#f8fafd;border-radius:24px;padding:2rem;border:1px solid rgba(0,0,0,.05);margin-top:1rem;animation:luxurySlideDown .4s cubic-bezier(.16,1,.3,1)}.inline-browser-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.btn-inline-back{display:flex;align-items:center;gap:.5rem;background:#fff;border:1px solid rgba(0,0,0,.08);padding:.5rem 1rem;border-radius:12px;font-size:.85rem;font-weight:700;cursor:pointer}.inline-selection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:1rem;max-height:400px;overflow-y:auto}.ref-images-horizontal{display:flex;gap:1.5rem;overflow-x:auto;padding:.5rem .5rem 1.5rem;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.1) transparent;-webkit-overflow-scrolling:touch;min-height:120px}.ref-images-horizontal::-webkit-scrollbar{height:6px}.ref-images-horizontal::-webkit-scrollbar-thumb{background:#0000001a;border-radius:10px}.ref-wrapper{position:relative;flex-shrink:0}.ref-thumb{width:100px;height:100px;border-radius:24px;object-fit:cover;border:3px solid white;box-shadow:0 10px 25px #0000001a;transition:all .3s cubic-bezier(.16,1,.3,1)}.ref-wrapper:hover .ref-thumb{transform:translateY(-8px) scale(1.05);box-shadow:0 20px 40px #00000026}.remove-ref{position:absolute;top:-10px;right:-10px;width:28px;height:28px;background:#1a1a1a;color:#fff;border:2px solid white;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;box-shadow:0 4px 10px #0003}.remove-ref:hover{background:#ef4444}.result-canvas{background:#0a0a0b;border-radius:48px;min-height:600px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;box-shadow:0 50px 100px -20px #0006;border:1px solid rgba(255,255,255,.05)}.canvas-empty{text-align:center;color:#fff6}.sparkle-icon{color:var(--accent-primary);filter:drop-shadow(0 0 15px rgba(99,102,241,.5))}@keyframes luxurySlideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:3rem}.collection-card{background:#fff;border-radius:32px;overflow:hidden;box-shadow:0 10px 30px #00000008;transition:all .5s cubic-bezier(.16,1,.3,1);cursor:pointer}.collection-preview{height:260px;background:#f1f3f9}.collection-preview img{width:100%;height:100%;object-fit:cover}.collection-info{padding:2rem}.collection-name{font-size:1.5rem;font-weight:800;color:var(--text-main);font-family:var(--font-heading)}.thumbnail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1.5rem}.thumbnail-card{aspect-ratio:1;border-radius:24px;overflow:hidden;cursor:pointer}.thumbnail-card img{width:100%;height:100%;object-fit:cover}.btn-premium{padding:1rem 2.5rem;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:#fff;border:none;border-radius:20px;font-weight:800;cursor:pointer;display:flex;align-items:center;gap:.8rem;box-shadow:0 10px 25px -5px #4f46e566}.form-input{width:100%;background:#f4f6f9;border:2px solid transparent;padding:1.25rem 1.5rem;border-radius:20px}.form-input:focus{background:#fff;border-color:var(--accent-primary)}.form-label-luxury{font-size:.85rem;font-weight:800;color:#b0b0b0;text-transform:uppercase;letter-spacing:.15em;margin-bottom:.75rem;display:block}.preview-modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);display:flex;align-items:center;justify-content:center;z-index:3000}.preview-content{background:#fff;border-radius:32px;width:90%;max-width:1100px;overflow:hidden}@media(max-width:768px){.album-content{padding:1.5rem 1rem}.studio-title{font-size:2.25rem}.studio-subtitle{font-size:1rem}.prompt-box-luxury{padding:1.5rem;border-radius:24px;gap:1.5rem}.gallery-grid{grid-template-columns:1fr;gap:1.5rem}.thumbnail-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem}.detail-header{flex-direction:column;align-items:flex-start;gap:1rem}.detail-controls{flex-direction:column;align-items:stretch!important;gap:1.25rem}.preview-modal-overlay{padding:1rem}.preview-content{border-radius:20px}.result-canvas{min-height:400px;border-radius:32px}.inline-archive-browser{padding:1rem}.inline-selection-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.btn-premium{padding:.8rem 1.5rem;font-size:1rem}}.reminder-container{height:100%;display:flex;flex-direction:column;background:var(--bg-main);padding:3rem 2rem;overflow-y:auto}.reminder-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:3.5rem;max-width:1200px;width:100%;margin-left:auto;margin-right:auto}.reminder-title{font-size:3rem;font-weight:950;color:var(--text-main);letter-spacing:-.04em;margin-bottom:.5rem}.reminder-subtitle{font-size:1.2rem;color:var(--text-muted);font-weight:500}.btn-add-reminder{padding:1rem 2rem;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:#fff;border:none;border-radius:18px;font-weight:800;cursor:pointer;display:flex;align-items:center;gap:.8rem;box-shadow:0 10px 25px -5px #4f46e54d;transition:all .3s cubic-bezier(.16,1,.3,1)}.btn-add-reminder:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 15px 35px -5px #4f46e566}.reminder-content{flex:1;max-width:1200px;width:100%;margin:0 auto}.reminder-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:2rem}.reminder-card{background:#fff;border-radius:32px;padding:2.25rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem;box-shadow:0 10px 40px #0000000a;border:1px solid rgba(0,0,0,.05);transition:all .5s cubic-bezier(.16,1,.3,1);min-height:140px}.reminder-card:hover{transform:translateY(-8px) scale(1.01);box-shadow:0 30px 60px #00000014}.reminder-card.completed{opacity:.6;background:#f8fafc;filter:grayscale(.5)}.reminder-card.completed .reminder-card-title{text-decoration:line-through;color:#94a3b8}.reminder-info{flex:1;min-width:280px}.reminder-card-title{font-size:1.5rem;font-weight:900;color:var(--text-main);margin-bottom:.8rem;white-space:normal;word-break:break-word}.reminder-meta{display:flex;flex-wrap:wrap;gap:1.2rem;color:var(--text-muted);font-size:.95rem;font-weight:700}.meta-item{display:flex;align-items:center;gap:.5rem;white-space:nowrap}.badge-freq{background:#f0f4ff;color:#4f46e5;padding:4px 12px;border-radius:100px;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}.reminder-actions{display:flex;gap:.8rem;margin-left:1.5rem;flex-shrink:0}.action-btn{width:60px;height:60px;border-radius:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.16,1,.3,1);border:1px solid rgba(0,0,0,.05);background:#f8fafd;flex-shrink:0}.action-btn:hover{transform:scale(1.1);background:#fff;box-shadow:0 10px 20px #0000001a}.action-btn.check:hover{background:#e0f2fe;color:#0ea5e9;border-color:#0ea5e9}.action-btn.edit{color:#6366f1}.action-btn.edit:hover{background:#eef2ff;border-color:#6366f1}.action-btn.delete{color:#ef4444}.action-btn.delete:hover{background:#fef2f2;border-color:#ef4444}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:400px;color:var(--text-muted)}.empty-state h3{font-size:1.75rem;margin:1.5rem 0 .5rem;color:#1a1a1a}.icon-muted{opacity:.15}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.select-luxury{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;background-size:1.2em;padding-right:3rem}.toast-success{position:fixed;bottom:2rem;right:2rem;background:#10b981;color:#fff;padding:1rem 2rem;border-radius:16px;display:flex;align-items:center;gap:.75rem;font-weight:700;box-shadow:0 10px 30px #10b98166;animation:toastSlideIn .4s cubic-bezier(.16,1,.3,1);z-index:5000}@keyframes toastSlideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media(max-width:768px){.reminder-container{padding:2rem 1rem}.reminder-header{flex-direction:column;align-items:stretch;gap:1.5rem;margin-bottom:2.5rem}.reminder-title{font-size:2.25rem}.reminder-grid{grid-template-columns:1fr}.reminder-card{flex-direction:column;align-items:stretch;padding:1.75rem}.reminder-actions{margin-left:0;margin-top:1.5rem;justify-content:flex-end}.form-row{grid-template-columns:1fr;gap:0}}.puzzle-container{height:100%;display:flex;flex-direction:column;background:var(--bg-main);padding:3rem 2rem;overflow-y:auto}.puzzle-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:3rem;max-width:1000px;width:100%;margin-left:auto;margin-right:auto}.puzzle-title{font-size:3rem;font-weight:950;color:var(--text-main);letter-spacing:-.04em;margin-bottom:.5rem}.puzzle-subtitle{font-size:1.2rem;color:var(--text-muted);font-weight:500}.btn-shuffle{padding:1rem 2rem;background:#fff;color:var(--text-main);border:1px solid rgba(0,0,0,.1);border-radius:18px;font-weight:800;cursor:pointer;display:flex;align-items:center;gap:.8rem;box-shadow:0 10px 20px #00000008;transition:all .3s cubic-bezier(.16,1,.3,1)}.btn-shuffle:hover{transform:translateY(-2px);box-shadow:0 15px 30px #00000014}.puzzle-content{flex:1;max-width:1000px;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:2.5rem}.stats-panel{display:flex;gap:2rem}.stat-card{background:#fff;padding:1.5rem 2.5rem;border-radius:24px;display:flex;align-items:center;gap:1.25rem;box-shadow:0 10px 30px #00000008;border:1px solid rgba(0,0,0,.05)}.stat-icon{color:var(--accent-primary)}.stat-label{display:block;font-size:.85rem;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.05em}.stat-value{display:block;font-size:1.5rem;font-weight:900;color:var(--text-main)}.puzzle-board-container{background:#e5e7eb;padding:1rem;border-radius:40px;position:relative;box-shadow:inset 0 0 40px #0000000d;aspect-ratio:1;max-width:600px;margin:0 auto}.puzzle-grid{display:grid;gap:.75rem;height:100%;width:100%}.puzzle-tile{background:#fff;border-radius:20px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 10px 25px #0000001a;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.puzzle-tile:hover{transform:scale(.98)}.puzzle-tile.void{background:transparent;box-shadow:none;cursor:default}.puzzle-tile.won{border-radius:0;box-shadow:none}.tile-hint{position:absolute;top:8px;left:8px;background:#ffffffe6;padding:2px 8px;border-radius:100px;font-size:.75rem;font-weight:900;color:#1a1a1a;box-shadow:0 2px 10px #0000001a}.win-overlay,.start-overlay{position:absolute;inset:0;background:#ffffffd9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:40px;display:flex;align-items:center;justify-content:center;z-index:10;animation:fadeIn .4s ease-out}.win-content{text-align:center}.win-content h2{font-size:2.5rem;font-weight:950;margin:1.5rem 0 .5rem;color:var(--text-main)}.win-content p{font-size:1.25rem;color:var(--text-muted);margin-bottom:2.5rem}.trophy-gold{color:#fbbf24;filter:drop-shadow(0 0 20px rgba(251,191,36,.4))}.btn-start-luxury{padding:1.5rem 3rem;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:#fff;border:none;border-radius:24px;font-size:1.5rem;font-weight:900;cursor:pointer;display:flex;align-items:center;gap:1.25rem;box-shadow:0 20px 40px #4f46e54d;transition:all .3s cubic-bezier(.16,1,.3,1)}.btn-start-luxury:hover{transform:scale(1.05);box-shadow:0 30px 60px #4f46e566}@media(max-width:768px){.puzzle-container{padding:2rem 1rem}.puzzle-header{flex-direction:column;align-items:stretch;gap:1.5rem;margin-bottom:2.5rem}.puzzle-title{font-size:2.25rem}.stats-panel{gap:1rem}.stat-card{padding:1rem;flex:1;justify-content:center}.stat-value{font-size:1.2rem}}.discovery-container{height:100%;display:flex;flex-direction:column;background:var(--bg-main);padding:3rem 2rem;overflow-y:auto}.discovery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4rem;max-width:1200px;width:100%;margin-left:auto;margin-right:auto}.discovery-title{font-size:3rem;font-weight:950;color:var(--text-main);letter-spacing:-.04em;margin-bottom:.5rem}.discovery-subtitle{font-size:1.2rem;color:var(--text-muted);font-weight:500}.search-box-luxury{background:#fff;border-radius:20px;padding:.75rem 1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:0 10px 30px #00000008;border:1px solid rgba(0,0,0,.05);min-width:380px}.search-box-luxury input{border:none;outline:none;width:100%;font-size:1rem;font-family:inherit;font-weight:600}.search-icon{color:var(--text-muted)}.discovery-content{flex:1;max-width:1200px;width:100%;margin:0 auto}.discovery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2.5rem}.profile-card{background:#fff;border-radius:32px;overflow:hidden;box-shadow:0 10px 40px #0000000a;border:1px solid rgba(0,0,0,.05);transition:all .5s cubic-bezier(.16,1,.3,1);position:relative;display:flex;flex-direction:column}.profile-card:hover{transform:translateY(-12px);box-shadow:0 30px 70px #0000001a}.card-media{height:320px;position:relative;overflow:hidden}.friend-avatar{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}.profile-card:hover .friend-avatar{transform:scale(1.1)}.status-dot{position:absolute;top:20px;right:20px;width:14px;height:14px;border-radius:50%;border:3px solid white;box-shadow:0 0 10px #0003}.status-dot.online{background:#10b981}.status-dot.offline{background:#94a3b8}.role-badge{position:absolute;bottom:20px;left:20px;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:6px 12px;border-radius:100px;font-size:.75rem;font-weight:900;color:#1a1a1a;display:flex;align-items:center;gap:.5rem;text-transform:uppercase;letter-spacing:.05em;box-shadow:0 4px 15px #0000001a}.card-info{padding:2rem;flex:1}.friend-name{font-size:1.5rem;font-weight:900;color:var(--text-main);margin-bottom:.4rem}.friend-location{font-size:.9rem;color:var(--text-muted);font-weight:700;display:flex;align-items:center;gap:.4rem;margin-bottom:1.25rem}.friend-bio{font-size:1rem;line-height:1.5;color:var(--text-muted);font-weight:500}.card-actions{padding:0 2rem 2rem;display:flex;gap:1rem}.btn-connect{flex:1;padding:.9rem;border-radius:16px;font-weight:800;cursor:pointer;transition:all .3s;border:none;background:#f1f5f9;color:var(--text-main)}.btn-connect:hover{background:#e2e8f0}.btn-connect.active{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:#fff;box-shadow:0 10px 20px -5px #4f46e566}.btn-message{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:#f1f5f9;border:none;cursor:pointer;transition:all .2s}.btn-message:hover{background:#e0f2fe;color:#4f46e5}.empty-discovery{text-align:center;padding:100px 0;color:var(--text-muted)}.empty-discovery h3{font-size:2rem;margin:1.5rem 0 .5rem;color:var(--text-main)}@media(max-width:768px){.discovery-container{padding:2rem 1rem}.discovery-header{flex-direction:column;align-items:stretch;gap:2rem;margin-bottom:3rem}.discovery-title{font-size:2.25rem}.search-box-luxury{min-width:0}.discovery-grid{grid-template-columns:1fr}}.login-container{min-height:100vh;background-color:#f8fafc;display:flex;align-items:center;justify-content:center;padding:1rem}.login-card-wrapper{width:100%;max-width:28rem;animation:fadeInUp .5s ease-out}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0}.login-header p{color:#64748b;margin-top:.5rem;font-size:1rem}.login-card{background-color:#fff;border-radius:.75rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;border:1px solid #e2e8f0;overflow:hidden;padding:1.5rem}.login-form{position:relative;display:flex;flex-direction:column;gap:1.5rem}.form-group-stack{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:.875rem;font-weight:500;color:#334155}.input-wrapper{position:relative}.input-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:1.25rem;height:1.25rem;color:#94a3b8}.form-input{width:100%;padding:.5rem 1rem .5rem 2.5rem;background-color:#fff;border:1px solid #cbd5e1;border-radius:.5rem;color:#1e293b;outline:none;transition:all .2s;font-size:1rem;box-sizing:border-box}.form-input:focus{ring:2px solid #3b82f6;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.submit-btn-wrapper{padding-top:.5rem}.submit-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;background-color:#2563eb;color:#fff;padding-top:.625rem;padding-bottom:.625rem;border-radius:.5rem;font-weight:500;transition:all .2s;border:none;cursor:pointer}.submit-btn:hover{background-color:#1d4ed8}.submit-btn:disabled{opacity:.7;cursor:not-allowed}.forgot-password-wrapper{display:flex;justify-content:center;padding-top:.5rem}.forgot-password-link{font-size:.875rem;color:#2563eb;font-weight:500;display:flex;align-items:center;gap:.25rem;background:none;border:none;cursor:pointer;transition:all .2s}.forgot-password-link:hover{color:#1d4ed8;text-decoration:underline}.rotate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-message{padding:.75rem 1rem;border-radius:.5rem;font-size:.875rem;display:flex;align-items:center;gap:.5rem;animation:fadeInUp .3s ease-out}.auth-message.error{background-color:#fff1f2;border:1px solid #fecdd3;color:#e11d48}.auth-message.success{background-color:#ecfdf5;border:1px solid #a7f3d0;color:#059669}:root{--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--bg-hover: #f1f3f5;--text-primary: #212529;--text-secondary: #6c757d;--accent-primary: #6366f1;--accent-secondary: #a855f7;--border-color: #dee2e6;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .15)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100dvh;margin:0;overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-container{display:flex;height:100dvh;width:100%;margin:0;position:relative;background:var(--bg-primary)}.section-container{display:flex;flex-direction:column;height:100%;width:100%;background:var(--bg-primary)}.section-header{padding:1.5rem;border-bottom:1px solid var(--border-color);background:var(--bg-primary);flex-shrink:0}.section-header h1{font-size:1.5rem;font-weight:600;color:var(--text-primary)}.section-content{flex:1;overflow-y:auto;background:var(--bg-primary)}.section-footer{flex-shrink:0;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.main-content{flex:1;overflow:hidden;position:relative}@media(min-width:769px){.app-container{flex-direction:row}}@media(max-width:768px){.app-container{flex-direction:column}.main-content{padding-bottom:70px}.section-header h1{font-size:1.25rem}}.text-center{text-align:center}.text-muted{color:var(--text-secondary)}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}*{scrollbar-width:thin;scrollbar-color:var(--border-color) var(--bg-secondary)}
