:root{--primary:#1a1a2e;--primary-light:#16213e;--secondary:#0f3460;--accent:#e94560;--accent-light:#f16a84;--success:#00d4aa;--warning:#ffc107;--text-primary:#1a1a2e;--text-secondary:#6c757d;--text-muted:#9ca3af;--text-white:#fff;--bg-primary:#fff;--bg-secondary:#f8fafc;--bg-tertiary:#f1f5f9;--bg-dark:#0f172a;--gradient-primary:linear-gradient(135deg,#667eea,#764ba2);--gradient-accent:linear-gradient(135deg,#e94560,#f16a84);--gradient-success:linear-gradient(135deg,#00d4aa,#4ade80);--shadow-sm:0 1px 2px 0 rgba(0,0,0,.05);--shadow-md:0 4px 6px -1px rgba(0,0,0,.1);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.1);--shadow-xl:0 20px 25px -5px rgba(0,0,0,.1);--border-color:#e2e8f0;--border-radius:12px;--border-radius-lg:20px}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Google Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;overflow-x:hidden}.hero-section{min-height:100vh;display:flex;align-items:center;padding:2rem;background:linear-gradient(135deg,#f8fafc,#e2e8f0 50%,#cbd5e1);position:relative;overflow:hidden}.hero-section:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:200%;background:var(--gradient-primary);opacity:.05;border-radius:50%;animation:float 20s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-20px) rotate(180deg)}}.hero-content{flex:1 1;max-width:600px;z-index:2}.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--bg-primary);padding:8px 16px;border-radius:50px;box-shadow:var(--shadow-sm);border:1px solid var(--border-color);margin-bottom:2rem;font-size:14px;font-weight:500;color:var(--text-secondary)}.hero-title{font-size:clamp(2.5rem,5vw,4rem);font-weight:700;line-height:1.1;margin-bottom:1.5rem;color:var(--text-primary)}.gradient-text{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{font-size:1.2rem;color:var(--text-secondary);margin-bottom:2.5rem;line-height:1.7}.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}.hero-visual{flex:1 1;display:flex;justify-content:center;align-items:center;position:relative}.floating-cards{position:relative;width:300px;height:300px}.photo-card{position:absolute;background:var(--bg-primary);border-radius:var(--border-radius-lg);padding:2rem;box-shadow:var(--shadow-xl);border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center}.card-1{top:0;left:0;animation:floatCard1 6s ease-in-out infinite}.card-2{top:50%;right:0;animation:floatCard2 8s ease-in-out infinite}.card-3{bottom:0;left:50%;transform:translateX(-50%);animation:floatCard3 7s ease-in-out infinite}@keyframes floatCard1{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-15px) rotate(5deg)}}@keyframes floatCard2{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-20px) rotate(-8deg)}}@keyframes floatCard3{0%,to{transform:translateX(-50%) translateY(0) rotate(0deg)}50%{transform:translateX(-50%) translateY(-10px) rotate(3deg)}}.header{top:2rem;z-index:1000}.logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--text-primary);font-weight:600;font-size:18px;padding:12px 24px;border-radius:50px;background:hsla(0,0%,100%,.95);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);transition:all .3s ease}.logo:hover{transform:translateY(-2px);box-shadow:var(--shadow-xl)}.primary-btn{display:inline-flex;align-items:center;gap:12px;background:var(--gradient-primary);color:var(--text-white);border:none;padding:16px 32px;border-radius:var(--border-radius);font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-md)}.primary-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.primary-btn:active{transform:translateY(0)}.primary-btn.large{padding:20px 40px;font-size:18px}.secondary-btn{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--text-primary);border:2px solid var(--border-color);padding:14px 28px;border-radius:var(--border-radius);font-size:16px;font-weight:500;cursor:pointer;transition:all .3s ease}.secondary-btn:hover{border-color:var(--primary);color:var(--primary);background:rgba(26,26,46,.05)}.back-button{position:fixed;top:32px;left:32px;color:var(--text-primary);background:hsla(0,0%,100%,.95);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);display:flex;align-items:center;gap:8px;text-decoration:none;padding:12px 20px;border-radius:50px;border:1px solid var(--border-color);font-weight:500;transition:all .3s ease;box-shadow:var(--shadow-md);z-index:1000}.back-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.features-section{padding:6rem 2rem;background:var(--bg-primary)}.section-header{text-align:center;margin-bottom:4rem;max-width:600px;margin-left:auto;margin-right:auto}.section-title{font-size:clamp(2rem,4vw,3rem);font-weight:700;margin-bottom:1rem;color:var(--text-primary)}.section-subtitle{font-size:1.2rem;color:var(--text-secondary);line-height:1.6}.features-grid{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:4rem}.feature-item{display:grid;grid-template-columns:1fr 1fr;grid-gap:4rem;gap:4rem;align-items:center}.feature-item.reverse{direction:rtl}.feature-item.reverse *{direction:ltr}.feature-icon,.feature-visual{display:flex;justify-content:center;align-items:center}.feature-icon{width:120px;height:120px;background:var(--gradient-primary);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);position:relative;overflow:hidden}.feature-icon:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,hsla(0,0%,100%,.1),transparent 50%);animation:shimmer 3s ease-in-out infinite}@keyframes shimmer{0%{transform:translateX(-100%) translateY(-100%) rotate(45deg)}to{transform:translateX(100%) translateY(100%) rotate(45deg)}}.feature-content h3{font-size:1.8rem;font-weight:700;margin-bottom:1rem;color:var(--text-primary)}.feature-content p{font-size:1.1rem;color:var(--text-secondary);margin-bottom:1.5rem;line-height:1.7}.feature-content ul{list-style:none;padding:0}.feature-content li{display:flex;align-items:center;gap:12px;padding:8px 0;color:var(--text-secondary)}.feature-content li:before{content:"✓";display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background:var(--gradient-success);color:#fff;border-radius:50%;font-size:12px;font-weight:700;flex-shrink:0}.cta-section{padding:6rem 2rem;background:var(--bg-secondary);text-align:center}.cta-content{max-width:600px;margin:0 auto}.cta-title{font-size:clamp(2rem,4vw,3rem);font-weight:700;margin-bottom:1.5rem;color:var(--text-primary)}.cta-description{font-size:1.2rem;color:var(--text-secondary);margin-bottom:2.5rem;line-height:1.7}.cta-actions{margin-bottom:1.5rem}.cta-note{font-size:14px;color:var(--text-muted);font-style:italic}@media (max-width:768px){.hero-section{flex-direction:column;text-align:center;min-height:auto;padding:6rem 1rem 1rem}.hero-content{margin-bottom:3rem}.hero-title{font-size:clamp(2rem,8vw,2.5rem)}.hero-description{font-size:1rem}.hero-actions{justify-content:center}.floating-cards{width:250px;height:250px}.photo-card{padding:1.5rem}.features-section{padding:4rem 1rem}.feature-item{grid-template-columns:1fr;gap:2rem;text-align:center}.feature-item.reverse{direction:ltr}.section-title{font-size:clamp(1.8rem,6vw,2.5rem)}.section-subtitle{font-size:1rem}.feature-content h3{font-size:1.5rem}.feature-content p{font-size:1rem}.cta-section{padding:4rem 1rem}.cta-title{font-size:clamp(1.8rem,6vw,2.5rem)}.cta-description{font-size:1rem}.header{top:1rem}.logo{padding:10px 20px;font-size:16px}.back-button{top:1rem;left:1rem;padding:10px 16px}.primary-btn,.secondary-btn{padding:14px 24px;font-size:14px}.primary-btn.large{padding:16px 32px;font-size:16px}}.bottom-gradient,.dots{display:none}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#f8fafc,#e2e8f0 50%,#cbd5e1)}.auth-container{width:100%;max-width:400px}.auth-card{background:var(--bg-primary);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-xl);padding:2.5rem;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid hsla(0,0%,100%,.2)}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h1{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.auth-header p{color:var(--text-secondary);font-size:.95rem}.auth-form{gap:1.5rem}.auth-form,.form-group{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group label{font-weight:500;color:var(--text-primary);font-size:.9rem}.form-group input{padding:.875rem 1rem;border:2px solid var(--border-color);border-radius:var(--border-radius);font-size:1rem;transition:all .2s ease;background:var(--bg-primary);color:var(--text-primary)}.form-group input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(233,69,96,.1)}.form-group input::placeholder{color:var(--text-muted)}.error-message{background:rgba(233,69,96,.1);color:var(--accent);border-left:4px solid var(--accent)}.error-message,.success-message{padding:.75rem 1rem;border-radius:var(--border-radius);font-size:.9rem}.success-message{background:rgba(0,212,170,.1);color:var(--success);border-left:4px solid var(--success)}.auth-submit-btn{background:var(--gradient-accent);color:var(--text-white);border:none;padding:1rem;border-radius:var(--border-radius);font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:.5rem}.auth-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg)}.auth-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-footer{margin-top:2rem;text-align:center}.auth-links{margin-bottom:1.5rem}.forgot-link{color:var(--accent);text-decoration:none;font-size:.9rem;transition:color .2s ease}.forgot-link:hover{color:var(--accent-light);text-decoration:underline}.auth-divider{margin:1.5rem 0;position:relative;text-align:center}.auth-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border-color)}.auth-divider span{background:var(--bg-primary);padding:0 1rem;color:var(--text-muted);font-size:.9rem}.login-prompt,.signup-prompt{color:var(--text-secondary);font-size:.95rem}.login-prompt a,.signup-prompt a{color:var(--accent);text-decoration:none;font-weight:500;transition:color .2s ease}.login-prompt a:hover,.signup-prompt a:hover{color:var(--accent-light);text-decoration:underline}.header{justify-content:space-between;padding:1rem 2rem;position:fixed;top:1rem;left:50%;transform:translateX(-50%);z-index:100;background:hsla(0,0%,100%,.95);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);border:1px solid hsla(0,0%,100%,.2);width:calc(100% - 4rem);max-width:1200px}.header,.header-nav{display:flex;align-items:center}.header-nav{gap:1rem}.auth-buttons{display:flex;align-items:center;gap:.75rem}.login-btn-header{color:var(--text-primary);text-decoration:none;padding:.5rem 1rem;border-radius:var(--border-radius);transition:all .2s ease;font-weight:500}.login-btn-header:hover{background:var(--bg-secondary);color:var(--accent)}.signup-btn-header{background:var(--gradient-accent);color:var(--text-white);text-decoration:none;padding:.5rem 1rem;border-radius:var(--border-radius);font-weight:500;transition:all .2s ease;border:none}.signup-btn-header:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.user-menu{gap:1.5rem}.user-menu,.user-profile{display:flex;align-items:center}.user-profile{gap:.75rem}.user-avatar{object-fit:cover}.user-avatar,.user-avatar-placeholder{width:32px;height:32px;border-radius:50%;border:2px solid var(--border-color)}.user-avatar-placeholder{background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center}.user-info{display:flex;flex-direction:column;gap:.125rem}.user-role{font-size:.75rem;color:var(--text-muted);font-weight:400}.user-actions{display:flex;align-items:center;gap:.75rem}.dashboard-btn,.profile-btn{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);text-decoration:none;font-size:.9rem;font-weight:500;transition:all .2s ease}.dashboard-btn:hover,.profile-btn:hover{border-color:var(--secondary);background:var(--bg-secondary)}.user-link{text-decoration:none;color:var(--text-primary)}.user-name{font-weight:500;padding:.5rem 1rem;border-radius:var(--border-radius);background:var(--bg-secondary)}.logout-btn-header{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);padding:.5rem 1rem;border-radius:var(--border-radius);cursor:pointer;font-size:.9rem;transition:all .2s ease}.logout-btn-header:hover{border-color:var(--accent);color:var(--accent)}.dashboard{min-height:100vh;padding:8rem 2rem 2rem;background:var(--bg-secondary)}.dashboard-container{max-width:1200px;margin:0 auto}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:3rem;gap:2rem}.welcome-section h1{font-size:2.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.welcome-section p{color:var(--text-secondary);font-size:1.1rem;max-width:600px}.logout-btn{background:var(--gradient-accent);color:var(--text-white);border:none;padding:.75rem 1.5rem;border-radius:var(--border-radius);font-weight:500;cursor:pointer;transition:all .3s ease}.logout-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.dashboard-content{display:flex;flex-direction:column;gap:3rem}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:2rem;gap:2rem}.feature-card{background:var(--bg-primary);padding:2rem;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);text-align:center;transition:all .3s ease;border:1px solid var(--border-color)}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.feature-card .feature-icon{margin-bottom:1rem;display:flex;justify-content:center}.feature-card h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.feature-card p{color:var(--text-secondary);margin-bottom:1.5rem;line-height:1.6}.feature-btn{background:var(--bg-tertiary);color:var(--text-muted);border:1px solid var(--border-color);padding:.75rem 1.5rem;border-radius:var(--border-radius);font-weight:500;cursor:not-allowed;transition:all .2s ease}.status-section{background:var(--bg-primary);padding:2rem;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md)}.status-section h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:1.5rem}.status-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:1.5rem;gap:1.5rem}.status-item{display:flex;flex-direction:column;gap:.5rem;text-align:center;padding:1rem;border-radius:var(--border-radius);background:var(--bg-secondary)}.status-label{color:var(--text-secondary);font-size:.9rem}.status-value{color:var(--text-primary);font-size:1.25rem;font-weight:600}.user-welcome{display:flex;align-items:center;gap:1.5rem}.dashboard-avatar{object-fit:cover}.dashboard-avatar,.dashboard-avatar-placeholder{width:60px;height:60px;border-radius:50%;border:3px solid var(--border-color)}.dashboard-avatar-placeholder{background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center}.user-role-text,.welcome-text h1{margin-bottom:.5rem}.user-role-text{color:var(--text-muted);font-size:.9rem;font-weight:500}.profile-incomplete-notice{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #f59e0b;border-radius:var(--border-radius);padding:1.5rem;margin-bottom:2rem}.notice-content{display:flex;align-items:center;gap:1rem}.notice-text{flex:1 1}.notice-text h3{color:#92400e;font-size:1.1rem;font-weight:600;margin-bottom:.25rem}.notice-text p{color:#b45309;font-size:.95rem}.complete-profile-btn{padding:.75rem 1.5rem;background:var(--gradient-primary);color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:500;text-decoration:none;transition:all .2s ease;white-space:nowrap}.complete-profile-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}.profile-progress{background:var(--bg-primary);border-radius:var(--border-radius);padding:1.5rem;box-shadow:var(--shadow-md);margin-bottom:1.5rem;border:1px solid var(--border-color)}.progress-header h3{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin:0}.progress-percentage{font-size:1.25rem;font-weight:700;color:var(--secondary)}.progress-percentage.complete{color:var(--success)}.progress-bar-container{width:100%;height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden;margin-bottom:1rem}.progress-bar-fill{height:100%;background:var(--gradient-primary);border-radius:4px;transition:width .3s ease}.progress-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));grid-gap:.75rem;gap:.75rem}.progress-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;border-radius:6px;background:var(--bg-secondary);transition:all .2s ease}.progress-item.completed{background:rgba(0,212,170,.1);border:1px solid rgba(0,212,170,.2)}.progress-item.pending{background:rgba(156,163,175,.1);border:1px solid rgba(156,163,175,.2)}.progress-item.optional{opacity:.8}.progress-icon{font-size:1rem;width:20px;display:flex;justify-content:center}.progress-label{font-size:.9rem;color:var(--text-primary);font-weight:500}.completion-message{display:flex;align-items:center;gap:.5rem;background:rgba(0,212,170,.1);border:1px solid var(--success);border-radius:6px;padding:.75rem;margin-top:1rem;color:var(--success);font-weight:500;font-size:.95rem}.loading-container{min-height:200px}.loading-spinner{display:flex;align-items:center;justify-content:center}.spinner{width:32px;height:32px;border-top:3px solid var(--border-color);border:3px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}.spinner-small .spinner{width:20px;height:20px;border-width:2px}.spinner-large .spinner{width:48px;height:48px;border-width:4px}.loading-text{color:var(--text-secondary);font-size:.95rem}@media (max-width:768px){.auth-card{padding:2rem;margin:1rem}.dashboard-header{flex-direction:column;align-items:center;text-align:center;gap:1rem}.welcome-section h1{font-size:2rem}.header{width:calc(100% - 2rem);padding:1rem}.auth-buttons{gap:.5rem}.login-btn-header,.signup-btn-header{padding:.4rem .8rem;font-size:.9rem}.user-menu{gap:.5rem}.logout-btn-header,.user-name{padding:.4rem .8rem;font-size:.9rem}}.profile-page{min-height:100vh;padding:2rem;background:var(--bg-secondary)}.profile-container{max-width:600px;margin:0 auto;padding:2rem 0}.profile-header{text-align:center;margin-bottom:2rem}.profile-header h1{font-size:2rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.profile-header p{color:var(--text-secondary);font-size:1.1rem}.profile-form-container{background:var(--bg-primary);border-radius:var(--border-radius);padding:2rem;box-shadow:var(--shadow-lg)}.profile-form{gap:1.5rem}.form-section,.profile-form{display:flex;flex-direction:column}.form-section{gap:.5rem}.form-label{font-weight:500;color:var(--text-primary);font-size:.9rem}.form-input,.form-select{padding:.75rem;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;transition:all .2s ease;background:var(--bg-primary);color:var(--text-primary)}.form-input:focus,.form-select:focus{outline:none;border-color:var(--secondary);box-shadow:0 0 0 3px rgba(15,52,96,.1)}.form-input.error,.form-select.error{border-color:var(--accent);box-shadow:0 0 0 3px rgba(233,69,96,.1)}.field-error{color:var(--accent);font-size:.85rem;margin-top:.25rem;display:block}.profile-photo-upload{display:flex;flex-direction:column;align-items:center;gap:1rem}.photo-preview{width:120px;height:120px;border-radius:50%;border:3px dashed var(--border-color);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;overflow:hidden;background:var(--bg-tertiary)}.photo-preview:hover{border-color:var(--secondary);background:var(--bg-secondary)}.preview-image{width:100%;height:100%;object-fit:cover}.placeholder{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--text-muted);text-align:center}.placeholder span{font-size:.9rem}.photo-actions{display:flex;gap:.5rem}.remove-btn,.upload-btn{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;font-size:.9rem;transition:all .2s ease}.upload-btn:hover{border-color:var(--secondary);background:var(--bg-secondary)}.remove-btn{color:var(--accent);border-color:var(--accent)}.remove-btn:hover{background:var(--accent);color:#fff}.hidden-input{display:none}.profile-submit-btn{padding:.75rem 1.5rem;background:var(--gradient-primary);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;margin-top:1rem}.profile-submit-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-lg)}.profile-submit-btn:disabled{opacity:.6;cursor:not-allowed}.upload-progress{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border-color)}.progress-bar{background:var(--bg-secondary)}.progress-text{font-size:.9rem;color:var(--text-secondary);text-align:center}@media (max-width:768px){.profile-page{padding:1rem}.profile-container{padding:1rem 0}.profile-form-container{padding:1.5rem}.photo-preview{width:100px;height:100px}.progress-details{grid-template-columns:1fr}.progress-header{gap:.5rem}.progress-header,.user-welcome{flex-direction:column;text-align:center}.user-welcome{gap:1rem}.user-profile{flex-direction:column;text-align:center;gap:.5rem}.user-actions{flex-wrap:wrap;justify-content:center}}.photo-upload{width:100%;max-width:800px;margin:0 auto}.upload-dropzone{border:2px dashed var(--border-color);border-radius:var(--border-radius);padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .3s ease;background:var(--bg-secondary);position:relative;overflow:hidden}.upload-dropzone:hover{border-color:var(--accent);background:rgba(233,69,96,.05);transform:translateY(-2px)}.upload-dropzone.drag-over{border-color:var(--accent);background:rgba(233,69,96,.1);transform:scale(1.02)}.upload-dropzone.uploading{pointer-events:none;opacity:.7}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.upload-icon{opacity:.6;transition:opacity .3s ease}.upload-dropzone:hover .upload-icon{opacity:1}.upload-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0}.upload-description{color:var(--text-secondary);line-height:1.6;margin:0}.upload-formats{font-size:.9rem;color:var(--text-muted)}.upload-select-btn{background:var(--gradient-primary);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:var(--border-radius);font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-md)}.upload-select-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.hidden-file-input{display:none}.upload-progress-section{margin-top:2rem;background:#fff;border-radius:var(--border-radius);padding:1.5rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.progress-header h4{margin:0;color:var(--text-primary);font-weight:600}.clear-completed-btn{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);padding:.5rem 1rem;border-radius:6px;font-size:.875rem;cursor:pointer;transition:all .2s ease}.clear-completed-btn:hover:not(:disabled){background:var(--bg-secondary);color:var(--text-primary)}.clear-completed-btn:disabled{opacity:.5;cursor:not-allowed}.upload-list{display:flex;flex-direction:column;gap:.75rem}.upload-item{position:relative;background:var(--bg-secondary);border-radius:8px;padding:1rem;border:1px solid var(--border-color);transition:all .2s ease}.upload-item:hover{box-shadow:var(--shadow-sm)}.upload-item-info{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.file-info{flex:1 1;min-width:0}.file-name{display:block;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.25rem}.file-size{font-size:.875rem;color:var(--text-muted)}.upload-status{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.status-text{font-weight:500}.progress-percent{color:var(--text-muted)}.progress-bar{height:4px;border-radius:2px;margin-top:.5rem}.progress-fill{transition:width .3s ease;border-radius:2px}.error-message{padding:.5rem;border-radius:6px;font-size:.875rem;margin-top:.5rem;border:1px solid rgba(239,68,68,.2)}.error-message,.remove-upload-btn{background:rgba(239,68,68,.1);color:#dc2626}.remove-upload-btn{position:absolute;top:.5rem;right:.5rem;border:none;width:24px;height:24px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;transition:all .2s ease}.remove-upload-btn:hover{background:rgba(239,68,68,.2);transform:scale(1.1)}.upload-section{margin-bottom:2rem;background:#fff;border-radius:var(--border-radius);padding:2rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.upload-section .section-header{text-align:center;margin-bottom:2rem}.upload-section .section-header h2{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.upload-section .section-header p{color:var(--text-secondary);font-size:1rem;line-height:1.6}@media (max-width:768px){.upload-dropzone{padding:2rem 1rem}.upload-title{font-size:1.25rem}.upload-item-info{gap:.5rem}.progress-header,.upload-item-info{flex-direction:column;align-items:flex-start}.progress-header{gap:1rem}.upload-section{padding:1.5rem;margin-bottom:1rem}.upload-section .section-header h2{font-size:1.5rem}}.photo-analysis{max-width:1000px;margin:0 auto}.analysis-controls{background:#fff;border-radius:var(--border-radius);padding:2rem;margin-bottom:2rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.analysis-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:1rem;gap:1rem;margin:1.5rem 0}.option-group{display:flex;flex-direction:column;gap:.5rem}.option-group label{font-weight:500}.option-group label,.option-group select{color:var(--text-primary);font-size:.9rem}.option-group select{padding:.75rem;border:1px solid var(--border-color);border-radius:8px;background:#fff}.option-group select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(233,69,96,.1)}.analysis-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.analysis-btn{min-width:200px;padding:.875rem 1.5rem;font-size:1rem;font-weight:500;border-radius:var(--border-radius);transition:all .3s ease}.analysis-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.analysis-progress{background:#fff;border-radius:var(--border-radius);padding:1.5rem;margin-bottom:2rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.progress-text{color:var(--text-primary);font-weight:500}.progress-percent{color:var(--text-secondary);font-weight:600}.progress-bar{width:100%;height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:var(--gradient-primary);border-radius:4px;transition:width .5s ease}.analysis-result-summary{background:#fff;border-radius:var(--border-radius);padding:2rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.analysis-result-summary h4{margin:0 0 1.5rem;color:var(--text-primary);font-size:1.25rem}.result-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));grid-gap:1rem;gap:1rem;margin-bottom:2rem}.stat-item{text-align:center;padding:1rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.stat-value{display:block;font-size:2rem;font-weight:700;color:var(--accent);margin-bottom:.25rem}.stat-label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.event-type-breakdown{margin-bottom:1.5rem}.event-type-breakdown h5{margin:0 0 1rem;color:var(--text-primary);font-size:1rem}.event-types{display:flex;flex-wrap:wrap;gap:.75rem}.event-type-item{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-secondary);border-radius:6px;border:1px solid var(--border-color)}.event-type-name{color:var(--text-primary);font-weight:500}.event-type-count{color:var(--text-secondary);font-size:.875rem}.time-range-info{text-align:center;color:var(--text-secondary);font-size:.9rem;padding-top:1rem;border-top:1px solid var(--border-color)}.auto-album-gallery{max-width:1200px;margin:0 auto}.auto-album-gallery.empty{text-align:center;padding:4rem 2rem}.empty-state{max-width:400px;margin:0 auto}.empty-state img{opacity:.5;margin-bottom:1rem}.empty-state h3{color:var(--text-primary);margin-bottom:.5rem}.empty-state p{color:var(--text-secondary)}.gallery-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color)}.gallery-title h3{margin:0 0 .5rem;color:var(--text-primary);font-size:1.5rem}.gallery-title p{margin:0;color:var(--text-secondary);font-size:.9rem}.gallery-actions{display:flex;align-items:center;gap:1rem}.select-all-label{align-items:center;color:var(--text-secondary);font-size:.9rem;cursor:pointer}.select-all-label,.selected-actions{display:flex;gap:.5rem}.delete-btn,.merge-btn{padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;transition:all .2s ease}.merge-btn{background:var(--gradient-primary);color:#fff;border:none}.merge-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.delete-btn{background:rgba(239,68,68,.1);color:#dc2626;border:1px solid rgba(239,68,68,.3)}.delete-btn:hover{background:rgba(239,68,68,.2)}.albums-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));grid-gap:1.5rem;gap:1.5rem}.album-card{background:#fff;border-radius:var(--border-radius);padding:1.5rem;box-shadow:var(--shadow-sm);border:2px solid transparent;transition:all .3s ease;position:relative}.album-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.album-card.selected{border-color:var(--accent);background:rgba(233,69,96,.02)}.album-selection{position:absolute;top:1rem;left:1rem;z-index:2}.album-selection input[type=checkbox]{width:18px;height:18px;cursor:pointer}.album-cover{position:relative;width:100%;height:180px;border-radius:8px;overflow:hidden;margin-bottom:1rem;background:var(--bg-secondary)}.album-cover img{width:100%;height:100%;object-fit:cover}.album-placeholder{display:flex;align-items:center;justify-content:center;height:100%;opacity:.5}.confidence-badge{position:absolute;top:.5rem;right:.5rem;padding:.25rem .5rem;border-radius:4px;color:#fff;font-size:.75rem;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.3)}.album-info{flex:1 1}.album-title h4{margin:0 0 1rem;color:var(--text-primary);cursor:pointer;font-size:1.1rem;line-height:1.4}.album-title h4:hover{color:var(--accent)}.album-name-edit{display:flex;gap:.5rem;align-items:center}.album-name-edit input{flex:1 1;padding:.5rem;border:1px solid var(--border-color);border-radius:4px;font-size:1rem}.edit-actions{display:flex;gap:.25rem}.edit-actions button{width:28px;height:28px;border:none;border-radius:4px;cursor:pointer;font-size:.875rem;font-weight:700}.edit-actions button:first-child{background:#22c55e;color:#fff}.edit-actions button:last-child{background:#ef4444;color:#fff}.album-details{display:grid;grid-template-columns:1fr 1fr;grid-gap:.75rem;gap:.75rem;margin-bottom:1rem}.detail-item{display:flex;justify-content:space-between;align-items:center;font-size:.875rem}.detail-label{color:var(--text-secondary)}.detail-value{color:var(--text-primary);font-weight:500}.album-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.album-tag{padding:.25rem .5rem;background:var(--bg-secondary);color:var(--text-secondary);border-radius:4px;font-size:.75rem;border:1px solid var(--border-color)}.album-tag.more{background:var(--accent);color:#fff;border-color:var(--accent)}.album-actions{position:absolute;top:1rem;right:1rem;display:flex;gap:.5rem;opacity:0;transition:opacity .3s ease}.album-card:hover .album-actions{opacity:1}.action-btn{width:32px;height:32px;border:none;border-radius:6px;background:hsla(0,0%,100%,.9);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .2s ease;box-shadow:0 2px 4px rgba(0,0,0,.1)}.action-btn:hover{transform:scale(1.1);background:#fff;box-shadow:0 4px 8px rgba(0,0,0,.15)}.album-location{margin-top:.5rem;padding:.5rem;background:var(--bg-secondary);border-radius:6px;font-size:.875rem;color:var(--text-secondary);border-left:3px solid var(--accent)}@media (max-width:768px){.analysis-options{grid-template-columns:1fr}.analysis-buttons{flex-direction:column}.analysis-btn{min-width:auto;width:100%}.result-stats{grid-template-columns:repeat(2,1fr)}.gallery-header{flex-direction:column;align-items:flex-start;gap:1rem}.album-details,.albums-grid{grid-template-columns:1fr}}.dashboard-tabs{display:flex;border-bottom:2px solid var(--border-color);margin-bottom:2rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.tab-button{background:none;padding:1rem 2rem;color:var(--text-secondary);font-weight:500;font-size:1rem;cursor:pointer;white-space:nowrap;border:none;border-bottom:3px solid transparent;transition:all .3s ease}.tab-button:hover{color:var(--text-primary);background:rgba(233,69,96,.05)}.tab-button.active{color:var(--accent);border-bottom-color:var(--accent);background:rgba(233,69,96,.05)}.tab-content{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.loading-albums{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.loading-spinner{width:40px;height:40px;border-top:4px solid var(--bg-tertiary);border:4px solid var(--bg-tertiary);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-albums p{color:var(--text-secondary);font-size:1rem}.albums-section{max-width:1200px;margin:0 auto}.future-features{margin-top:3rem;padding-top:2rem;border-top:2px solid var(--border-color)}.future-features h3{text-align:center;color:var(--text-primary);margin-bottom:2rem}.future-features .feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:1.5rem;gap:1.5rem;max-width:800px;margin:0 auto}.feature-card.upcoming{background:linear-gradient(135deg,rgba(233,69,96,.05),rgba(241,106,132,.05));border:2px dashed var(--border-color);opacity:.8}.feature-card.upcoming:hover{opacity:1;border-color:var(--accent);transform:translateY(-2px)}.analysis-summary{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border-color)}.analysis-summary h3{margin:0 0 1rem;color:var(--text-primary);font-size:1.1rem}.analysis-stats{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:1rem;gap:1rem}.analysis-stat{text-align:center;padding:1rem;background:rgba(233,69,96,.05);border-radius:8px;border:1px solid rgba(233,69,96,.1)}.analysis-stat .stat-value{display:block;font-size:1.5rem;font-weight:700;color:var(--accent);margin-bottom:.25rem}.analysis-stat .stat-label{font-size:.8rem;color:var(--text-secondary);font-weight:500}@media (max-width:768px){.dashboard-tabs{margin-bottom:1rem}.tab-button{padding:.75rem 1rem;font-size:.9rem}.analysis-stats{grid-template-columns:1fr;gap:.5rem}.analysis-stat{padding:.75rem}.analysis-stat .stat-value{font-size:1.25rem}.future-features .feature-grid{grid-template-columns:1fr}}.photo-search{max-width:1200px;margin:0 auto;padding:0 1rem}.search-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:1rem}.search-title h2{margin:0 0 .5rem;color:var(--text-primary);font-size:1.5rem;font-weight:700}.search-title p{margin:0;color:var(--text-secondary);font-size:1rem;line-height:1.5}.search-stats{text-align:right;font-size:.9rem;color:var(--text-secondary)}.search-stats span{display:block;margin:0 0 .25rem}.search-time{font-size:.8rem;color:var(--text-muted)}.search-bar{margin-bottom:1.5rem}.search-input-container{position:relative;display:flex;align-items:center;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--border-radius);padding:0;transition:all .2s ease}.search-input-container:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(233,69,96,.1)}.search-input{flex:1 1;padding:1rem 1.25rem;border:none;background:transparent;font-size:1rem;color:var(--text-primary);outline:none}.search-input::placeholder{color:var(--text-muted)}.search-actions{display:flex;align-items:center;gap:.5rem;padding:.5rem}.advanced-filter-btn,.clear-search-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:1.1rem}.advanced-filter-btn:hover,.clear-search-btn:hover{background:var(--bg-tertiary)}.advanced-filter-btn.active{background:var(--accent);color:var(--text-white)}.quick-search-buttons{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.quick-search-btn{padding:.5rem 1rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-secondary);border-radius:20px;cursor:pointer;transition:all .2s ease;font-size:.9rem;font-weight:500}.quick-search-btn:hover{background:var(--accent);color:var(--text-white);border-color:var(--accent);transform:translateY(-1px)}.quick-search-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.advanced-filters{background:var(--bg-secondary);border-radius:var(--border-radius);padding:2rem;border:1px solid var(--border-color)}.advanced-filters,.filter-section{margin-bottom:2rem}.filter-section:last-child{margin-bottom:0}.filter-section h4{margin:0 0 1rem;color:var(--text-primary);font-size:1rem;font-weight:600}.date-inputs{display:flex;align-items:center;gap:1rem}.date-input{padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;transition:border-color .2s ease}.date-input:focus{outline:none;border-color:var(--accent)}.tag-input-container{margin-bottom:1rem}.tag-input{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;transition:border-color .2s ease}.tag-input:focus{outline:none;border-color:var(--accent)}.selected-tags{display:flex;gap:.5rem;flex-wrap:wrap}.tag-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .75rem;background:var(--accent);color:var(--text-white);border-radius:16px;font-size:.8rem;font-weight:500}.tag-remove-btn{background:none;border:none;color:var(--text-white);cursor:pointer;font-size:1rem;line-height:1;opacity:.8;transition:opacity .2s ease}.tag-remove-btn:hover{opacity:1}.radio-group{display:flex;flex-direction:column;gap:.75rem}.radio-option{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem;color:var(--text-secondary)}.radio-option input[type=radio]{margin:0;accent-color:var(--accent)}.sort-select{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:border-color .2s ease}.sort-select:focus{outline:none;border-color:var(--accent)}.search-results{min-height:400px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem}.no-results{text-align:center;padding:4rem 2rem}.no-results-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.no-results h3{margin:0 0 1rem;color:var(--text-primary);font-size:1.25rem;font-weight:600}.no-results p{margin:0;color:var(--text-secondary);font-size:1rem}.search-placeholder{text-align:center;padding:4rem 2rem}.placeholder-icon{font-size:4rem;margin-bottom:1.5rem;opacity:.5}.search-placeholder h3{margin:0 0 1rem;color:var(--text-primary);font-size:1.5rem;font-weight:600}.search-placeholder p{margin:0 0 2rem;color:var(--text-secondary);font-size:1rem;line-height:1.5}.search-tips{max-width:600px;margin:0 auto;text-align:left}.search-tips h4{margin:0 0 1rem;color:var(--text-primary);font-size:1.1rem;font-weight:600}.search-tips ul{list-style:none;padding:0;margin:0}.search-tips li{margin-bottom:.5rem;color:var(--text-secondary);font-size:.9rem;line-height:1.4}.search-tips strong{color:var(--accent);font-weight:600}.photo-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:1.5rem;gap:1.5rem;margin-bottom:2rem}.photo-item{background:var(--bg-primary);border-radius:var(--border-radius);overflow:hidden;box-shadow:var(--shadow-md);transition:all .3s ease;cursor:pointer}.photo-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.photo-thumbnail{position:relative;width:100%;height:200px;overflow:hidden;background:var(--bg-tertiary)}.photo-image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.photo-item:hover .photo-image{transform:scale(1.05)}.photo-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:var(--bg-tertiary);opacity:.5}.photo-info{padding:1rem}.photo-title{margin:0 0 .5rem;color:var(--text-primary);font-size:.9rem;font-weight:600;line-height:1.3;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.photo-meta{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.75rem}.photo-date,.photo-location{font-size:.8rem;color:var(--text-muted)}.photo-tags{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.photo-tag{color:var(--accent);background:rgba(233,69,96,.1);padding:.2rem .5rem;border-radius:10px}.photo-tag,.photo-tag-more{font-size:.75rem;font-weight:500}.photo-tag-more{color:var(--text-muted)}.load-more-container{text-align:center;margin:2rem 0}.load-more-btn{padding:.75rem 2rem;background:var(--accent);color:var(--text-white);border:none;border-radius:25px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease}.load-more-btn:hover{background:var(--accent-light);transform:translateY(-1px)}.photo-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.photo-modal{position:relative;background:var(--bg-primary);border-radius:var(--border-radius);max-width:90vw;max-height:90vh;overflow:auto;box-shadow:var(--shadow-xl)}.modal-close-btn{position:absolute;top:1rem;right:1rem;width:40px;height:40px;border:none;background:rgba(0,0,0,.8);color:var(--text-white);border-radius:50%;cursor:pointer;font-size:1.2rem;z-index:1001;transition:background-color .2s ease}.modal-close-btn:hover{background:#000}.modal-content{display:grid;grid-template-columns:1fr 350px;grid-gap:0;gap:0;min-height:500px}.photo-display{display:flex;align-items:center;justify-content:center;background:var(--bg-dark);min-height:500px}.modal-photo{max-width:100%;max-height:80vh;object-fit:contain}.photo-details{padding:2rem;overflow-y:auto;background:var(--bg-primary)}.photo-details h3{margin:0 0 2rem;color:var(--text-primary);font-size:1.25rem;font-weight:700;word-break:break-word}.detail-section{margin-bottom:2rem}.detail-section:last-child{margin-bottom:0}.detail-section h4{margin:0 0 1rem;color:var(--text-primary);font-size:1rem;font-weight:600}.detail-section p{margin:0 0 .5rem;color:var(--text-secondary);font-size:.9rem;line-height:1.4}.detail-section p:last-child{margin-bottom:0}.modal-tags{display:flex;gap:.5rem;flex-wrap:wrap}.modal-tag{font-size:.8rem;color:var(--accent);background:rgba(233,69,96,.1);padding:.4rem .75rem;border-radius:12px;font-weight:500}@media (max-width:768px){.photo-search{padding:0 .5rem}.search-header{flex-direction:column;align-items:flex-start;gap:1rem}.search-stats{text-align:left}.quick-search-buttons{gap:.5rem}.quick-search-btn{font-size:.8rem;padding:.4rem .8rem}.advanced-filters{padding:1.5rem}.date-inputs{flex-direction:column;align-items:stretch}.photo-gallery{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.photo-thumbnail{height:180px}.modal-content{grid-template-columns:1fr;max-width:95vw}.photo-display{min-height:300px}.photo-details{padding:1.5rem}}@media (max-width:480px){.photo-gallery{grid-template-columns:1fr}.photo-item{max-width:100%}.search-input{font-size:16px}}