:root{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--bg-card:#1e293b;--bg-hover:#334155;--bg-input:#1e293b;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--accent:#38bdf8;--accent-hover:#7dd3fc;--accent-muted:#38bdf826;--border:#334155;--border-light:#475569;--success:#34d399;--warning:#fbbf24;--danger:#f87171;--sidebar-width:240px;--radius:8px;--radius-lg:12px;--shadow:0 4px 6px -1px #0000004d;--transition:0.2s ease}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background:#0f172a;background:var(--bg-primary);color:#f1f5f9;color:var(--text-primary);font-family:Inter,-apple-system,sans-serif;line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:Space Grotesk,sans-serif;font-weight:600}a{color:#38bdf8;color:var(--accent);text-decoration:none}a:hover{color:#7dd3fc;color:var(--accent-hover)}.app-layout{display:flex;min-height:100vh}.sidebar{background:#1e293b;background:var(--bg-secondary);border-right:1px solid #334155;border-right:1px solid var(--border);bottom:0;display:flex;flex-direction:column;left:0;padding:24px 0;position:fixed;top:0;transition:transform .2s ease;transition:transform var(--transition);width:240px;width:var(--sidebar-width);z-index:100}.sidebar-logo{border-bottom:1px solid #334155;border-bottom:1px solid var(--border);margin-bottom:16px;padding:0 24px 24px}.brand-logo{align-items:center;display:inline-flex;gap:14px}.brand-logo-copy{min-width:0}.brand-logo h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#f8fafc,#38bdf8);background:linear-gradient(135deg,#f8fafc,var(--accent));-webkit-background-clip:text;background-clip:text;font-size:1.5rem;line-height:1}.brand-logo span{color:#64748b;color:var(--text-muted);display:block;font-size:.75rem;letter-spacing:.12em;margin-top:6px;text-transform:uppercase}.brand-logo-mark{border-radius:16px;box-shadow:0 10px 30px #0ea5e91f;display:grid;flex:0 0 auto;height:52px;place-items:center;width:52px}.brand-logo-mark svg{height:100%;overflow:visible;width:100%}.brand-logo-mark-bg{fill:#020617;stroke:#7dd3fc47;stroke-width:2}.brand-logo-mark-ring{fill:none;stroke:#7dd3fc;stroke-width:5}.brand-logo-mark-cut{stroke:#f8fafc;stroke-width:4.5;stroke-linecap:round;opacity:.95}.brand-logo-mark-dot{fill:#38bdf8}.brand-logo-compact h1{font-size:1.45rem}.brand-logo-compact span{margin-top:5px}.sidebar-nav{flex:1 1;padding:0 12px}.sidebar-nav a{align-items:center;border-radius:8px;border-radius:var(--radius);color:#94a3b8;color:var(--text-secondary);display:flex;font-size:.9rem;gap:12px;padding:10px 12px;transition:all .2s ease;transition:all var(--transition)}.sidebar-nav a.active,.sidebar-nav a:hover{background:#38bdf826;background:var(--accent-muted);color:#38bdf8;color:var(--accent)}.sidebar-nav a .mdi{font-size:1.2rem;text-align:center;width:24px}.sidebar-stats{border-top:1px solid #334155;border-top:1px solid var(--border);color:#64748b;color:var(--text-muted);font-size:.8rem;padding:16px 24px}.sidebar-stats .stat-row{display:flex;justify-content:space-between;margin-bottom:4px}.sidebar-stats .stat-value{color:#94a3b8;color:var(--text-secondary)}.main-content{flex:1 1;margin-left:240px;margin-left:var(--sidebar-width);min-height:100vh;padding:32px}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.page-header h2{font-size:1.75rem}.btn{align-items:center;border:1px solid #0000;border-radius:8px;border-radius:var(--radius);box-sizing:border-box;cursor:pointer;display:inline-flex;font-family:Inter,sans-serif;font-size:.875rem;font-weight:500;gap:8px;line-height:1.4;padding:8px 16px;text-decoration:none;transition:all .2s ease;transition:all var(--transition);white-space:nowrap}.btn-primary{background:#38bdf8;background:var(--accent);color:#0f172a;color:var(--bg-primary);font-weight:600}.btn-primary:hover{background:#7dd3fc;background:var(--accent-hover);box-shadow:0 0 12px #38bdf866}.btn-secondary{background:#334155;background:var(--bg-tertiary);border:1px solid #475569;border:1px solid var(--border-light);color:#f1f5f9;color:var(--text-primary);font-weight:600}.btn-secondary:hover{background:#334155;background:var(--bg-hover);border-color:#38bdf8;border-color:var(--accent);color:#38bdf8;color:var(--accent)}.btn-danger{background:#f8717126;border:1px solid #f871714d;color:#f87171;color:var(--danger)}.btn-danger:hover{background:#f8717140}.btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.5}.btn-sm{font-size:.8rem;padding:4px 10px}.btn-icon{padding:8px}.photo-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.photo-card{background:#1e293b;background:var(--bg-card);border:1px solid #334155;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius-lg);cursor:pointer;overflow:hidden;transition:all .2s ease;transition:all var(--transition)}.photo-card:hover{border-color:#38bdf8;border-color:var(--accent);box-shadow:0 4px 6px -1px #0000004d;box-shadow:var(--shadow);transform:translateY(-2px)}.photo-card-image{aspect-ratio:1;background:#334155;background:var(--bg-tertiary);overflow:hidden}.photo-card-image img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.photo-card:hover .photo-card-image img{transform:scale(1.05)}.photo-card-info{padding:12px}.photo-card-info .filename{color:#f1f5f9;color:var(--text-primary);font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.photo-card-info .meta{color:#64748b;color:var(--text-muted);font-size:.75rem;margin-top:4px}.photo-card-tags{display:flex;flex-wrap:wrap;gap:4px;padding:0 12px 12px}.tag-badge{align-items:center;border-radius:100px;display:inline-flex;font-size:.7rem;font-weight:500;gap:4px;padding:2px 8px}.tag-badge-system{border:1px dashed #94a3b833}.tag-badge .remove-tag{cursor:pointer;margin-left:2px;opacity:.7}.tag-badge .remove-tag:hover{opacity:1}.tag-has-tooltip{position:relative}.tag-has-tooltip:after{background:#0f172a;background:var(--bg-primary);border:1px solid #334155;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);bottom:calc(100% + 8px);box-shadow:0 4px 12px #0000004d;color:#94a3b8;color:var(--text-secondary);content:attr(data-tooltip);font-size:.72rem;font-weight:400;left:50%;line-height:1.4;max-width:280px;opacity:0;padding:6px 10px;pointer-events:none;position:absolute;text-align:center;transform:translateX(-50%);transition:opacity .15s ease;white-space:nowrap;white-space:normal;z-index:100}.tag-has-tooltip:hover:after{opacity:1}.upload-dropzone{background:#1e293b;background:var(--bg-secondary);border:2px dashed #475569;border:2px dashed var(--border-light);border-radius:12px;border-radius:var(--radius-lg);cursor:pointer;padding:48px;text-align:center;transition:all .2s ease;transition:all var(--transition)}.upload-dropzone.active{background:#38bdf826;background:var(--accent-muted);border-color:#38bdf8;border-color:var(--accent)}.upload-dropzone .mdi{color:#38bdf8;color:var(--accent);display:block;font-size:3rem;margin-bottom:12px}.upload-dropzone h3{color:#f1f5f9;color:var(--text-primary);margin-bottom:8px}.upload-dropzone p{color:#64748b;color:var(--text-muted);font-size:.9rem}.upload-progress-list{margin-top:24px}.upload-progress-item{align-items:center;background:#1e293b;background:var(--bg-card);border:1px solid #334155;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);display:flex;gap:12px;margin-bottom:8px;padding:12px 16px}.upload-progress-item .filename{flex:1 1;font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-progress-bar{background:#334155;background:var(--bg-tertiary);border-radius:3px;height:6px;overflow:hidden;width:120px}.upload-progress-bar-fill{background:#38bdf8;background:var(--accent);border-radius:3px;height:100%;transition:width .3s ease}.upload-progress-bar-fill.complete{background:#34d399;background:var(--success)}.upload-progress-bar-fill.error{background:#f87171;background:var(--danger)}.upload-status{font-size:.75rem;min-width:60px;text-align:right}.upload-status.complete{color:#34d399;color:var(--success)}.upload-status.error{color:#f87171;color:var(--danger)}.photo-detail{grid-gap:24px;align-items:start;display:grid;gap:24px;grid-template-columns:1fr 380px}.photo-detail-image{background:#1e293b;background:var(--bg-secondary);border:1px solid #334155;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius-lg);overflow:hidden}.photo-detail-image img{display:block;max-height:75vh;object-fit:contain;width:100%}.photo-detail-sidebar{display:flex;flex-direction:column;gap:16px}.exif-panel{background:#1e293b;background:var(--bg-card);border:1px solid #334155;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius-lg);overflow:hidden}.exif-panel-header{align-items:center;border-bottom:1px solid #334155;border-bottom:1px solid var(--border);display:flex;font-family:Space Grotesk,sans-serif;font-weight:600;gap:8px;padding:16px}.exif-panel-body{padding:16px}.exif-row{border-bottom:1px solid #33415580;display:flex;font-size:.85rem;justify-content:space-between;padding:6px 0}.exif-row:last-child{border-bottom:none}.exif-row .label{color:#64748b;color:var(--text-muted)}.exif-row .value{color:#f1f5f9;color:var(--text-primary);font-weight:500}.map-container{border:1px solid #334155;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius-lg);overflow:hidden}.map-full{height:calc(100vh - 128px)}.map-small{height:200px}.map-locations{border-radius:12px;border-radius:var(--radius-lg);height:400px}.filter-bar{background:#1e293b;background:var(--bg-secondary);border-radius:12px;border-radius:var(--radius-lg);display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px;padding:16px}.filter-bar,.filter-bar input,.filter-bar select{border:1px solid #334155;border:1px solid var(--border)}.filter-bar input,.filter-bar select{background:#1e293b;background:var(--bg-input);border-radius:8px;border-radius:var(--radius);color:#f1f5f9;color:var(--text-primary);font-family:Inter,sans-serif;font-size:.875rem;padding:8px 12px}.filter-bar input:focus,.filter-bar select:focus{border-color:#38bdf8;border-color:var(--accent);outline:none}.filter-bar input::placeholder{color:#64748b;color:var(--text-muted)}.album-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.album-card{background:#1e293b;background:var(--bg-card);border:1px solid #334155;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius-lg);cursor:pointer;overflow:hidden;transition:all .2s ease;transition:all var(--transition)}.album-card:hover{border-color:#38bdf8;border-color:var(--accent);box-shadow:0 4px 6px -1px #0000004d;box-shadow:var(--shadow);transform:translateY(-2px)}.album-card-cover{align-items:center;aspect-ratio:16/10;background:#334155;background:var(--bg-tertiary);display:flex;justify-content:center}.album-card-cover img{height:100%;object-fit:cover;width:100%}.album-card-cover .mdi{color:#64748b;color:var(--text-muted);font-size:3rem}.album-card-info{padding:16px}.album-card-info h3{font-size:1rem;margin-bottom:4px}.album-card-info .meta{color:#64748b;color:var(--text-muted);font-size:.8rem}.duplicate-group{background:#1e293b;background:var(--bg-card);border:1px solid #334155;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius-lg);margin-bottom:20px;padding:20px}.duplicate-group h3{font-size:1rem;margin-bottom:16px}.duplicate-photos{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.duplicate-photo{border:2px solid #334155;border:2px solid var(--border);border-radius:8px;border-radius:var(--radius);overflow:hidden;transition:border-color .2s ease;transition:border-color var(--transition)}.duplicate-photo.best{border-color:#34d399;border-color:var(--success)}.duplicate-photo img{aspect-ratio:1;object-fit:cover;width:100%}.duplicate-photo-info{font-size:.8rem;padding:12px}.duplicate-photo-info .meta-row{display:flex;justify-content:space-between;margin-bottom:4px}.tag-input-container{position:relative}.tag-input{align-items:center;background:#1e293b;background:var(--bg-input);border:1px solid #334155;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);display:flex;flex-wrap:wrap;gap:6px;min-height:42px;padding:8px 12px}.tag-input input{background:none;border:none;color:#f1f5f9;color:var(--text-primary);flex:1 1;font-size:.85rem;min-width:100px;outline:none}.tag-autocomplete{background:#1e293b;background:var(--bg-secondary);border:1px solid #334155;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);left:0;margin-top:4px;max-height:180px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:50}.tag-autocomplete-item{align-items:center;cursor:pointer;display:flex;font-size:.85rem;gap:8px;padding:8px 12px}.tag-autocomplete-item:hover{background:#334155;background:var(--bg-hover)}.tag-color-dot{border-radius:50%;height:10px;width:10px}.lightbox-overlay{align-items:center;background:#000000e6;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.lightbox-overlay img{max-height:90vh;max-width:90vw;object-fit:contain}.lightbox-close{background:none;border:none;color:#fff;cursor:pointer;font-size:2rem;padding:8px;position:absolute;right:16px;top:16px}.modal-overlay{align-items:center;background:#0009;display:flex;inset:0;justify-content:center;position:fixed;z-index:500}.modal{background:#1e293b;background:var(--bg-secondary);border:1px solid #334155;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius-lg);max-width:600px;min-width:400px;padding:24px}.modal h3{margin-bottom:16px}.modal input,.modal textarea{background:#1e293b;background:var(--bg-input);border:1px solid #334155;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);color:#f1f5f9;color:var(--text-primary);font-family:Inter,sans-serif;font-size:.875rem;margin-bottom:12px;padding:8px 12px;width:100%}.modal textarea{min-height:80px;resize:vertical}.modal input:focus,.modal textarea:focus{border-color:#38bdf8;border-color:var(--accent);outline:none}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.empty-state{color:#64748b;color:var(--text-muted);padding:64px;text-align:center}.empty-state .mdi{display:block;font-size:4rem;margin-bottom:16px;opacity:.5}.empty-state h3{color:#94a3b8;color:var(--text-secondary);margin-bottom:8px}@media (max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.main-content{margin-left:0;padding:16px}.photo-detail{grid-template-columns:1fr}.photo-grid{gap:8px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.mobile-menu-btn{display:block!important}}.mobile-menu-btn{background:#1e293b;background:var(--bg-secondary);border:1px solid #334155;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);color:#f1f5f9;color:var(--text-primary);cursor:pointer;display:none;font-size:1.2rem;left:12px;padding:8px 12px;position:fixed;top:12px;z-index:200}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.text-muted{color:#64748b;color:var(--text-muted)}.text-sm{font-size:.85rem}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#0f172a;background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:#334155;background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#475569;background:var(--border-light)}.spinner{animation:spin .8s linear infinite;border:3px solid #334155;border-top-color:#38bdf8;border:3px solid var(--border);border-radius:50%;border-top-color:var(--accent);height:32px;margin:32px auto;width:32px}@keyframes spin{to{transform:rotate(1turn)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.auth-page{align-items:center;background:#0f172a;background:var(--bg-primary);display:flex;justify-content:center;min-height:100vh;padding:16px}.auth-card{background:#1e293b;background:var(--bg-secondary);border:1px solid #334155;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 8px 32px #0000004d;max-width:440px;padding:40px;width:100%}.auth-header{margin-bottom:32px;text-align:center}.auth-brand{display:flex;justify-content:center;margin-bottom:14px}.auth-brand .brand-logo-mark{border-radius:18px;box-shadow:0 16px 48px #0ea5e924;height:64px;width:64px}.auth-brand h1{font-size:2rem}.auth-header p{color:#64748b;color:var(--text-muted);font-size:.9rem}.auth-field{margin-bottom:16px}.auth-field label{color:#94a3b8;color:var(--text-secondary);display:block;font-size:.85rem;font-weight:500;margin-bottom:6px}.auth-field input{background:#1e293b;background:var(--bg-input);border:1px solid #334155;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);color:#f1f5f9;color:var(--text-primary);font-family:Inter,sans-serif;font-size:.9rem;padding:10px 14px;transition:border-color .2s ease;transition:border-color var(--transition);width:100%}.auth-field input:focus{border-color:#38bdf8;border-color:var(--accent);outline:none}.auth-field input::placeholder{color:#64748b;color:var(--text-muted)}.auth-submit{font-size:.95rem;justify-content:center;margin-top:8px;padding:12px;width:100%}.auth-submit:disabled{cursor:not-allowed;opacity:.6}.auth-error{background:#f871711f;border:1px solid #f871714d;border-radius:8px;border-radius:var(--radius);color:#f87171;color:var(--danger);font-size:.85rem;margin-bottom:16px;padding:10px 14px;text-align:center}.auth-divider{align-items:center;display:flex;gap:12px;margin:24px 0}.auth-divider:after,.auth-divider:before{background:#334155;background:var(--border);content:"";flex:1 1;height:1px}.auth-divider span{color:#64748b;color:var(--text-muted);font-size:.8rem;white-space:nowrap}.auth-social-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.auth-social-btn{align-items:center;background:#334155;background:var(--bg-tertiary);border:1px solid #334155;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);color:#94a3b8;color:var(--text-secondary);cursor:not-allowed;display:flex;font-family:Inter,sans-serif;font-size:.85rem;gap:8px;justify-content:center;opacity:.45;padding:10px 12px;transition:all .2s ease;transition:all var(--transition)}.auth-social-btn .mdi{font-size:1.2rem}.auth-social-btn:disabled{opacity:.45}.auth-footer{color:#64748b;color:var(--text-muted);font-size:.85rem;margin-top:24px;text-align:center}.auth-footer a{font-weight:500}.sidebar-user{border-top:1px solid #334155;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px;padding:16px 24px}.sidebar-user-info{align-items:center;color:#94a3b8;color:var(--text-secondary);display:flex;font-size:.85rem;gap:8px}.sidebar-user-info .mdi{color:#38bdf8;color:var(--accent);font-size:1.4rem}.sidebar-user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user .btn{justify-content:center;width:100%}.dashboard-hero-header{margin-bottom:24px}.dashboard-hero-greeting{font-family:Space Grotesk,sans-serif;font-size:1.8rem;font-weight:700;letter-spacing:-.5px;margin-bottom:4px}.dashboard-hero-name{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#38bdf8,#a78bfa,#f472b6);-webkit-background-clip:text;background-clip:text}.dashboard-hero-sub{color:#94a3b8;color:var(--text-secondary);font-size:.9rem}.dashboard-hero-stats{display:flex;gap:12px;margin-bottom:24px;overflow-x:auto;padding-bottom:4px}.dashboard-hero-stat{align-items:center;background:#1e293b;background:var(--bg-secondary);border:1px solid #334155;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius-lg);display:flex;flex:1 1;flex-direction:column;gap:6px;min-width:120px;padding:18px 12px;transition:border-color .2s,transform .2s}.dashboard-hero-stat.clickable{cursor:pointer}.dashboard-hero-stat.clickable:hover{border-color:#38bdf8;border-color:var(--accent);transform:translateY(-3px)}.dashboard-hero-stat-icon{border-radius:12px;display:grid;font-size:1.3rem;height:42px;place-items:center;width:42px}.dashboard-hero-stat-value{font-family:Space Grotesk,sans-serif;font-size:1.5rem;font-weight:700;line-height:1}.dashboard-hero-stat-label{color:#64748b;color:var(--text-muted);font-size:.72rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.dashboard-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.dashboard-section-header h3{align-items:center;display:flex;font-size:1rem}.dashboard-section-pct{font-family:Space Grotesk,sans-serif;font-size:1.4rem;font-weight:700}.dashboard-welcome{margin-bottom:24px}.dashboard-empty{align-items:center;display:flex;flex-direction:column;gap:12px;justify-content:center;min-height:60vh;text-align:center}.dashboard-overview{align-items:stretch;display:flex;gap:24px;margin-bottom:32px}.dashboard-ring-container{align-items:center;background:#1e293b;background:var(--bg-secondary);border:1px solid #334155;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius-lg);display:flex;flex-direction:column;flex-shrink:0;justify-content:center;min-width:200px;padding:24px 28px}.dashboard-ring-text{font-family:Space Grotesk,sans-serif;font-size:2.4rem;font-weight:700}.dashboard-ring-label{color:#94a3b8;color:var(--text-secondary);font-size:.82rem;font-weight:500;margin-top:12px}.dashboard-categories-grid{grid-gap:12px;display:grid;flex:1 1;gap:12px;grid-template-columns:1fr 1fr}.dashboard-category-card{background:#1e293b;background:var(--bg-secondary);border:1px solid #334155;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:10px;padding:16px}.dashboard-category-header{align-items:center;display:flex;gap:8px}.dashboard-category-title{font-size:.9rem;font-weight:600}.dashboard-category-footer{align-items:center;display:flex;justify-content:space-between}.dashboard-category-fraction{color:#94a3b8;color:var(--text-secondary);font-size:.78rem}.progress-bar{background:#334155;background:var(--bg-tertiary);border-radius:3px;height:6px;overflow:hidden}.progress-fill{border-radius:3px;height:100%;min-width:0;transition:width .6s ease,background .4s ease}.dashboard-section{margin-bottom:28px}.dashboard-recent-strip{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.dashboard-recent-thumb{aspect-ratio:1;border:2px solid #334155;border:2px solid var(--border);border-radius:12px;border-radius:var(--radius-lg);cursor:pointer;overflow:hidden;position:relative;transition:border-color .2s,transform .2s,box-shadow .2s}.dashboard-recent-thumb:hover{border-color:#38bdf8;border-color:var(--accent);box-shadow:0 12px 32px #0000004d;transform:translateY(-4px)}.dashboard-recent-thumb img{display:block;height:100%;object-fit:cover;width:100%}.dashboard-medals{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.dashboard-medal{align-items:center;display:flex;flex-direction:column;position:relative;transition:transform .2s ease}.dashboard-medal.unlocked:hover{transform:translateY(-4px)}.dashboard-medal-tooltip{background:#0f172a;background:var(--bg-primary);border:1px solid #334155;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);bottom:100%;box-shadow:0 8px 24px #0006;display:flex;flex-direction:column;gap:2px;left:50%;opacity:0;padding:8px 12px;pointer-events:none;position:absolute;transform:translateX(-50%) translateY(4px);transition:opacity .2s,transform .2s;white-space:nowrap;z-index:20}.dashboard-medal-tooltip strong{color:#f1f5f9;color:var(--text-primary);font-size:.78rem}.dashboard-medal-tooltip span{color:#94a3b8;color:var(--text-secondary);font-size:.72rem}.dashboard-medal:hover .dashboard-medal-tooltip{opacity:1;transform:translateX(-50%) translateY(-4px)}.dashboard-medal-visual{height:125px;position:relative;width:100px}.dashboard-medal-visual svg{display:block;height:100%;width:100%}.dashboard-medal-icon{font-size:1.9rem;left:50%;line-height:1;position:absolute;top:28px;transform:translateX(-50%)}.dashboard-medal.locked .dashboard-medal-icon{font-size:1.3rem;top:33px}.dashboard-medal-shimmer{border-radius:50%;height:70px;left:15px;overflow:hidden;pointer-events:none;position:absolute;top:10px;width:70px}.dashboard-medal-shimmer:after{animation:medalShimmer 3s ease-in-out infinite;background:linear-gradient(90deg,#0000,#ffffff26,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;width:50%}@keyframes medalShimmer{0%,to{left:-100%}50%{left:150%}}@keyframes achievement-pulse{0%{transform:scale(1)}to{transform:scale(1.15)}}.dashboard-medal-title{font-size:.78rem;font-weight:600;line-height:1.3;margin-top:-2px;text-align:center}.dashboard-medal-tooltip-status{color:#34d399!important;color:var(--success)!important;font-weight:600}.magic-box{background:linear-gradient(135deg,#38bdf808,#a855f708);border:2px dashed #334155;border:2px dashed var(--border);border-radius:20px;margin-bottom:32px;overflow:hidden;padding:40px 32px;position:relative;transition:border-color .3s ease}.magic-box:hover{border-color:#38bdf8;border-color:var(--accent)}.magic-box.drag-over{background:linear-gradient(135deg,#38bdf814,#a855f714);border-color:#a78bfa;border-style:solid;transform:scale(1.01)}.magic-box.processing,.magic-box.reveal{border-color:#38bdf84d;border-style:solid;cursor:default}.magic-box.reveal.done{border-color:#34d399;border-color:var(--success)}.magic-box-inner{align-items:center;display:flex;flex-direction:column;position:relative;text-align:center;z-index:2}.magic-box-icon{background:linear-gradient(135deg,#38bdf81f,#a855f71f);border-radius:50%;display:grid;height:72px;margin-bottom:16px;place-items:center;width:72px}.magic-box-icon .mdi{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#38bdf8,#a78bfa);-webkit-background-clip:text;background-clip:text;font-size:2rem}.magic-box-icon.scanning{animation:magicPulse 1.5s ease-in-out infinite}.magic-box-icon.scanning .mdi{animation:magicSpin 3s linear infinite}.magic-box-icon.done{background:linear-gradient(135deg,#34d3991f,#38bdf81f)}.magic-box-icon.done .mdi{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#34d399,#38bdf8);-webkit-background-clip:text;background-clip:text}@keyframes magicPulse{0%,to{box-shadow:0 0 0 0 #38bdf833;transform:scale(1)}50%{box-shadow:0 0 30px 10px #38bdf81a;transform:scale(1.05)}}@keyframes magicSpin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.magic-box-title{color:#f1f5f9;color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:1.2rem;font-weight:600;margin-bottom:8px}.magic-box-sub{color:#94a3b8;color:var(--text-secondary);font-size:.88rem;line-height:1.6;margin-bottom:12px;max-width:400px}.magic-box-hint{align-items:center;color:#64748b;color:var(--text-muted);display:flex;font-size:.75rem;gap:4px}.magic-box-hint .mdi{font-size:1rem}.magic-box-buttons{display:flex;gap:10px;margin-bottom:12px;position:relative;z-index:3}.magic-box-browse{align-items:center;background:linear-gradient(135deg,#38bdf8,#818cf8);border:none;border-radius:100px;color:#fff;cursor:pointer;display:inline-flex;font-family:Inter,sans-serif;font-size:.82rem;font-weight:600;gap:6px;padding:9px 20px;transition:transform .2s,box-shadow .2s,background .2s}.magic-box-browse:hover{box-shadow:0 4px 16px #38bdf84d;transform:translateY(-1px)}.magic-box-browse.folder{background:#ffffff0f;border:1px solid #ffffff1a;color:#94a3b8;color:var(--text-secondary)}.magic-box-browse.folder:hover{background:#ffffff1a;border-color:#fff3;box-shadow:none;color:#f1f5f9;color:var(--text-primary)}.magic-box-glow{background:radial-gradient(circle,#38bdf80f 0,#0000 70%);border-radius:50%;height:300px;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);transition:opacity .5s ease;width:300px;z-index:0}.magic-box-glow.active{animation:glowPulse 2s ease-in-out infinite;background:radial-gradient(circle,#38bdf81f 0,#a855f70f 50%,#0000 70%)}.magic-box-glow.done{background:radial-gradient(circle,#34d3991f 0,#0000 70%)}@keyframes glowPulse{0%,to{opacity:.6;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.2)}}.magic-box-particles{inset:0;overflow:hidden;pointer-events:none;position:absolute;z-index:1}.magic-particle{animation:particleFloat ease-in-out infinite;border-radius:50%;contain:strict;opacity:.15;position:absolute;will-change:transform,opacity}@keyframes particleFloat{0%,to{opacity:.08;transform:translateZ(0)}50%{opacity:.25;transform:translate3d(10px,-18px,0)}}.magic-progress-bar{background:#334155;background:var(--bg-tertiary);border-radius:3px;height:6px;margin:12px 0 8px;max-width:360px;overflow:hidden;width:100%}.magic-progress-fill{background:linear-gradient(90deg,#38bdf8,#a78bfa);border-radius:3px;height:100%;transition:width .3s ease}.magic-progress-label{color:#64748b;color:var(--text-muted);font-size:.78rem;margin-bottom:20px}.magic-discovery-grid{display:flex;flex-wrap:wrap;gap:28px;justify-content:center;margin-top:8px}.magic-discovery-grid.large{gap:36px;margin-top:16px}.magic-discovery-stat{align-items:center;display:flex;flex-direction:column;gap:2px}.magic-discovery-value{font-family:Space Grotesk,sans-serif;font-size:1.8rem;font-weight:700;line-height:1;transition:all .3s ease}.magic-discovery-grid.large .magic-discovery-value{font-size:2.2rem}.magic-discovery-label{color:#64748b;color:var(--text-muted);font-size:.72rem;font-weight:500;letter-spacing:.3px;text-transform:uppercase}.magic-box-actions{display:flex;gap:10px;margin-top:24px}.magic-failed-list{background:#ef44440f;border:1px solid #ef444426;border-radius:8px;border-radius:var(--radius);margin-top:16px;max-width:420px;padding:12px 14px;text-align:left;width:100%}.magic-failed-header{align-items:center;color:#f87171;color:var(--danger);display:flex;font-size:.82rem;font-weight:600;gap:6px;margin-bottom:8px}.magic-failed-item{align-items:center;border-top:1px solid #ffffff0a;display:flex;font-size:.78rem;gap:10px;justify-content:space-between;padding:5px 0}.magic-failed-name{color:#f1f5f9;color:var(--text-primary);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.magic-failed-reason{color:#64748b;color:var(--text-muted);flex-shrink:0;font-size:.72rem}.landing{background:#060b18;min-height:100vh;overflow-x:hidden;position:relative}.landing-orb{border-radius:50%;filter:blur(100px);pointer-events:none;position:fixed;z-index:0}.landing-orb-1{animation:orbFloat1 12s ease-in-out infinite alternate;background:#38bdf814;height:600px;left:-150px;top:-120px;width:600px}.landing-orb-2{animation:orbFloat2 15s ease-in-out infinite alternate;background:#a855f712;bottom:10%;height:500px;right:-100px;width:500px}.landing-orb-3{animation:orbFloat3 10s ease-in-out infinite alternate;background:#34d3990d;height:350px;left:40%;top:50%;width:350px}@keyframes orbFloat1{to{transform:translate(60px,80px) scale(1.1)}}@keyframes orbFloat2{to{transform:translate(-80px,-60px) scale(1.15)}}@keyframes orbFloat3{to{transform:translate(-40px,40px) scale(.9)}}.reveal-on-scroll{opacity:0;transform:translateY(32px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}.reveal-on-scroll.revealed{opacity:1;transform:translateY(0)}.landing-nav{align-items:center;backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);background:#060b18b3;border-bottom:1px solid #ffffff0a;display:flex;justify-content:space-between;left:0;padding:16px 40px;position:fixed;right:0;top:0;z-index:100}.landing-nav-brand{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#38bdf8,#a78bfa);-webkit-background-clip:text;background-clip:text;font-family:Space Grotesk,sans-serif;font-size:1.4rem;font-weight:700;letter-spacing:-.5px}.landing-nav-links{align-items:center;display:flex;gap:8px}.landing-nav-link{background:none;border:none;border-radius:8px;border-radius:var(--radius);color:#94a3b8;color:var(--text-secondary);cursor:pointer;font-family:Inter,sans-serif;font-size:.88rem;padding:8px 16px;transition:color .2s}.landing-nav-link:hover{color:#f1f5f9;color:var(--text-primary)}.landing-nav-cta{background:linear-gradient(135deg,#38bdf8,#818cf8);border:none;border-radius:100px;color:#fff;cursor:pointer;font-family:Inter,sans-serif;font-size:.85rem;font-weight:600;padding:9px 22px;transition:transform .2s,box-shadow .2s}.landing-nav-cta:hover{box-shadow:0 4px 20px #38bdf84d;transform:translateY(-1px)}.landing-hero{align-items:center;display:flex;gap:64px;justify-content:center;margin:0 auto;max-width:1200px;min-height:100vh;padding:100px 48px 60px;position:relative;z-index:1}.landing-hero-content{flex:1 1;max-width:560px}.landing-pill{align-items:center;background:#38bdf814;border:1px solid #38bdf826;border-radius:100px;color:#38bdf8;display:inline-flex;font-size:.78rem;font-weight:600;letter-spacing:.5px;margin-bottom:24px;padding:6px 16px;text-transform:uppercase}.landing-h1{color:#f1f5f9;color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:3.6rem;font-weight:700;letter-spacing:-1.5px;line-height:1.08;margin-bottom:20px}.landing-gradient-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#38bdf8,#a78bfa 50%,#f472b6);-webkit-background-clip:text;background-clip:text}.landing-hero-sub{color:#94a3b8;color:var(--text-secondary);font-size:1.1rem;line-height:1.75;margin-bottom:36px}.landing-hero-actions{align-items:center;display:flex;gap:14px}.landing-btn-primary{align-items:center;background:linear-gradient(135deg,#38bdf8,#818cf8);border:none;border-radius:100px;color:#fff;cursor:pointer;display:inline-flex;font-family:Inter,sans-serif;font-size:.95rem;font-weight:600;gap:8px;padding:14px 32px;transition:transform .2s,box-shadow .2s}.landing-btn-primary:hover{box-shadow:0 8px 32px #38bdf84d;transform:translateY(-2px)}.landing-btn-primary.lg{font-size:1.05rem;padding:18px 40px}.landing-btn-ghost{align-items:center;background:#ffffff0a;border:1px solid #ffffff14;border-radius:100px;color:#94a3b8;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-family:Inter,sans-serif;font-size:.95rem;font-weight:500;gap:8px;padding:14px 28px;transition:background .2s,color .2s,border-color .2s}.landing-btn-ghost:hover{background:#ffffff14;border-color:#ffffff26;color:#f1f5f9;color:var(--text-primary)}.landing-hero-visual{flex:1 1;max-width:480px;position:relative}.landing-hero-img-stack{aspect-ratio:4/3;position:relative;width:100%}.landing-hero-img{border:1px solid #ffffff0f;border-radius:16px;box-shadow:0 20px 60px #00000080;object-fit:cover;position:absolute}.landing-hero-img.img-1{animation:imgFloat1 6s ease-in-out infinite alternate;height:80%;left:0;top:0;width:100%;z-index:1}.landing-hero-img.img-2{animation:imgFloat2 7s ease-in-out infinite alternate;bottom:-8%;height:50%;right:-6%;width:55%;z-index:2}.landing-hero-img.img-3{animation:imgFloat3 5s ease-in-out infinite alternate;border-radius:12px;bottom:5%;height:40%;left:-8%;width:35%;z-index:3}@keyframes imgFloat1{to{transform:translateY(-8px) rotate(.5deg)}}@keyframes imgFloat2{to{transform:translateY(6px) rotate(-1deg)}}@keyframes imgFloat3{to{transform:translateY(-5px) rotate(1deg)}}.landing-stats-ribbon{background:#ffffff03;border-bottom:1px solid #ffffff0a;border-top:1px solid #ffffff0a;display:flex;gap:48px;justify-content:center;padding:48px 24px;position:relative;z-index:1}.landing-stat{text-align:center}.landing-stat-value{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#38bdf8,#a78bfa);-webkit-background-clip:text;background-clip:text;font-family:Space Grotesk,sans-serif;font-size:2rem;font-weight:700}.landing-stat-label{color:#64748b;color:var(--text-muted);font-size:.82rem;letter-spacing:.3px;margin-top:4px}.landing-features{margin:0 auto;max-width:1100px;padding:80px 48px;position:relative;z-index:1}.landing-section-label{color:#38bdf8;font-size:.75rem;font-weight:700;letter-spacing:2px;margin-bottom:12px;text-transform:uppercase}.landing-h2{color:#f1f5f9;color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:2.6rem;font-weight:700;letter-spacing:-1px;line-height:1.12;margin-bottom:56px}.landing-feature-list{display:flex;flex-direction:column;gap:40px}.landing-feat-row{align-items:center;display:flex;gap:48px}.landing-feat-row.reverse{flex-direction:row-reverse}.landing-feat-img-wrap{border-radius:16px;flex:1 1;overflow:hidden;position:relative}.landing-feat-img-wrap img{border:1px solid #ffffff0f;border-radius:16px;display:block;height:280px;object-fit:cover;transition:transform .4s ease;width:100%}.landing-feat-row:hover .landing-feat-img-wrap img{transform:scale(1.03)}.landing-feat-img-badge{align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#060b18b3;border:1px solid #ffffff14;border-radius:12px;display:flex;height:44px;justify-content:center;left:16px;position:absolute;top:16px;width:44px}.landing-feat-img-badge .mdi{color:#38bdf8;font-size:1.3rem}.landing-feat-text{flex:1 1}.landing-feat-text h3{color:#f1f5f9;color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:1.35rem;font-weight:600;margin-bottom:10px}.landing-feat-text p{color:#94a3b8;color:var(--text-secondary);font-size:.95rem;line-height:1.7}.landing-cta-banner{background:linear-gradient(180deg,#0000,#38bdf808 40%,#a855f708 70%,#0000);padding:100px 48px;position:relative;text-align:center;z-index:1}.landing-cta-banner h2{font-family:Space Grotesk,sans-serif;font-size:2.4rem;font-weight:700;letter-spacing:-.8px;line-height:1.15;margin-bottom:14px}.landing-cta-banner p{color:#94a3b8;color:var(--text-secondary);font-size:1.05rem;margin-bottom:32px}.landing-footer{align-items:center;border-top:1px solid #ffffff0a;display:flex;flex-direction:column;gap:10px;padding:40px 24px;position:relative;z-index:1}.landing-footer-brand{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#38bdf8,#a78bfa);-webkit-background-clip:text;background-clip:text;font-family:Space Grotesk,sans-serif;font-size:1.1rem;font-weight:700}.landing-footer p{color:#64748b;color:var(--text-muted);font-size:.78rem}.landing-section-sub{color:#94a3b8;color:var(--text-secondary);font-size:1rem;line-height:1.6;margin:-20px auto 40px;max-width:560px}.landing-magic-demo{align-items:center;display:flex;gap:32px;margin:0 auto;max-width:900px}.landing-magic-box{align-items:center;background:#ffffff08;border:2px dashed #ffffff1f;border-radius:20px;display:flex;flex:1 1;flex-direction:column;justify-content:center;min-height:260px;overflow:hidden;padding:32px 24px;position:relative;text-align:center}.landing-magic-box h3{color:#f1f5f9;color:var(--text-primary);font-size:1.1rem;margin:0 0 6px;position:relative;z-index:2}.landing-magic-box p{color:#64748b;color:var(--text-muted);font-size:.82rem;margin:0;position:relative;z-index:2}.landing-magic-box-glow{background:radial-gradient(circle,#a78bfa14 0,#0000 70%);inset:-40%;pointer-events:none;position:absolute}.landing-magic-particles{inset:0;pointer-events:none;position:absolute}.landing-magic-particle{animation:landingParticleFloat 6s ease-in-out infinite alternate;border-radius:50%;opacity:.5;position:absolute}@keyframes landingParticleFloat{0%{opacity:.3;transform:translate(0) scale(1)}50%{opacity:.7;transform:translate(8px,-12px) scale(1.3)}to{opacity:.3;transform:translate(-6px,6px) scale(.8)}}.landing-magic-icon{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#a78bfa,#38bdf8);-webkit-background-clip:text;font-size:2.4rem;margin-bottom:12px;position:relative;z-index:2}.landing-magic-arrow{animation:landingArrowPulse 2s ease-in-out infinite;color:#64748b;color:var(--text-muted);flex-shrink:0;font-size:2rem}@keyframes landingArrowPulse{0%,to{opacity:.4;transform:translateX(0)}50%{opacity:1;transform:translateX(6px)}}.landing-magic-results{grid-gap:12px;display:grid;flex:0.7 1;gap:12px;grid-template-columns:1fr 1fr}.landing-magic-result{align-items:center;animation:landingResultPop .5s ease-out both;background:#ffffff08;border:1px solid #ffffff0f;border-radius:14px;display:flex;flex-direction:column;gap:4px;padding:18px 14px}@keyframes landingResultPop{0%{opacity:0;transform:scale(.8) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.landing-magic-result-value{font-family:Space Grotesk,sans-serif;font-size:1.4rem;font-weight:700}.landing-magic-result-label{color:#64748b;color:var(--text-muted);font-size:.72rem;letter-spacing:.5px;text-transform:uppercase}.landing-dashboard-preview{background:#ffffff05;border:1px solid #ffffff0f;border-radius:20px;margin:0 auto;max-width:860px;padding:28px}.landing-dash-stats{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(4,1fr);margin-bottom:24px}.landing-dash-stat{align-items:center;background:#ffffff08;border:1px solid #ffffff0d;border-radius:14px;display:flex;flex-direction:column;gap:6px;padding:16px 10px}.landing-dash-stat-icon{align-items:center;border-radius:10px;display:flex;font-size:1.1rem;height:36px;justify-content:center;width:36px}.landing-dash-stat-value{font-family:Space Grotesk,sans-serif;font-size:1.5rem;font-weight:700}.landing-dash-stat-label{color:#64748b;color:var(--text-muted);font-size:.72rem;letter-spacing:.5px;text-transform:uppercase}.landing-dash-completion{align-items:center;background:#ffffff05;border:1px solid #ffffff0d;border-radius:14px;display:flex;gap:28px;padding:20px}.landing-dash-ring{flex-shrink:0}.landing-dash-categories{display:flex;flex:1 1;flex-direction:column;gap:14px}.landing-dash-cat-header{color:#94a3b8;color:var(--text-secondary);display:flex;font-size:.82rem;justify-content:space-between;margin-bottom:5px}.landing-dash-cat-bar{background:#ffffff0f;border-radius:3px;height:6px;overflow:hidden}.landing-dash-cat-bar>div{border-radius:3px;height:100%;transition:width 1s ease}.landing-medals-row{display:flex;flex-wrap:wrap;gap:24px;justify-content:center;margin-top:40px}.landing-medal{align-items:center;display:flex;flex-direction:column;gap:4px;position:relative;width:80px}.landing-medal-svg{height:75px;width:60px}.landing-medal-icon{font-size:1.3rem;position:absolute;top:18px}.landing-medal-title{color:#64748b;color:var(--text-muted);font-size:.65rem;line-height:1.2;text-align:center}@media (max-width:768px){.dashboard-overview{align-items:center;flex-direction:column}.dashboard-categories-grid{grid-template-columns:1fr}.dashboard-hero-stats{flex-wrap:wrap}.dashboard-hero-stat{flex:initial;min-width:calc(50% - 8px)}.dashboard-hero-greeting{font-size:1.4rem}.landing-nav{padding:12px 20px}.landing-nav-link{display:none}.landing-hero{flex-direction:column;gap:40px;padding:100px 24px 40px;text-align:center}.landing-hero-content{max-width:100%}.landing-h1{font-size:2.2rem;letter-spacing:-.8px}.landing-hero-sub{font-size:.95rem}.landing-hero-actions{flex-wrap:wrap;justify-content:center}.landing-hero-visual{max-width:100%}.landing-stats-ribbon{flex-wrap:wrap;gap:24px;padding:32px 16px}.landing-stat-value{font-size:1.5rem}.landing-features{padding:48px 24px}.landing-h2{font-size:1.8rem;margin-bottom:36px}.landing-feat-row,.landing-feat-row.reverse{flex-direction:column;gap:20px}.landing-feat-img-wrap img{height:200px}.landing-cta-banner{padding:60px 24px}.landing-cta-banner h2{font-size:1.6rem}.landing-magic-demo{flex-direction:column;gap:20px}.landing-magic-arrow{transform:rotate(90deg)}.landing-magic-results{width:100%}.landing-dash-stats{grid-template-columns:repeat(2,1fr)}.landing-dash-completion{flex-direction:column;text-align:center}.landing-medals-row{gap:16px}.landing-medal{width:70px}.landing-medal-svg{height:62px;width:50px}.landing-medal-icon{font-size:1.1rem;top:14px}}.location-picker-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.location-picker-modal{background:#1e293b;background:var(--bg-secondary);border:1px solid #334155;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius-lg);display:flex;flex-direction:column;max-height:95vh;max-width:800px;overflow-y:auto;width:95%}.location-picker-photo-preview{background:#0f172a;background:var(--bg-primary);flex-shrink:0;max-height:360px;overflow:hidden;position:relative;width:100%}.location-picker-photo-img{background:#000;display:block;max-height:360px;object-fit:contain;width:100%}.location-picker-photo-placeholder{align-items:center;color:#64748b;color:var(--text-muted);display:flex;font-size:3rem;height:120px;justify-content:center}.location-picker-photo-overlay{background:linear-gradient(#0000,#000c);bottom:0;left:0;padding:32px 20px 12px;position:absolute;right:0}.location-picker-filename{color:#fff;font-size:.9rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;text-shadow:0 1px 3px #00000080;white-space:nowrap}.location-picker-hint{color:#ffffffb3;font-size:.78rem;margin-top:2px}.location-picker-search-wrap{padding:12px 20px 0;position:relative}.location-picker-search-icon{color:#64748b;color:var(--text-muted);font-size:1.1rem;left:32px;pointer-events:none;position:absolute;top:22px}.location-picker-search{background:#1e293b;background:var(--bg-input);border:1px solid #334155;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);color:#f1f5f9;color:var(--text-primary);font-size:.88rem;outline:none;padding:8px 12px 8px 36px;width:100%}.location-picker-search:focus{border-color:#38bdf8;border-color:var(--accent)}.location-picker-search-spinner{color:#64748b;color:var(--text-muted);font-size:1rem;position:absolute;right:32px;top:22px}.location-picker-search-results{background:#0f172a;background:var(--bg-primary);border:1px solid #334155;border:1px solid var(--border);border-radius:0 0 8px 8px;border-radius:0 0 var(--radius) var(--radius);left:20px;max-height:200px;overflow-y:auto;position:absolute;right:20px;top:100%;z-index:10}.location-picker-search-item{align-items:center;border-bottom:1px solid #334155;border-bottom:1px solid var(--border);color:#94a3b8;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.82rem;gap:8px;padding:10px 14px}.location-picker-search-item:last-child{border-bottom:none}.location-picker-search-item:hover{background:#334155;background:var(--bg-hover);color:#f1f5f9;color:var(--text-primary)}.location-picker-search-item .mdi{color:#38bdf8;color:var(--accent);flex-shrink:0;font-size:1rem}.location-picker-search-item span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.location-picker-map{border:1px solid #334155;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);flex-shrink:0;height:350px;margin:12px 20px 0;overflow:hidden}.location-picker-info{align-items:center;color:#94a3b8;color:var(--text-secondary);display:flex;font-size:.82rem;gap:8px;overflow:hidden;padding:8px 20px;text-overflow:ellipsis;white-space:nowrap}.location-picker-actions{align-items:center;border-top:1px solid #334155;border-top:1px solid var(--border);display:flex;flex-shrink:0;gap:8px;padding:16px 20px}.locations-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;margin-bottom:16px}.locations-count{color:#94a3b8;color:var(--text-secondary);font-size:.88rem}.loc-hierarchy{margin-bottom:8px}.loc-level{margin-bottom:2px}.loc-level-header{align-items:center;background:#1e293b;background:var(--bg-secondary);border:1px solid #334155;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);color:#f1f5f9;color:var(--text-primary);cursor:pointer;display:flex;font-size:.9rem;gap:10px;padding:10px 14px;transition:background .15s ease;width:100%}.loc-level-header:hover{background:#334155;background:var(--bg-hover)}.loc-level-name{flex-shrink:1;font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.loc-level-badge{border-radius:4px;color:#94a3b8;color:var(--text-secondary);font-size:.65rem;font-weight:700;letter-spacing:1px;padding:2px 6px}.loc-level-badge,.loc-level-count{background:#334155;background:var(--bg-tertiary)}.loc-level-count{border-radius:10px;color:#64748b;color:var(--text-muted);flex-shrink:0;font-size:.78rem;padding:2px 8px}.loc-level-thumb-wrap{border-radius:6px;flex-shrink:0;height:32px;overflow:hidden;width:32px}.loc-level-thumb{display:block;height:100%;object-fit:cover;width:100%}.loc-children{margin-top:2px;padding-left:20px}.loc-city>.loc-level-header{background:#0000;border-color:#334155;border-color:var(--border)}.loc-suburb>.loc-level-header{background:#0000;border-color:#0000;border-left:2px solid #334155;border-left:2px solid var(--border);border-radius:0;font-size:.85rem;padding:8px 14px}.loc-suburb>.loc-level-header:hover{background:#1e293b;background:var(--bg-secondary)}.loc-photos-wrap{padding:8px 0 8px 20px}.locations-section{margin-bottom:20px}.locations-section-header{align-items:center;background:#1e293b;background:var(--bg-secondary);border:1px solid #334155;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);color:#f1f5f9;color:var(--text-primary);cursor:pointer;display:flex;font-size:.92rem;gap:10px;margin-bottom:12px;padding:12px 16px;transition:background .15s ease;width:100%}.locations-section-header:hover{background:#334155;background:var(--bg-hover)}.locations-section-title{font-weight:600}.locations-section-count{background:#334155;background:var(--bg-tertiary);border-radius:10px;color:#64748b;color:var(--text-muted);font-size:.78rem;padding:2px 8px}.locations-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.locations-photo{background:#0f172a;background:var(--bg-primary);border:2px solid #0000;border-radius:8px;border-radius:var(--radius);cursor:pointer;overflow:hidden;position:relative;transition:border-color .15s ease,transform .15s ease}.locations-photo:hover{transform:translateY(-2px)}.locations-photo.selected,.locations-photo:hover{border-color:#38bdf8;border-color:var(--accent)}.locations-photo.unknown{opacity:.6}.locations-photo.unknown:hover{opacity:1}.locations-photo img{aspect-ratio:1;display:block;object-fit:cover;width:100%}.locations-photo-name{color:#64748b;color:var(--text-muted);font-size:.72rem;overflow:hidden;padding:6px 8px;text-overflow:ellipsis;white-space:nowrap}.locations-photo-check{color:#38bdf8;color:var(--accent);font-size:1.2rem;left:6px;position:absolute;text-shadow:0 1px 3px #00000080;top:6px;z-index:1}.locations-photo-undo{align-items:center;background:#0009;border:none;border-radius:50%;color:#f1f5f9;color:var(--text-primary);cursor:pointer;display:flex;font-size:.9rem;height:28px;justify-content:center;opacity:0;position:absolute;right:6px;top:6px;transition:opacity .15s ease;width:28px;z-index:1}.locations-photo:hover .locations-photo-undo{opacity:1}.locations-photo-undo:hover{background:#38bdf8;background:var(--accent)}.people-tile-grid{grid-gap:3px;display:grid;gap:3px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));padding:4px 0 16px}.people-tile{aspect-ratio:1;background:#334155;background:var(--bg-tertiary);border:2px solid #0000;cursor:pointer;overflow:hidden;position:relative;transition:border-color .15s}.people-tile.active,.people-tile:hover{border-color:#38bdf8;border-color:var(--accent)}.people-tile.active{box-shadow:0 0 0 1px #38bdf8;box-shadow:0 0 0 1px var(--accent)}.people-tile-img{display:block;height:100%;object-fit:cover;width:100%}.people-tile-placeholder{display:grid;height:100%;place-items:center;width:100%}.people-tile-placeholder .mdi{color:#64748b;color:var(--text-muted);font-size:3rem}.people-tile-overlay{background:linear-gradient(#0000,#000000bf);bottom:0;display:flex;flex-direction:column;gap:1px;left:0;padding:24px 8px 8px;position:absolute;right:0}.people-tile-name{color:#fff;font-size:.8rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.people-tile-count{color:#ffffffb3;font-size:.65rem}.people-expanded{background:#1e293b;background:var(--bg-secondary);border:1px solid #334155;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius-lg);margin-bottom:16px;padding:16px}.activity-tabs{border-bottom:1px solid #334155;border-bottom:1px solid var(--border);gap:4px;margin-bottom:16px;padding-bottom:8px}.activity-tab,.activity-tabs{align-items:center;display:flex}.activity-tab{background:#0000;border:none;border-radius:8px 8px 0 0;border-radius:var(--radius) var(--radius) 0 0;color:#64748b;color:var(--text-muted);cursor:pointer;font-size:.85rem;font-weight:600;gap:6px;padding:8px 16px;transition:all .15s ease}.activity-tab:hover{color:#f1f5f9;color:var(--text-primary)}.activity-tab.active,.activity-tab:hover{background:#1e293b;background:var(--bg-secondary)}.activity-tab.active{border-bottom:2px solid #38bdf8;border-bottom:2px solid var(--accent);color:#38bdf8;color:var(--accent)}.activity-filters{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.activity-filter-btn{align-items:center;background:#0000;border:1px solid #334155;border:1px solid var(--border);border-radius:20px;color:#94a3b8;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.78rem;font-weight:500;gap:5px;padding:5px 12px;transition:all .15s ease}.activity-filter-btn:hover{border-color:#38bdf8;border-color:var(--accent);color:#f1f5f9;color:var(--text-primary)}.activity-filter-btn.active{background:#38bdf814;border-color:#38bdf8;border-color:var(--accent);color:#38bdf8;color:var(--accent)}.activity-filter-count{background:#334155;background:var(--bg-tertiary);border-radius:8px;color:#64748b;color:var(--text-muted);font-size:.68rem;padding:1px 6px}.activity-level-filters{display:flex;gap:4px;margin-bottom:16px}.activity-level-btn{background:#0000;border:1px solid #0000;border-radius:4px;color:#64748b;color:var(--text-muted);cursor:pointer;font-size:.72rem;font-weight:500;padding:3px 10px}.activity-level-btn.active,.activity-level-btn:hover{color:#f1f5f9;color:var(--text-primary)}.activity-level-btn.active{background:#1e293b;background:var(--bg-secondary);border-color:#334155;border-color:var(--border)}.activity-list{border:1px solid #334155;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);overflow:hidden}.activity-entry{border-bottom:1px solid #334155;border-bottom:1px solid var(--border);display:flex;gap:12px;padding:10px 14px;transition:background .1s ease}.activity-entry:last-child{border-bottom:none}.activity-entry:hover{background:#1e293b;background:var(--bg-secondary)}.activity-entry-icon{flex-shrink:0;font-size:1.1rem;padding-top:1px}.activity-entry-body{flex:1 1;min-width:0}.activity-entry-message{color:#f1f5f9;color:var(--text-primary);font-size:.84rem;line-height:1.4;word-break:break-word}.activity-entry-meta{color:#64748b;color:var(--text-muted);display:flex;font-size:.7rem;gap:10px;margin-top:3px}@media (max-width:600px){.location-picker-modal{max-width:none;width:100%}.location-picker-map{height:250px}.location-picker-photo-img,.location-picker-photo-preview{max-height:240px}.locations-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.loc-children,.loc-photos-wrap{padding-left:12px}.activity-filters{gap:4px}.activity-filter-btn{font-size:.72rem;padding:4px 8px}}
/*# sourceMappingURL=main.b51f909e.css.map*/