@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600;700&display=swap";@font-face{font-family:Brown Sugar;src:url(/fonts/Brown-Sugar-Regular.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Tan Pearl;src:url(/fonts/tan-pearl.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}:root{font-family:Playfair Display,Georgia,serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;width:100%;height:100vh;overflow-x:hidden}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;cursor:pointer;transition:border-color .25s}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}:root{--color-primary: #e0d7c6;--color-primary-dark: #414040;--color-primary-gradient: linear-gradient(135deg, #e0d7c6 0%, #c9c2a9 100%);--color-bg-main: #e0d7c6;--color-bg-secondary: #e0d7c6;--color-bg-tertiary: #e0d7c6;--color-text-primary: #414040;--color-text-secondary: #ffffff;--color-text-tertiary: #666;--color-text-light: #888;--color-header-bg: #e0d7c6;--color-header-text: #414040;--color-border-light: #e0e0e0;--color-border-medium: #f0f0f0;--color-card-bg: white;--color-card-bg-transparent: rgba(255, 255, 255, .85);--color-card-shadow: rgba(0, 0, 0, .1);--color-card-shadow-hover: rgba(0, 0, 0, .15);--color-card-shadow-strong: rgba(0, 0, 0, .2);--color-overlay: rgba(0, 0, 0, .3);--color-dropdown-bg: white;--color-avatar-placeholder-bg: white;--color-avatar-placeholder-text: #414040;--color-lang-btn-bg: transparent;--color-lang-btn-hover-bg: rgba(255, 255, 255, .3);--color-lang-btn-active-bg: white;--color-lang-btn-active-text: #414040;--color-lang-btn-border: white;--color-lang-btn-text: #414040;--color-error-bg: #f8d7da;--color-error-text: #721c24;--color-error-border: #f5c6cb;--color-success-bg: #d4edda;--color-success-text: #155724;--color-success-border: #c3e6cb;--color-btn-secondary: #6c757d;--color-btn-secondary-hover: #5a6268;--color-btn-logout: #dc3545;--color-btn-logout-hover: #c82333;--image-brightness: .7;--color-watermark: rgba(0, 0, 0, .35)}*{margin:0;padding:0;box-sizing:border-box}#root{width:100%;height:100%}.app{width:100vw;min-height:100vh;height:100vh;background-image:url(/background.jpg);background-size:cover;background-position:center center;background-repeat:no-repeat;background-attachment:fixed;display:flex;align-items:center;justify-content:center;padding:20px;position:fixed;inset:0;overflow-y:auto}.app:before{content:"";position:absolute;inset:0;background:#0000004d;z-index:0}.app:after{content:"Developed by Cam";position:fixed;bottom:15px;right:20px;font-size:12px;color:var(--color-primary);text-shadow:1px 1px 3px rgba(0,0,0,.8);letter-spacing:.5px;z-index:9999;pointer-events:none;-webkit-user-select:none;user-select:none}.auth-container,.profile-container{position:relative;z-index:1}.auth-container{width:100%;max-width:450px;margin:0 auto}.auth-card{background:var(--color-bg-main);border-radius:10px;padding:40px;box-shadow:0 10px 25px var(--color-card-shadow-strong)}.auth-card h2{color:var(--color-text-primary);margin-bottom:30px;text-align:center;font-size:28px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:var(--color-text-primary);font-family:Montserrat,Helvetica,Arial,sans-serif;font-weight:600;font-size:15px;letter-spacing:.5px}.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 15px;border:2px solid var(--color-border-light);border-radius:6px;font-family:Montserrat,Helvetica,Arial,sans-serif;font-size:15px;transition:border-color .3s;background:var(--color-bg-main);color:var(--color-text-primary)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary)}.form-group textarea{resize:vertical}.form-group small{display:block;margin-top:5px;color:var(--color-text-light);font-size:12px}.btn-primary{width:100%;padding:14px;background:var(--color-primary-gradient);color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px var(--color-card-shadow-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{padding:12px 24px;background:var(--color-btn-secondary);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background .3s}.btn-secondary:hover:not(:disabled){background:var(--color-btn-secondary-hover)}.btn-logout{padding:10px 20px;background:var(--color-btn-logout);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background .3s}.btn-logout:hover{background:var(--color-btn-logout-hover)}.error-message{background:var(--color-error-bg);color:var(--color-error-text);padding:12px;border-radius:6px;margin-bottom:20px;border:1px solid var(--color-error-border);font-size:14px}.success-message{background:var(--color-success-bg);color:var(--color-success-text);padding:12px;border-radius:6px;margin-bottom:20px;border:1px solid var(--color-success-border);font-size:14px}.auth-link{text-align:center;margin-top:20px;color:var(--color-text-tertiary);font-size:14px}.auth-link a{color:var(--color-primary);text-decoration:none;font-weight:600}.auth-link a:hover{text-decoration:underline}.profile-container{width:100%;max-width:600px;margin:0 auto}.profile-card{background:var(--color-bg-main);border-radius:10px;padding:40px;box-shadow:0 10px 25px var(--color-card-shadow-strong)}.profile-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid var(--color-border-medium)}.profile-header h2{color:var(--color-text-primary);font-size:28px;margin:0}.avatar-container{text-align:center;margin-bottom:30px}.avatar{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid var(--color-primary);box-shadow:0 4px 10px var(--color-card-shadow)}.profile-view{width:100%}.profile-info{margin-bottom:30px}.info-row{display:flex;padding:15px 0;border-bottom:1px solid var(--color-border-medium)}.info-row:last-child{border-bottom:none}.info-label{font-weight:600;color:var(--color-text-secondary);width:150px;flex-shrink:0}.info-value{color:var(--color-text-primary);flex-grow:1}.profile-edit{width:100%}.button-group{display:flex;gap:15px;margin-top:20px}.button-group button{flex:1}.dashboard-container{width:100vw;min-height:100vh;background:var(--color-bg-main);position:fixed;inset:0;overflow-y:auto;z-index:10}.dashboard-header{background:var(--color-header-bg);padding:15px 40px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px var(--color-card-shadow);position:relative;z-index:10;width:100%;min-height:60px}.wedding-title{color:var(--color-header-text);font-size:28px;margin:0;flex-shrink:0;white-space:nowrap}.profile-menu-container{position:relative}.profile-avatar-button{cursor:pointer;width:50px;height:50px;border-radius:50%;overflow:hidden;border:3px solid var(--color-header-text);transition:transform .2s}.profile-avatar-button:hover{transform:scale(1.05)}.header-avatar{width:100%;height:100%;object-fit:cover}.header-avatar-placeholder{width:100%;height:100%;background:var(--color-avatar-placeholder-bg);color:var(--color-avatar-placeholder-text);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700}.profile-dropdown{position:absolute;top:60px;right:0;background:var(--color-dropdown-bg);border-radius:8px;box-shadow:0 4px 20px var(--color-card-shadow-hover);min-width:220px;z-index:1000;overflow:hidden;border:1px solid var(--color-border-light)}.profile-dropdown-header{padding:15px;border-bottom:1px solid var(--color-border-medium)}.profile-dropdown-name{font-weight:600;color:var(--color-text-primary);margin:0 0 5px}.profile-dropdown-email{font-size:13px;color:var(--color-text-tertiary);margin:0}.dropdown-item{width:100%;padding:12px 15px;background:none;border:none;text-align:left;cursor:pointer;color:var(--color-text-primary);font-size:14px;transition:background .2s}.dropdown-item:hover{background:var(--color-bg-secondary)}.dropdown-item.logout{color:var(--color-btn-logout);border-top:1px solid var(--color-border-medium)}.wedding-content{max-width:1200px;margin:0 auto;padding:40px 20px;position:relative;z-index:5}.wedding-hero{text-align:center;margin-bottom:60px}.couple-names{font-size:48px;color:var(--color-primary);margin:0 0 10px;font-weight:300;letter-spacing:2px;text-shadow:2px 2px 4px rgba(0,0,0,.7)}.wedding-date{font-size:32px;color:var(--color-primary);margin:0 0 15px;font-weight:400;letter-spacing:3px;text-shadow:2px 2px 4px rgba(0,0,0,.7)}.wedding-tagline{font-size:18px;color:var(--color-primary);font-style:italic;text-shadow:2px 2px 4px rgba(0,0,0,.7)}.floating-menu{display:flex;flex-direction:column;gap:20px;max-width:250px;margin:0 auto;padding:20px 20px 100px}.menu-item{display:flex;align-items:center;justify-content:center;padding:15px 25px;background:#ffffff73;border:2px solid var(--color-primary);border-radius:50px;cursor:pointer;transition:all .3s;font-size:18px;font-weight:600;color:var(--color-text-primary);box-shadow:0 4px 15px #0003;width:fit-content;min-width:200px;margin:0 auto}.menu-item:hover{background:#e0d7c673;transform:translateY(-3px);box-shadow:0 6px 20px #0000004d}.menu-text{text-align:center;color:var(--color-primary);text-shadow:2px 2px 4px rgba(0,0,0,.7);font-weight:300;font-family:Tan Pearl,Times,serif;font-size:15px}.page-container{width:100vw;min-height:100vh;background:var(--color-bg-main);padding:40px 20px 100px;overflow-y:auto;position:fixed;inset:0;z-index:10}.page-content{max-width:900px;margin:0 auto;padding-bottom:env(safe-area-inset-bottom,20px)}.page-header{text-align:center;margin-bottom:50px}.page-header h1{color:#333;font-size:42px;margin:0 0 15px}.page-subtitle{color:#555;font-size:18px;margin:0}.schedule-timeline{background:var(--color-card-bg);border-radius:12px;padding:40px;box-shadow:0 4px 15px var(--color-card-shadow)}.timeline-item{display:flex;gap:30px;border-left:3px solid var(--color-primary);padding:25px 0 25px 30px;position:relative}.timeline-item:before{content:"";position:absolute;left:-8px;top:25px;width:13px;height:13px;border-radius:50%;background:var(--color-primary)}.timeline-time{font-weight:700;color:#414040;font-size:18px;min-width:100px}.timeline-content h3{margin:0 0 10px;color:#333;font-size:22px;font-family:Tan Pearl,Times,serif}.timeline-content p{margin:0;color:#555;line-height:1.6;font-family:Bodoni Moda,Bodoni MT,Didot,serif}.dress-code-content{background:var(--color-card-bg);border-radius:12px;padding:40px;box-shadow:0 4px 15px var(--color-card-shadow)}.dress-code-section{margin-bottom:35px}.dress-code-section:last-child{margin-bottom:0}.dress-code-section h3{color:#414040;font-size:24px;margin:0 0 15px;font-family:Tan Pearl,Times,serif}.dress-code-section p{color:#555;line-height:1.8;margin:0;font-family:Bodoni Moda,Bodoni MT,Didot,serif}.dress-code-section ul{list-style:none;padding:0;margin:15px 0 0}.dress-code-section li{color:#555;padding:8px 0 8px 25px;position:relative;font-family:Bodoni Moda,Bodoni MT,Didot,serif}.dress-code-section li:before{content:"•";color:#414040;font-weight:700;position:absolute;left:0;font-size:20px}.faq-list{display:flex;flex-direction:column;gap:20px}.faq-item{background:var(--color-card-bg);border-radius:12px;padding:30px;box-shadow:0 4px 15px var(--color-card-shadow)}.faq-item h3{color:#414040;font-size:20px;margin:0 0 15px;font-family:Tan Pearl,Times,serif}.faq-item p{color:#555;line-height:1.7;margin:0;font-family:Bodoni Moda,Bodoni MT,Didot,serif}.things-to-do-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:25px;margin-bottom:40px}.activity-card{background:var(--color-card-bg);border-radius:12px;padding:25px;box-shadow:0 4px 15px var(--color-card-shadow);transition:transform .3s,box-shadow .3s}.activity-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px var(--color-card-shadow-hover)}.activity-card h3{color:#414040;font-size:20px;margin:0 0 15px;font-family:Tan Pearl,Times,serif}.activity-card p{color:#555;line-height:1.7;margin:0;font-family:Bodoni Moda,Bodoni MT,Didot,serif}.travel-tip{background:var(--color-card-bg);border-radius:12px;padding:30px;box-shadow:0 4px 15px var(--color-card-shadow);border-left:4px solid #414040}.travel-tip h3{color:#414040;font-size:22px;margin:0 0 15px;font-family:Tan Pearl,Times,serif}.travel-tip p{color:#555;line-height:1.7;margin:0;font-family:Bodoni Moda,Bodoni MT,Didot,serif}.travel-sections{display:flex;flex-direction:column;gap:30px}.travel-section{background:var(--color-card-bg);border-radius:12px;padding:35px;box-shadow:0 4px 15px var(--color-card-shadow)}.travel-section h3{color:#414040;font-size:26px;margin:0 0 20px;font-family:Tan Pearl,Times,serif}.travel-section p{color:#555;line-height:1.8;margin:0 0 10px;font-family:Bodoni Moda,Bodoni MT,Didot,serif}.travel-section ul{list-style:none;padding:0;margin:15px 0 0}.travel-section li{color:#555;padding:10px 0 10px 25px;position:relative;line-height:1.7;font-family:Bodoni Moda,Bodoni MT,Didot,serif}.travel-section li:before{content:"•";color:#414040;font-weight:700;position:absolute;left:0;font-size:20px}.hotel-list{display:flex;flex-direction:column;gap:20px;margin-top:20px}.hotel-item{background:var(--color-bg-secondary);padding:20px;border-radius:8px;border-left:3px solid #414040}.hotel-item h4{color:#333;font-size:20px;margin:0 0 8px;font-family:Tan Pearl,Times,serif}.hotel-item p{margin:5px 0;color:#555;font-family:Bodoni Moda,Bodoni MT,Didot,serif}.hotel-detail{font-size:14px;color:#666}.wedding-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:25px;margin-bottom:40px}.wedding-card{background:var(--color-card-bg-transparent);border-radius:12px;padding:30px;box-shadow:0 4px 15px var(--color-card-shadow);transition:transform .3s,box-shadow .3s}.wedding-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px var(--color-card-shadow-hover)}.card-icon{font-size:36px;margin-bottom:15px}.wedding-card h3{color:var(--color-text-primary);font-size:22px;margin:0 0 15px}.card-primary{font-size:18px;font-weight:600;color:var(--color-primary);margin:10px 0}.card-secondary{font-size:15px;color:var(--color-text-tertiary);margin:5px 0}.card-detail{font-size:14px;color:var(--color-text-secondary);margin:8px 0}.rsvp-button,.registry-button{width:100%;padding:12px;margin-top:15px;background:var(--color-primary-gradient);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:transform .2s}.rsvp-button:hover,.registry-button:hover{transform:translateY(-2px)}.additional-info{background:var(--color-bg-secondary);border-radius:12px;padding:30px;margin-top:40px}.additional-info h3{color:var(--color-text-primary);font-size:24px;margin:0 0 25px}.info-section{margin-bottom:25px}.info-section h4{color:var(--color-primary);font-size:18px;margin:0 0 10px}.info-section p{color:var(--color-text-secondary);line-height:1.6;margin:0}.btn-back{padding:10px 20px;background:var(--color-primary);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background .3s}.btn-back:hover{background:var(--color-primary-dark)}.profile-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}.photo-marquee-container{position:fixed;top:0;left:0;width:100vw;height:100vh;overflow:hidden;z-index:0}.photo-marquee{width:100%;height:100%;overflow:hidden;display:flex;align-items:center}.photo-marquee-track{display:flex;gap:0;will-change:transform;height:100%;transform:translateZ(0);-webkit-transform:translate3d(0,0,0);backface-visibility:hidden;-webkit-backface-visibility:hidden}.marquee-photo{height:100vh;width:100vw;object-fit:cover;flex-shrink:0;filter:brightness(var(--image-brightness));transform:translateZ(0);-webkit-transform:translateZ(0)}.language-buttons{display:flex;gap:10px}.lang-btn{padding:12px 30px;background:var(--color-lang-btn-bg);color:var(--color-lang-btn-text);border:2px solid var(--color-lang-btn-border);border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;text-transform:uppercase;letter-spacing:1px;outline:none}.lang-btn:focus{outline:2px solid #414040;outline-offset:2px}.lang-btn:hover{background:var(--color-lang-btn-hover-bg);border-color:#414040;transform:translateY(-2px)}.lang-btn.active{background:var(--color-lang-btn-active-bg);color:var(--color-lang-btn-active-text);border-color:#414040;box-shadow:0 4px 15px var(--color-card-shadow-hover)}.dashboard-header{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}.theme-toggle-btn{padding:12px 20px;background:var(--color-lang-btn-bg);color:var(--color-header-text);border:2px solid var(--color-header-text);border-radius:8px;font-size:20px;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;min-width:54px}.theme-toggle-btn:hover{background:var(--color-lang-btn-hover-bg);transform:translateY(-2px);filter:brightness(1.2)}.header-controls{display:flex;align-items:center;gap:15px;flex-shrink:0}.rsvp-container{width:100vw;min-height:100vh;background:var(--color-bg-main);padding:40px 20px;overflow-y:auto;position:fixed;inset:0;z-index:10}.rsvp-card{max-width:800px;margin:0 auto;background:var(--color-card-bg);border-radius:12px;padding:40px;box-shadow:0 4px 15px var(--color-card-shadow)}.btn-back-inline{padding:10px 20px;background:var(--color-primary);color:#fff;border:2px solid #000000;border-radius:6px;font-size:14px;font-weight:800;color:#000;cursor:pointer;transition:background .3s;margin-bottom:30px}.btn-back-inline:hover{background:var(--color-primary-dark)}.rsvp-header{text-align:center;margin-bottom:40px;padding-bottom:30px;border-bottom:2px solid var(--color-border-medium)}.rsvp-header h1{color:var(--color-primary);font-size:42px;margin:0 0 10px;font-weight:300;letter-spacing:2px}.rsvp-subtitle{font-family:Bodoni Moda,Bodoni MT,Didot,serif;font-size:20px;color:var(--color-text-secondary);margin:5px 0}.rsvp-date{font-family:Montserrat,Helvetica,Arial,sans-serif;font-size:16px;color:var(--color-text-tertiary);margin:5px 0}.rsvp-deadline{font-family:Montserrat,Helvetica,Arial,sans-serif;font-size:14px;color:var(--color-primary);font-weight:600;margin-top:15px}.rsvp-form{display:flex;flex-direction:column;gap:30px}.form-section{padding:25px;background:var(--color-bg-secondary);border-radius:8px}.form-section h3{color:var(--color-text-primary);font-family:Tan Pearl,Times,serif;font-weight:400;font-size:24px;margin:0 0 20px;padding-bottom:10px;border-bottom:2px solid var(--color-border-light)}.disabled-input{background:var(--color-bg-tertiary)!important;cursor:not-allowed;opacity:.7}.radio-group{display:flex;flex-direction:column;gap:12px}.radio-option{display:flex;align-items:center;padding:15px;background:var(--color-bg-main);border:2px solid var(--color-border-light);border-radius:8px;cursor:pointer;transition:all .3s}.radio-option:hover{border-color:var(--color-primary);background:var(--color-bg-secondary)}.radio-option input[type=radio]{margin-right:12px;width:20px;height:20px;cursor:pointer}.radio-option span{font-family:Montserrat,Helvetica,Arial,sans-serif;font-size:16px;color:var(--color-text-primary);font-weight:500}.rsvp-success{text-align:center;padding:60px 20px}.success-icon{width:80px;height:80px;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:48px;margin:0 auto 30px;box-shadow:0 4px 15px #4caf504d}.rsvp-success h2{font-family:Tan Pearl,Times,serif;color:var(--color-text-primary);font-size:36px;margin:0 0 15px}.rsvp-success p{font-family:Montserrat,Helvetica,Arial,sans-serif;color:var(--color-text-secondary);font-size:18px;margin:10px 0}.rsvp-details{color:var(--color-primary)!important;font-weight:600;margin-top:20px!important}.registry-container{width:100vw;min-height:100vh;background:var(--color-bg-main);padding:40px 20px;overflow-y:auto;position:fixed;inset:0;z-index:10}.registry-content{max-width:1200px;margin:0 auto}.registry-header{text-align:center;margin-bottom:50px;padding:40px 20px;background:var(--color-card-bg);border-radius:12px;box-shadow:0 4px 15px var(--color-card-shadow)}.registry-header h1{color:var(--color-primary);font-size:42px;margin:0 0 10px;font-weight:300;letter-spacing:2px}.registry-subtitle{font-size:20px;color:var(--color-text-secondary);margin:5px 0 20px}.registry-description{max-width:700px;margin:0 auto;color:var(--color-text-tertiary);line-height:1.6;font-size:16px}.registry-stores{margin-bottom:50px}.registry-stores h2{color:var(--color-text-primary);font-size:28px;margin:0 0 25px;text-align:center}.store-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:40px}.store-link{display:flex;align-items:center;gap:15px;padding:25px;background:var(--color-card-bg);border-radius:12px;box-shadow:0 4px 15px var(--color-card-shadow);text-decoration:none;transition:transform .3s,box-shadow .3s}.store-link:hover{transform:translateY(-5px);box-shadow:0 8px 25px var(--color-card-shadow-hover)}.store-icon{font-size:48px;flex-shrink:0}.store-link h3{color:var(--color-text-primary);font-size:20px;margin:0 0 5px}.store-link p{color:var(--color-primary);font-size:14px;margin:0;font-weight:600}.registry-items-section{margin-bottom:50px}.registry-items-section h2{color:var(--color-text-primary);font-size:28px;margin:0 0 25px;text-align:center}.registry-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:25px}.registry-item{background:var(--color-card-bg);border-radius:12px;padding:25px;box-shadow:0 4px 15px var(--color-card-shadow);transition:transform .3s,box-shadow .3s;position:relative;display:flex;flex-direction:column}.registry-item:hover{transform:translateY(-5px);box-shadow:0 8px 25px var(--color-card-shadow-hover)}.registry-item.purchased{opacity:.6}.purchased-badge{position:absolute;top:10px;right:10px;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600}.item-image{font-size:64px;text-align:center;margin-bottom:15px}.item-details{flex-grow:1;display:flex;flex-direction:column}.item-details h3{color:var(--color-text-primary);font-size:18px;margin:0 0 10px;min-height:44px}.item-price{color:var(--color-primary);font-size:20px;font-weight:600;margin:5px 0}.item-store{color:var(--color-text-tertiary);font-size:14px;margin:5px 0 15px}.item-button{display:inline-block;padding:10px 20px;background:var(--color-primary-gradient);color:#fff;text-decoration:none;border-radius:6px;text-align:center;font-weight:600;font-size:14px;transition:transform .2s;margin-top:auto}.item-button:hover{transform:translateY(-2px)}.registry-notes{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:25px;margin-top:40px}.note-card{background:var(--color-bg-secondary);border-radius:12px;padding:30px;border-left:4px solid var(--color-primary)}.note-card h3{color:var(--color-text-primary);font-size:20px;margin:0 0 15px}.note-card p{color:var(--color-text-secondary);line-height:1.6;margin:10px 0}.payment-info,.address-info{margin-top:15px;padding:15px;background:var(--color-bg-main);border-radius:8px}.payment-info p,.address-info p{margin:5px 0;color:var(--color-text-primary)}.song-search-section{background:var(--color-card-bg);border-radius:12px;padding:30px;margin-bottom:30px;box-shadow:0 4px 15px var(--color-card-shadow)}.song-search-section h2{color:var(--color-text-primary);font-size:24px;margin:0 0 20px;font-family:Tan Pearl,Times,serif}.song-search-form{display:flex;gap:15px;margin-bottom:20px;font-family:Montserrat,Helvetica,Arial,sans-serif}.song-search-input{flex:1 1 0;min-width:0;padding:14px 18px;border:2px solid var(--color-border-light);border-radius:8px;font-size:16px;background:var(--color-bg-main);color:var(--color-text-primary);transition:border-color .3s}.song-search-input:focus{outline:none;border-color:var(--color-primary)}.song-search-btn{flex:0 0 140px;padding:12px 16px;white-space:nowrap}.search-results{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto;font-family:Montserrat,Helvetica,Arial,sans-serif}.search-result-item{display:flex;align-items:center;gap:15px;padding:15px;background:#fff;border-radius:8px;border:1px solid var(--color-border-light);transition:transform .2s,box-shadow .2s}.search-result-item:hover{transform:translate(5px);box-shadow:0 2px 8px var(--color-card-shadow)}.song-artwork{width:60px;height:60px;border-radius:8px;object-fit:cover;flex-shrink:0}.song-info{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0;overflow:hidden;font-family:Montserrat,Helvetica,Arial,sans-serif}.song-title{display:block;font-weight:600;color:#333;font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-artist{display:block;color:#555;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-requested-by{color:var(--color-text-light);font-size:12px}.request-btn{padding:10px 20px;font-size:14px;flex-shrink:0;width:auto;font-family:Montserrat,Helvetica,Arial,sans-serif}.no-results{text-align:center;color:var(--color-text-tertiary);padding:20px;font-style:italic}.song-board-section{background:var(--color-card-bg);border-radius:12px;padding:30px;box-shadow:0 4px 15px var(--color-card-shadow)}.song-board-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px}.song-board-header h2{color:var(--color-text-primary);font-size:24px;margin:0;font-family:Tan Pearl,Times,serif}.refresh-btn{padding:10px 20px}.song-board{display:flex;flex-direction:column;gap:15px;font-family:Montserrat,Helvetica,Arial,sans-serif}.song-board-item{display:flex;align-items:center;gap:15px;padding:20px;background:var(--color-bg-secondary);border-radius:10px;transition:transform .2s,box-shadow .2s}.song-board-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--color-card-shadow)}.song-rank{font-size:24px;font-weight:700;color:var(--color-primary-dark);min-width:50px;text-align:center}.vote-section{display:flex;flex-direction:column;align-items:center;gap:8px;margin-left:auto;flex-shrink:0}.vote-count{font-size:14px;font-weight:600;color:var(--color-text-primary)}.vote-btn{padding:10px 20px;background:var(--color-primary-gradient);color:#fff;border:none;border-radius:25px;font-size:14px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;font-family:Montserrat,Helvetica,Arial,sans-serif}.vote-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px var(--color-card-shadow-hover)}.vote-btn:disabled{opacity:.6;cursor:not-allowed}.vote-btn.voted{background:var(--color-btn-secondary)}.delete-btn{padding:8px 16px;background:var(--color-btn-logout);color:#fff;border:none;border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;transition:background .2s,transform .2s;font-family:Montserrat,Helvetica,Arial,sans-serif}.delete-btn:hover{background:var(--color-btn-logout-hover);transform:scale(1.05)}.loading-text,.no-songs-text{text-align:center;color:var(--color-text-tertiary);padding:40px 20px;font-size:16px}.admin-dashboard{padding-bottom:80px}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:20px;margin-bottom:35px}.admin-stat-card{background:var(--color-card-bg);border-radius:12px;padding:25px 20px;box-shadow:0 4px 15px var(--color-card-shadow);display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center}.admin-stat-number{font-size:36px;font-weight:700;color:var(--color-text-primary);font-family:Montserrat,Helvetica,Arial,sans-serif}.admin-stat-label{font-size:13px;font-weight:600;color:var(--color-text-tertiary);font-family:Montserrat,Helvetica,Arial,sans-serif;text-transform:uppercase;letter-spacing:.5px}.admin-tabs{display:flex;gap:0;margin-bottom:25px;border-bottom:2px solid var(--color-border-light)}.admin-tab{padding:14px 30px;background:none;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;font-size:16px;font-weight:600;color:var(--color-text-tertiary);cursor:pointer;font-family:Montserrat,Helvetica,Arial,sans-serif;transition:color .2s,border-color .2s}.admin-tab:hover{color:var(--color-text-primary)}.admin-tab.active{color:var(--color-text-primary);border-bottom-color:var(--color-text-primary)}.admin-table-section{background:var(--color-card-bg);border-radius:12px;padding:25px;box-shadow:0 4px 15px var(--color-card-shadow)}.admin-table-header{display:flex;justify-content:flex-end;margin-bottom:20px}.admin-table-wrapper{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-family:Montserrat,Helvetica,Arial,sans-serif;font-size:14px}.admin-table thead th{text-align:left;padding:12px 15px;font-weight:700;color:var(--color-text-primary);border-bottom:2px solid var(--color-border-light);white-space:nowrap;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.admin-table tbody td{padding:12px 15px;color:var(--color-text-primary);border-bottom:1px solid var(--color-border-medium);max-width:200px;overflow:hidden;text-overflow:ellipsis}.admin-table tbody tr:hover{background:var(--color-bg-secondary)}.admin-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.badge-yes{background:var(--color-success-bg);color:var(--color-success-text)}.badge-no{background:var(--color-error-bg);color:var(--color-error-text)}@media(max-width:600px){.song-search-form{flex-direction:column}.song-search-btn{width:100%}.search-result-item{flex-wrap:wrap}.search-result-item .song-info{flex:1 1 calc(100% - 90px)}.search-result-item .request-btn{width:100%;margin-top:10px}.song-board-item{flex-wrap:wrap}.song-board-item .song-rank{min-width:40px;font-size:20px}.song-board-item .song-artwork{width:50px;height:50px}.song-board-item .song-info{flex:1 1 calc(100% - 120px)}.song-board-item .vote-section{width:100%;flex-direction:row;justify-content:space-between;margin-top:15px;padding-top:15px;border-top:1px solid var(--color-border-light)}.song-board-header{flex-direction:column;gap:15px;align-items:stretch}.song-board-header h2{text-align:center}.refresh-btn{width:100%}}.search-icon-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;padding:6px;color:var(--color-header-text);opacity:.8;transition:opacity .2s}.search-icon-btn:hover{opacity:1}.search-icon-btn svg{width:22px;height:22px}.page-search-btn{position:fixed;top:16px;right:16px;z-index:50;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:#414040;padding:4px;transition:color .2s}.page-search-btn:hover{color:#000}.page-search-btn svg{width:26px;height:26px}.search-overlay-backdrop{position:fixed;inset:0;z-index:2000;background:#0000008c;display:flex;align-items:flex-start;justify-content:center;padding-top:80px}.search-overlay-modal{background:var(--color-card-bg);border-radius:12px;width:100%;max-width:560px;margin:0 16px;box-shadow:0 8px 32px #00000040;overflow:hidden}.search-overlay-input-row{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--color-border-light)}.search-overlay-icon{width:20px;height:20px;flex-shrink:0;color:var(--color-text-tertiary)}.search-overlay-input{flex:1;border:none;outline:none;font-size:16px;background:transparent;color:var(--color-text-primary)}.search-overlay-input::placeholder{color:var(--color-text-light)}.search-overlay-close{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;padding:4px;color:var(--color-text-tertiary);transition:color .2s}.search-overlay-close:hover{color:var(--color-text-primary)}.search-overlay-close svg{width:18px;height:18px}.search-overlay-results{max-height:360px;overflow-y:auto;padding:8px 0}.search-overlay-no-results{text-align:center;color:var(--color-text-tertiary);padding:24px 16px;margin:0}.search-result-item{display:flex;flex-direction:column;gap:4px;width:100%;text-align:left;background:none;border:none;padding:12px 16px;cursor:pointer;transition:background .15s}.search-result-item:hover{background:var(--color-bg-secondary)}.search-result-page{font-weight:600;font-size:14px;color:var(--color-text-primary)}.search-result-snippet{font-size:13px;color:var(--color-text-tertiary);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:600px){.search-overlay-backdrop{padding-top:40px}.search-overlay-input{font-size:16px}.page-search-btn{top:12px;right:12px}}
