.header{display:flex;align-items:center;padding:1rem 2rem;background:#1a1a2ecc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.1);position:sticky;top:0;z-index:1000;transition:all .3s ease}.header-brand{flex-shrink:0}.logo{display:flex;align-items:center;gap:.5rem;font-size:1.5rem;font-weight:700;color:#fff;text-decoration:none;transition:all .3s ease}.logo:hover{transform:scale(1.05)}.logo-icon{font-size:1.8rem;filter:drop-shadow(0 0 10px rgba(255,255,255,.3))}.logo-text{background:linear-gradient(135deg,#667eea,#764ba2);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;font-weight:700}.header-nav{display:flex;gap:.25rem;margin-left:2rem;transition:all .3s ease}.nav-link{display:flex;align-items:center;gap:.5rem;color:#fffc;text-decoration:none;font-weight:500;padding:.5rem 1rem;border-radius:8px;transition:all .3s ease;position:relative;overflow:hidden}.nav-link:hover{color:#fff;background:#ffffff1a;transform:translateY(-1px)}.nav-link:before{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background:linear-gradient(135deg,#667eea,#764ba2);transition:all .3s ease;transform:translate(-50%)}.nav-link:hover:before{width:80%}.nav-icon{font-size:1.1rem;opacity:.8}.header-auth{display:flex;align-items:center;gap:1rem;margin-left:auto}.user-profile{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ffffff0d;border-radius:20px;border:1px solid rgba(255,255,255,.1)}.user-avatar{font-size:1.2rem;padding:.25rem;background:#ffffff1a;border-radius:50%;display:flex;align-items:center;justify-content:center}.welcome-text{color:#fff;font-weight:500;font-size:.9rem;white-space:nowrap}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);border:none;cursor:pointer;font-size:.9rem;position:relative;overflow:hidden}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66;background:linear-gradient(135deg,#5a6fd8,#6941a0)}.btn-ghost:hover{background:#ffffff1a;color:#fff;border-color:#ffffff4d;transform:translateY(-1px)}.btn-logout{background:#dc3545cc;color:#fff;border:1px solid rgba(220,53,69,.3)}.btn-logout:hover{background:#dc3545;transform:translateY(-1px);box-shadow:0 4px 15px #dc35454d}.mobile-menu-button{display:none;background:none;border:none;cursor:pointer;padding:.5rem;border-radius:8px;transition:all .3s ease}.mobile-menu-button:hover{background:#ffffff1a}.hamburger{display:flex;flex-direction:column;gap:3px;width:24px;height:18px;position:relative}.hamburger span{display:block;height:2px;width:100%;background:#fff;border-radius:1px;transition:all .3s ease;transform-origin:center}.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}.mobile-overlay{position:fixed;inset:0;background:#00000080;z-index:998;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@media (max-width: 1024px){.header{padding:1rem 1.5rem}.header-nav{margin-left:2rem;gap:1.5rem}}@media (max-width: 768px){.header{padding:1rem}.header-nav{position:fixed;top:0;right:-100%;width:280px;height:100vh;background:#1a1a2ef2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);flex-direction:column;padding:6rem 2rem 2rem;margin:0;gap:1rem;transition:right .3s ease;z-index:999;border-left:1px solid rgba(255,255,255,.1)}.header-nav.nav-open{right:0}.nav-link{width:100%;padding:1rem;border-radius:12px;font-size:1rem}.mobile-menu-button{display:flex;align-items:center;justify-content:center}.header-auth{display:none}.logo,.logo-text{font-size:1.3rem}}@media (max-width: 480px){.header{padding:.75rem}.logo,.logo-text{font-size:1.2rem}}.footer{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#1a1a2ecc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.1);color:#fffc;font-size:.9rem}.footer-left{display:flex;align-items:center}.footer-copy{font-weight:500;white-space:nowrap}.footer-links{display:flex;gap:1rem}.footer-link{color:#fffc;text-decoration:none;transition:color .3s ease,transform .3s ease;position:relative}.footer-link:after{content:"";position:absolute;bottom:-3px;left:0;width:0;height:2px;background:linear-gradient(135deg,#667eea,#764ba2);transition:width .3s ease}.footer-link:hover{color:#fff;transform:translateY(-1px)}.footer-link:hover:after{width:100%}@media (max-width: 768px){.footer{flex-direction:column;gap:.75rem;text-align:center}.footer-links{gap:.75rem}}.login-container{display:flex;justify-content:center;align-items:center;min-height:85vh;padding:20px;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);color:#fff}.login-card{background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:3rem;width:100%;max-width:450px;position:relative;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.login-card:hover{background:#ffffff14;border-color:#fff3;box-shadow:0 20px 40px #0000004d}.login-card h2{font-size:2.5rem;font-weight:700;text-align:center;margin-bottom:2rem;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);background-size:300% 300%;background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:gradientShift 6s ease-in-out infinite;line-height:1.2;letter-spacing:-.025em}.login-form{display:flex;flex-direction:column;gap:1.5rem}.login-button{margin-top:1rem;padding:1rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 4px 15px #667eea4d}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.login-button:disabled{background:#fff3;cursor:not-allowed;transform:none;box-shadow:none;opacity:.6}.login-button:active:not(:disabled){transform:translateY(0)}@media (max-width: 768px){.login-container{padding:1.5rem}.login-card{padding:2rem;max-width:100%}.login-card h2{font-size:2rem}}@media (max-width: 480px){.login-container{padding:1rem}.login-card{padding:1.5rem;border-radius:20px}.login-card h2{font-size:1.75rem;margin-bottom:1.5rem}.login-form{gap:1.25rem}.form-group input{padding:.875rem 1rem}.login-button{padding:.875rem 1.5rem}}.register-container{display:flex;justify-content:center;align-items:center;min-height:85vh;padding:20px;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);color:#fff}.register-card{background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:3rem;width:100%;max-width:450px;position:relative;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.register-card:hover{background:#ffffff14;border-color:#fff3;box-shadow:0 20px 40px #0000004d}.register-card h2{font-size:2.5rem;font-weight:700;text-align:center;margin-bottom:2rem;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);background-size:300% 300%;background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:gradientShift 6s ease-in-out infinite;line-height:1.2;letter-spacing:-.025em}.register-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:#fff;font-weight:600;font-size:.9rem;opacity:.9;text-transform:uppercase;letter-spacing:.5px}.form-group input{padding:1rem 1.25rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:12px;color:#fff;font-size:1rem;font-family:inherit;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.form-group input::placeholder{color:#ffffff80}.form-group input:focus{outline:none;border-color:#667eea;background:#ffffff26;box-shadow:0 0 0 3px #667eea1a}.form-group input.error{border-color:#dc3545;background:#dc35451a;box-shadow:0 0 0 3px #dc35451a}.field-error{color:#ff6b6b;font-size:.875rem;margin-top:.25rem;font-weight:500;opacity:.9}.register-button{margin-top:1rem;padding:1rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 4px 15px #667eea4d}.register-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.register-button:disabled{background:#fff3;cursor:not-allowed;transform:none;box-shadow:none;opacity:.6}.register-button:active:not(:disabled){transform:translateY(0)}.error-message{background:#dc354533;color:#fff;padding:1rem 1.25rem;border-radius:12px;margin-bottom:1rem;text-align:center;border:1px solid rgba(220,53,69,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-size:.9rem}.form-footer{margin-top:2rem;text-align:center;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1)}.form-footer p{margin:0;color:#fffc;font-size:.9rem}.form-footer a{color:#667eea;text-decoration:none;font-weight:600;transition:all .3s ease;position:relative}.form-footer a:hover{color:#764ba2;text-shadow:0 0 10px rgba(102,126,234,.5)}@media (max-width: 768px){.register-container{padding:1.5rem}.register-card{padding:2rem;max-width:100%}.register-card h2{font-size:2rem}}@media (max-width: 480px){.register-container{padding:1rem}.register-card{padding:1.5rem;border-radius:20px}.register-card h2{font-size:1.75rem;margin-bottom:1.5rem}.register-form{gap:1.25rem}.form-group input{padding:.875rem 1rem}.register-button{padding:.875rem 1.5rem}}.movie-carousel{width:100%;max-width:700px;margin:0 auto}.carousel-header{margin-bottom:1rem;text-align:center}.carousel-header h3{margin:0;font-size:1.5rem;color:#fff;font-weight:600}.carousel-container{position:relative;overflow:hidden;border-radius:16px;box-shadow:0 8px 32px #0000001a}.carousel-wrapper{overflow:hidden;width:100%}.carousel-track{display:flex;transition:transform .5s ease-in-out}.carousel-slide{flex:0 0 100%;height:400px}.movie-slide-link{display:block;height:100%;text-decoration:none;color:inherit}.movie-slide{position:relative;height:100%;display:flex;background:linear-gradient(135deg,var(--primary-dark) 0%,var(--secondary-dark) 50%,var(--accent-dark) 100%);overflow:hidden;cursor:pointer;transition:transform .3s ease}.movie-slide:hover{transform:scale(1.02)}.movie-slide:hover .slide-overlay{opacity:1}.movie-poster-container{flex:0 0 280px;height:100%;display:flex;align-items:center;justify-content:center;background:#0000001a}.movie-poster-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3rem;color:#ffffffb3}.movie-info{flex:1;padding:1.5rem;display:flex;flex-direction:column;justify-content:center;color:#fff;z-index:2}.movie-info h4{font-size:1.6rem;font-weight:700;margin:0 0 .75rem;line-height:1.2}.movie-info p{font-size:1rem;opacity:.8;margin:0;line-height:1.4}.slide-overlay{position:absolute;inset:0;background:#ffffff26;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease;z-index:3}.view-details{background:#ffffffe6;color:#333;padding:.75rem 1.5rem;border-radius:25px;font-weight:600;font-size:1rem;transform:translateY(10px);transition:transform .3s ease}.slide-overlay:hover .view-details{transform:translateY(0)}.carousel-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffffe6;border:none;border-radius:50%;width:50px;height:50px;font-size:1.5rem;font-weight:700;cursor:pointer;transition:all .3s ease;z-index:4;display:flex;align-items:center;justify-content:center;color:#333;opacity:0;visibility:hidden}.carousel-container:hover .carousel-nav{opacity:1;visibility:visible}.carousel-nav:hover{background:#fff;transform:translateY(-50%) scale(1.1)}.carousel-nav.prev{left:15px}.carousel-nav.next{right:15px}.carousel-indicators{display:flex;justify-content:center;gap:.5rem;margin-top:1rem}.indicator{width:12px;height:12px;border-radius:50%;border:none;background:#ffffff4d;cursor:pointer;transition:all .3s ease}.indicator.active{background:#fff;transform:scale(1.2)}.indicator:hover{background:#999}.carousel-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:400px;background:linear-gradient(135deg,var(--primary-dark) 0%,var(--secondary-dark) 50%,var(--accent-dark) 100%);border-radius:16px;color:#fff}.loading-spinner{font-size:3rem;animation:spin 2s linear infinite;margin-bottom:1rem}@media (max-width: 768px){.movie-carousel{max-width:100%;margin:0 1rem}.movie-slide{flex-direction:column}.movie-poster-container{flex:0 0 220px;width:100%}.movie-info{padding:1rem}.movie-info h4{font-size:1.4rem}.carousel-nav{width:40px;height:40px;font-size:1.2rem}.carousel-nav.prev{left:10px}.carousel-nav.next{right:10px}}@media (max-width: 480px){.movie-carousel{margin:0 .5rem}.carousel-header h3{font-size:1.2rem}.movie-poster-container{flex:0 0 200px}.movie-info{padding:.75rem}.movie-info h4{font-size:1.2rem}.movie-info p{font-size:.9rem}.carousel-nav{width:35px;height:35px;font-size:1rem}}.homepage-container{flex:1 0 auto;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);color:#fff;overflow:hidden!important}.hero-section{min-height:calc(100vh - var(--header-height) - var(--footer-height));display:flex;align-items:center;justify-content:space-between;padding:0 5%;max-width:1400px;margin:0 auto;gap:2.5rem}.hero-content{flex:1;max-width:750px}.hero-title{font-size:clamp(3rem,6vw,5rem);font-weight:700;line-height:1.1;margin-bottom:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);background-size:300% 300%;background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.brand-highlight{display:inline-block;background:linear-gradient(135deg,#ff6b6b,#feca57)!important;background-clip:text!important;-webkit-background-clip:text!important;-webkit-text-fill-color:transparent!important;position:relative;animation:rotateCustomGradient 3s ease-in-out infinite}.hero-subtitle{font-size:1.25rem;line-height:1.6;margin-bottom:2.5rem;opacity:.9;max-width:500px}.hero-cta{display:flex;gap:1rem;flex-wrap:wrap}.hero-visual{flex:1;display:flex;justify-content:center;align-items:center;position:relative}.hero-visual .movie-carousel{width:100%;max-width:700px}.hero-visual .movie-carousel .carousel-header h3{color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.3)}.hero-visual .movie-carousel .carousel-nav{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);color:#fff}.hero-visual .movie-carousel .carousel-nav:hover{background:#fff3;border-color:#ffffff4d}.features-section,.auth-section{padding:5rem 5% 3rem;max-width:1400px;margin:0 auto}.section-header{text-align:center;margin-bottom:4rem}.section-header h2{font-size:2.5rem;margin-bottom:1rem;font-weight:600}.section-header p{font-size:1.1rem;opacity:.8;max-width:600px;margin:0 auto}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem;margin-top:3rem}.feature-card{background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:2rem;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.feature-card:hover{transform:translateY(-8px);background:#ffffff14;border-color:#fff3;box-shadow:0 20px 40px #0000004d}.feature-card.primary{background:linear-gradient(135deg,#667eea26,#764ba226);border-color:#667eea4d}.feature-icon{margin-bottom:1.5rem}.icon{font-size:3rem;display:inline-block;padding:1rem;background:#ffffff1a;border-radius:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.feature-content h3{font-size:1.5rem;margin-bottom:1rem;font-weight:600}.feature-content p{opacity:.8;line-height:1.6;margin-bottom:1.5rem}.feature-stats{margin-bottom:2rem}.stat{display:inline-block;padding:.5rem 1rem;background:#ffffff1a;border-radius:20px;font-size:.875rem;font-weight:500}.feature-link{display:inline-flex;align-items:center;gap:.5rem;color:#fff;text-decoration:none;font-weight:600;padding:.75rem 1.5rem;background:#ffffff1a;border-radius:12px;transition:all .3s ease;border:1px solid rgba(255,255,255,.2)}.feature-link:hover{background:#fff3;transform:translate(4px)}.arrow{transition:transform .3s ease}.feature-link:hover .arrow{transform:translate(4px)}.auth-container{text-align:center;max-width:600px;margin:0 auto}.auth-container h2{font-size:2.5rem;margin-bottom:1rem;font-weight:600}.auth-container>p{font-size:1.1rem;opacity:.8;margin-bottom:3rem}.auth-benefits{display:flex;flex-direction:column;gap:1.5rem;max-width:400px;margin:0 auto}.benefit{display:flex;align-items:center;gap:1rem;padding:1rem;background:#ffffff0d;border-radius:12px;border:1px solid rgba(255,255,255,.1)}.benefit-icon{font-size:1.5rem;flex-shrink:0}.btn{display:inline-flex;align-items:center;justify-content:center;padding:1rem 2rem;border-radius:12px;font-weight:600;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);border:none;cursor:pointer;font-size:1rem;position:relative;overflow:hidden}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea66;background:linear-gradient(135deg,#5a6fd8,#6941a0)}.btn-secondary{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-secondary:hover{background:#fff3;border-color:#ffffff80;transform:translateY(-2px)}@keyframes rotateCustomGradient{0%{filter:hue-rotate(-45deg)}50%{filter:hue-rotate(0deg)}to{filter:hue-rotate(-45deg)}}@media (max-width: 1024px){.hero-section{flex-direction:column;text-align:center;padding:2rem 5%;gap:3rem}.feature-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}}@media (max-width: 768px){.hero-section{padding:1rem 4%}.hero-title{font-size:2.5rem}.hero-cta{justify-content:center}.hero-visual .movie-carousel{max-width:100%;margin:0 auto}.features-section,.auth-section{padding:3rem 4% 2rem}.feature-grid{grid-template-columns:1fr;gap:1.5rem}.feature-card{padding:1.5rem}.section-header h2{font-size:2rem}.auth-benefits{gap:1rem}.benefit{padding:.75rem}}.star-rating{display:flex;flex-direction:column;align-items:center;gap:0px;margin:0}.stars{display:flex;gap:0px}.star{font-size:48px;color:#ffffff4d;cursor:pointer;transition:color .2s ease,transform .2s ease;position:relative;-webkit-user-select:none;user-select:none}.star.interactive:hover{color:gold;transform:scale(1.1)}.star.filled{color:gold}.star.half-filled{background:linear-gradient(90deg,gold 50%,#ffffff4d 50%);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;color:gold}.star:not(.interactive){cursor:default}.rating-text{font-size:15px;color:#fffc;font-weight:500;text-shadow:0 1px 2px rgba(0,0,0,.5)}@supports not (background-clip: text){.star.half-filled{position:relative;color:#ffffff4d}.star.half-filled:before{content:"★";position:absolute;top:0;left:0;width:50%;overflow:hidden;color:gold}}.rating-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.rating-modal{background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);border-radius:16px;padding:32px;max-width:420px;width:90%;position:relative;box-shadow:0 20px 40px #0000004d;border:1px solid rgba(255,255,255,.1);color:#fff}.rating-modal-close{position:absolute;top:16px;right:20px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);font-size:20px;cursor:pointer;color:#fff;padding:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.rating-modal-close:hover{background:#fff3;border-color:#ffffff4d;transform:scale(1.05)}.rating-modal-content{text-align:center}.rating-modal-content h3{margin:0 0 12px;font-size:1.5rem;color:#fff;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.3)}.rating-modal-content .movie-title{font-size:1.1rem;color:#e2e8f0;margin:0 0 24px;font-weight:500;opacity:.9}.rating-modal-actions{display:flex;gap:16px;justify-content:center;margin-top:32px}.rating-modal-cancel,.rating-modal-confirm{padding:12px 24px;border:none;border-radius:10px;cursor:pointer;font-size:.95rem;font-weight:600;transition:all .2s ease;min-width:120px}.rating-modal-cancel{background:#ffffff1a;color:#e2e8f0;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.rating-modal-cancel:hover{background:#fff3;border-color:#ffffff4d;transform:translateY(-1px)}.rating-modal-confirm{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea4d}.rating-modal-confirm:hover:not(:disabled){background:linear-gradient(135deg,#5a67d8,#6b46c1);transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.rating-modal-confirm:disabled{background:#ffffff1a;color:#fff6;cursor:not-allowed;box-shadow:none;border:1px solid rgba(255,255,255,.1)}.movie-card,.watchlist-card{background:transparent;width:100%;height:600px;perspective:1000px;border-radius:16px}.card-inner{position:relative;width:100%;height:100%;text-align:center;transition:transform .6s;transform-style:preserve-3d;border-radius:16px}.movie-card.flipped .card-inner,.watchlist-card.flipped .card-inner{transform:rotateY(180deg)}.card-front,.card-back{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:16px;box-shadow:0 8px 25px #00000026;overflow:hidden}.card-front{background:#fff;cursor:pointer;transition:transform .3s ease,box-shadow .3s ease}.card-front:hover{transform:translateY(-5px);box-shadow:0 15px 35px #0003}.card-back{background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);transform:rotateY(180deg);display:flex;flex-direction:column;color:#fff;cursor:pointer;position:relative}.movie-poster-container{width:100%;height:100%;position:relative;overflow:hidden}.movie-poster{width:100%;height:100%;object-fit:cover}.movie-poster-fallback{width:100%;height:100%;background:linear-gradient(135deg,#f0f0f0,#e0e0e0);display:flex;align-items:center;justify-content:center;flex-direction:column}.poster-placeholder{text-align:center;color:#999}.poster-placeholder span{font-size:4rem;display:block;margin-bottom:15px}.poster-placeholder p{margin:0;font-size:1rem;font-weight:500}.card-front-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000c);color:#fff;padding:30px 15px 15px;text-align:left}.movie-title-front{font-size:1.2rem;font-weight:700;margin:0 0 8px;line-height:1.3;text-shadow:0 2px 4px rgba(0,0,0,.5);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.click-hint{font-size:.85rem;opacity:.9;margin:0;font-weight:500}.card-back-content{flex:1;display:flex;flex-direction:column;cursor:pointer;position:relative}.movie-info-back{flex:1;display:flex;flex-direction:column;padding:24px 24px 20px;text-align:left;overflow-y:auto}.click-to-flip-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);opacity:0;transition:opacity .3s ease;pointer-events:none;z-index:1}.click-to-flip-hint p{font-size:.8rem;color:#ffffffb3;margin:0;padding:8px 16px;background:#0000004d;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);white-space:nowrap}.card-back:hover .click-to-flip-hint{opacity:1}.movie-title{font-size:1.4rem;font-weight:700;color:#fff;margin:16px 0;line-height:1.3;text-shadow:0 2px 4px rgba(0,0,0,.3)}.movie-year{color:#e2e8f0;font-size:1rem;margin:0 0 8px;font-weight:500;display:inline-flex;align-items:center;gap:8px;padding:12px 16px;background:#ffffff14;border-radius:16px;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:fit-content}.movie-year:before{content:"📅";font-size:.9rem}.movie-genre{color:#cbd5e0;font-size:.9rem;margin:8px 0 16px;font-style:italic;display:inline-flex;align-items:center;gap:8px;padding:12px 16px;background:#ffffff14;border-radius:16px;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:fit-content}.movie-genre:before{content:"🎭";font-size:.9rem}.movie-rating{color:gold;font-size:1rem;margin:0 0 20px;font-weight:600;display:flex;align-items:center;gap:8px;text-shadow:0 1px 2px rgba(0,0,0,.3)}.movie-rating:before{content:"⭐";font-size:.9rem}.movie-overview-section{margin-top:auto;padding-top:15px;border-top:1px solid rgba(255,255,255,.1)}.movie-overview{color:#e2e8f0;font-size:.9rem;line-height:1.6;margin:0 0 15px;opacity:.9}.read-more-btn{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);padding:8px 16px;border-radius:8px;font-size:.85rem;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-weight:500}.read-more-btn:hover{background:#fff3;border-color:#ffffff4d;transform:translateY(-1px)}.based-on{color:#a0aec0;font-size:.85rem;margin:15px 0 0;padding:12px;background:#ffffff0d;border-radius:8px;border-left:3px solid #667eea}.based-on strong{color:#90cdf4;font-weight:600}.add-to-watchlist-btn,.remove-from-watchlist-btn{flex:1;border:none;padding:12px 16px;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;color:#fff}.add-to-watchlist-btn{background:linear-gradient(135deg,#48bb78,#38a169);box-shadow:0 4px 15px #48bb784d}.add-to-watchlist-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #48bb7866;background:linear-gradient(135deg,#38a169,#2f855a)}.remove-from-watchlist-btn{background:linear-gradient(135deg,#f56565,#e53e3e);box-shadow:0 4px 15px #f565654d}.remove-from-watchlist-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f5656566;background:linear-gradient(135deg,#e53e3e,#c53030)}.movie-modal{background:#1a1a2ef2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:1.25rem;max-width:600px;max-height:90vh;width:100%;text-align:left;color:#fff;overflow-y:auto;box-sizing:border-box;display:flex;flex-direction:column}.modal-close{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:10px;cursor:pointer;font-size:.95rem;font-weight:600;transition:all .2s ease;box-shadow:0 4px 15px #667eea4d;margin-top:1rem;width:100%}.modal-close:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66;background:linear-gradient(135deg,#5a67d8,#6b46c1)}@media (max-width: 768px){.modal-close{padding:10px 20px;font-size:.9rem}}@media (max-width: 480px){.modal-close{padding:8px 16px;font-size:.85rem;margin-top:.75rem}}.modal-content{display:flex;flex-direction:column;gap:1.5rem}.modal-title{font-size:1.4rem;margin:1rem 0 1.5rem;color:#fff;font-weight:700}.modal-details{margin-bottom:.5rem}.modal-info-item{margin-top:-1rem;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.modal-info-item:last-child{border-bottom:none;margin-bottom:-.25rem;padding-bottom:0}.modal-label{display:block;margin-top:.5rem;margin-bottom:.25rem;color:#667eea;font-weight:600}.modal-overview{margin-top:0}.modal-overview h3{color:#667eea;font-weight:600;margin-bottom:.5rem}.modal-overview p{font-size:1.1rem;line-height:1.6;color:#e2e8f0;margin:0;opacity:.9}@media (max-width: 768px){.movie-modal{padding:1rem;max-height:95vh}.modal-title{font-size:1.2rem}.modal-info-item{margin-bottom:1.25rem}.modal-value{font-size:1rem}.modal-overview p{font-size:1rem;line-height:1.5}}@media (max-width: 480px){.modal-overlay{padding:.375rem}.movie-modal{padding:.875rem;border-radius:16px}.modal-title{font-size:1.1rem}.modal-info-item{margin-bottom:1rem;padding-bottom:.4rem}.modal-label{font-size:.9rem}.modal-value{font-size:.95rem}.modal-overview p{font-size:.95rem;line-height:1.4}}.movie-actions{display:flex;gap:12px;padding:20px 24px;background:#0003;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(255,255,255,.1);position:relative;z-index:2}.seen-btn{flex:1;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 16px;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 15px #667eea4d}.seen-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66;background:linear-gradient(135deg,#5a67d8,#6b46c1)}.modal-seen-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:10px;cursor:pointer;font-size:.95rem;font-weight:600;transition:all .2s ease;box-shadow:0 4px 15px #667eea4d}.modal-seen-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66;background:linear-gradient(135deg,#5a67d8,#6b46c1)}.status-indicator{position:absolute;top:12px;right:12px;display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:20px;font-size:.8rem;font-weight:600;z-index:10;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);box-shadow:0 4px 12px #0000004d;border:1px solid rgba(255,255,255,.2);transition:all .2s ease}.status-indicator.watched{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;border-color:#48bb784d;box-shadow:0 4px 12px #48bb7866}.status-indicator.in-watchlist{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea4d;box-shadow:0 4px 12px #667eea66}.status-icon{font-size:14px}.status-text{white-space:nowrap}.card-back .status-indicator{position:relative;top:auto;right:auto;margin:8px 0;justify-content:center}.modal-details .status-indicator{position:relative;top:auto;right:auto;margin:12px 0;justify-content:center;display:inline-flex}@media (max-width: 768px){.status-indicator{top:8px;right:8px;padding:6px 10px;font-size:.75rem;border-radius:16px}}.movie-card:hover .status-indicator{opacity:1}.movies-container{min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);color:#fff}.movies-header{background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.1);padding:3rem 2rem;text-align:center}.search-section{max-width:600px;margin:0 auto}.search-form{display:flex;gap:1rem;align-items:center;justify-content:center;flex-wrap:wrap;margin-bottom:1rem}.search-input-container{position:relative;flex:1;min-width:300px;max-width:400px}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);font-size:1.2rem;opacity:.6;pointer-events:none}.search-input{width:100%;padding:1rem 1rem 1rem 3rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:12px;color:#fff;font-size:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.search-input:focus{outline:none;border-color:#667eea;background:#ffffff26;box-shadow:0 0 0 3px #667eea1a}.search-input::placeholder{color:#fff9}.search-button,.clear-button{padding:1rem 1.5rem;border-radius:12px;font-weight:600;transition:all .3s ease;white-space:nowrap}.clear-button{display:flex;align-items:center;gap:.5rem}.clear-icon{font-size:.9rem}.search-results-info{text-align:center;margin-top:1rem;padding:.75rem 1.5rem;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.search-results-info p{margin:0;opacity:.8}.search-results-info strong{color:#667eea}.movies-content{padding:2rem;max-width:1400px;margin:0 auto}.movies-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;margin-bottom:3rem}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 2rem;background:#ffffff0d;border-radius:20px;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.empty-state h2{font-size:2rem;margin-bottom:1rem;color:#fff}.empty-state p{font-size:1.1rem;opacity:.8;margin-bottom:2rem;max-width:500px;line-height:1.6}@media (max-width: 1024px){.movies-header{padding:2rem 1.5rem}.movies-content{padding:1.5rem}.movies-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}}@media (max-width: 768px){.movies-header{padding:1.5rem 1rem}.header-content h1{font-size:2.5rem;flex-direction:column;gap:.5rem}.header-icon{font-size:3rem}.search-form{flex-direction:column;align-items:stretch}.search-input-container{min-width:unset;max-width:unset}.movies-content{padding:1rem}.movies-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.pagination{flex-direction:column;gap:1rem}.pagination-btn{width:100%;max-width:200px;justify-content:center}}@media (max-width: 480px){.movies-header{padding:1rem}.header-content h1{font-size:2rem}.header-icon{font-size:2.5rem}.movies-grid{grid-template-columns:1fr}.empty-state{padding:2rem 1rem}.empty-state h2{font-size:1.5rem}}.watchlist-container{min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);color:#fff}.watchlist-header{background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.1);padding:2rem 1rem 1rem;text-align:center}.header-content{max-width:800px;margin:0 auto;text-align:center}.header-subtitle{font-size:1.2rem;opacity:.8;line-height:1.6;margin-bottom:2rem;text-align:center}.watchlist-stats{display:flex;justify-content:center;gap:2rem;margin-top:2rem}.stat-item{display:flex;flex-direction:column;align-items:center;padding:1.5rem 2rem;background:#ffffff1a;border-radius:16px;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.stat-number{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1}.stat-label{font-size:.9rem;opacity:.8;text-transform:uppercase;letter-spacing:.05em;margin-top:.5rem}.watchlist-content{padding:2rem;max-width:1400px;margin:0 auto}.watchlist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;margin-bottom:3rem}.empty-watchlist{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 2rem;background:#ffffff0d;border-radius:20px;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.empty-watchlist h2{font-size:2rem;margin-bottom:1rem;color:#fff}.empty-watchlist p{font-size:1.1rem;opacity:.8;margin-bottom:2rem;max-width:500px;line-height:1.6}.pagination{display:flex;align-items:center;justify-content:center;gap:2rem;padding:2rem 0;margin-top:2rem}.pagination-btn{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;border-radius:12px;font-weight:600;transition:all .3s ease}.pagination-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.pagination-btn:not(:disabled):hover{transform:translateY(-2px)}.pagination-icon{font-size:1.1rem;transition:transform .3s ease}.pagination-btn:not(:disabled):hover .pagination-icon{transform:translate(3px)}.pagination-btn:not(:disabled):hover .pagination-icon:first-child{transform:translate(-3px)}.pagination-info{display:flex;align-items:center;justify-content:center;padding:1rem 2rem;background:#ffffff0d;border-radius:12px;border:1px solid rgba(255,255,255,.1)}.page-indicator{font-weight:600;color:#fff}@media (max-width: 1024px){.watchlist-header{padding:2rem 1.5rem}.watchlist-content{padding:1.5rem}.watchlist-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}}@media (max-width: 768px){.watchlist-header{padding:1.5rem 1rem}.header-content h1{font-size:2.5rem;flex-direction:column;gap:.5rem}.header-icon{font-size:3rem}.watchlist-stats{flex-direction:column;align-items:center;gap:1rem}.stat-item{width:100%;max-width:200px;padding:1rem 1.5rem}.watchlist-content{padding:1rem}.watchlist-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.pagination{flex-direction:column;gap:1rem}.pagination-btn{width:100%;max-width:200px;justify-content:center}.auth-actions{flex-direction:column;align-items:center}.auth-actions .btn{width:100%;max-width:200px}}@media (max-width: 480px){.watchlist-header{padding:1rem}.header-content h1{font-size:2rem}.header-icon{font-size:2.5rem}.watchlist-grid{grid-template-columns:1fr}.empty-watchlist{padding:2rem 1rem}.empty-watchlist h2{font-size:1.5rem}.auth-required{margin:1rem;padding:2rem 1rem}}.recommendations-container{flex:1 0 auto;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);color:#fff}.recommendations-header{background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.1);padding:3rem 2rem;text-align:center}.header-content{max-width:800px;margin:0 auto 2rem}.header-content h1{display:flex;align-items:center;justify-content:center;gap:1rem;font-size:3rem;font-weight:700;margin-bottom:1rem;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);background-size:300% 300%;background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:gradientShift 6s ease-in-out infinite}.header-icon{font-size:3.5rem;filter:drop-shadow(0 0 20px rgba(255,255,255,.3))}.header-subtitle{font-size:1.2rem;opacity:.8;line-height:1.6}.recommendations-content{padding:3rem 2rem 2rem;max-width:1200px;margin:0 auto}.recommendation-card-container{display:flex;justify-content:center;margin-bottom:3rem;min-height:600px;perspective:1000px}.recommendation-card{width:100%;max-width:350px;background:#ffffff0d;border-radius:24px;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);overflow:hidden;cursor:grab;transition:transform .3s ease,opacity .3s ease,box-shadow .3s ease;-webkit-user-select:none;user-select:none;box-shadow:0 20px 40px #0000004d;display:flex;flex-direction:column}.recommendation-card:active{cursor:grabbing}.recommendation-card:hover{box-shadow:0 25px 50px #0006}.movie-poster-section{position:relative;aspect-ratio:2/3;overflow:hidden;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);display:flex;align-items:center;justify-content:center}.movie-poster{width:100%;height:100%;object-fit:cover;transition:transform .3s ease;background:transparent}.recommendation-card:hover .movie-poster{transform:scale(1.02)}.poster-fallback{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460)}.poster-placeholder{text-align:center;color:#fff}.poster-placeholder span{font-size:4rem;display:block;margin-bottom:1rem}.poster-placeholder p{font-size:1.1rem;font-weight:500}.movie-info-section{padding:1.5rem;background:#ffffff05;border-top:1px solid rgba(255,255,255,.1);color:#fff;pointer-events:none;-webkit-user-select:none;user-select:none}.movie-title{font-size:1.4rem;font-weight:700;margin-bottom:.75rem;line-height:1.3;color:#fff}.movie-meta{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.movie-year,.movie-genre{display:flex;align-items:center;gap:.4rem;padding:.4rem .8rem;margin-bottom:0rem;background:#ffffff26;border-radius:16px;font-size:.8rem;font-weight:500;color:#e2e8f0}.movie-overview{line-height:1.5;margin-bottom:1rem;font-size:.9rem;color:#cbd5e0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.recommendation-reason{padding:1rem;background:#ffffff14;border-radius:10px;border:1px solid rgba(255,255,255,.15);margin-bottom:.75rem}.recommendation-reason h4{font-size:.9rem;margin-bottom:.4rem;color:#90cdf4;font-weight:600}.recommendation-reason p{font-size:.8rem;margin:0;line-height:1.4;color:#cbd5e0}.based-on-movie{padding:1rem;background:#667eea1a;border-radius:10px;border:1px solid rgba(102,126,234,.2)}.based-on-movie h4{font-size:.9rem;margin-bottom:.4rem;color:#a78bfa;font-weight:600}.based-on-movie p{font-size:.8rem;margin:0;line-height:1.4;color:#e0e7ff;font-weight:500}.action-buttons{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap;pointer-events:auto;position:relative;z-index:10}.action-btn{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;border-radius:12px;font-weight:600;transition:all .3s ease;min-width:120px;justify-content:center;pointer-events:auto;cursor:pointer;border:none;font-family:inherit}.action-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;pointer-events:none}.action-btn:not(:disabled):hover{transform:translateY(-2px)}.action-btn:not(:disabled):active{transform:translateY(0)}.action-icon{font-size:1.2rem}.skip-btn:hover{background:#ff6b6b33;border-color:#ff6b6b4d}.like-btn:hover{box-shadow:0 8px 25px #667eea66}.action-buttons .btn.watched-btn,.action-buttons .btn.btn-primary.watched-btn{background:linear-gradient(135deg,var(--success-green),#17a085)!important;color:#fff!important;box-shadow:0 4px 15px #20c9974d!important;border:1px solid rgba(32,201,151,.2)!important}.action-buttons .btn.watched-btn:hover,.action-buttons .btn.btn-primary.watched-btn:hover{background:linear-gradient(135deg,#1abc9c,var(--success-green))!important;box-shadow:0 8px 25px #20c99766!important;transform:translateY(-2px)!important;color:#fff!important}.action-buttons .btn.watched-btn:active,.action-buttons .btn.btn-primary.watched-btn:active{transform:translateY(0)!important;box-shadow:0 4px 15px #20c9974d!important}.action-buttons .btn.watched-btn .action-icon,.action-buttons .btn.btn-primary.watched-btn .action-icon{filter:drop-shadow(0 0 8px rgba(255,255,255,.3))}.auth-required{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:4rem 2rem;background:#ffffff0d;border-radius:20px;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);margin:2rem}.auth-icon{font-size:4rem;margin-bottom:1.5rem;filter:drop-shadow(0 0 20px rgba(255,193,7,.3))}.auth-required h2{font-size:2rem;margin-bottom:1rem;color:#fff}.auth-required p{font-size:1.1rem;opacity:.8;margin-bottom:2rem;max-width:400px}.auth-actions{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:2rem}.loading-spinner{font-size:4rem;animation:spin 2s linear infinite;margin-bottom:1.5rem}.error-icon{font-size:4rem;margin-bottom:1.5rem;filter:drop-shadow(0 0 20px rgba(255,193,7,.3))}.loading-container h2,.error-container h2{font-size:2rem;margin-bottom:.5rem;color:#fff}.loading-container p,.error-container p{font-size:1.1rem;opacity:.8;margin-bottom:1.5rem}.empty-recommendations{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 2rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.empty-icon{font-size:4rem;margin-bottom:1.5rem;opacity:.6}.empty-recommendations h2{font-size:2rem;margin-bottom:1rem;color:#fff}.empty-recommendations p{font-size:1.1rem;opacity:.8;margin-bottom:2rem;max-width:500px;line-height:1.6}.empty-actions{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.button-icon{margin-right:.5rem}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-sizing:border-box}.movie-details-modal{background:#1a1a2ef2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:1.25rem;max-width:600px;max-height:90vh;width:100%;text-align:left;color:#fff;overflow-y:auto;box-sizing:border-box;display:flex;flex-direction:column}.movie-details-modal h3{font-size:1.4rem;margin:1rem 0 0rem;color:#fff;font-weight:700}.movie-details{margin-bottom:.5rem}.detail-row{margin-top:-1rem;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.movie-details .detail-row:last-child{border-bottom:none;margin-bottom:-1rem;padding-bottom:0}.detail-row strong,.modal-label{display:block;margin-top:.5rem;margin-bottom:.25rem;color:#667eea;font-weight:600}.modal-value{font-size:1.1rem;line-height:1.6;color:#fff;opacity:.9;margin:0}.detail-row p{margin:0;line-height:1.6;color:#fff;opacity:.9;font-size:1.1rem}.modal-actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;margin-top:1rem;flex-shrink:0}.modal-actions .btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:10px;cursor:pointer;font-size:.95rem;font-weight:600;transition:all .2s ease;box-shadow:0 4px 15px #667eea4d;width:100%}.modal-actions .btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66;background:linear-gradient(135deg,#5a67d8,#6b46c1)}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 1024px){.recommendations-header{padding:2rem 1.5rem}.recommendations-content{padding:2rem 1.5rem 1.5rem}}@media (max-width: 768px){.recommendations-header{padding:1.5rem 1rem}.header-content h1{font-size:2.5rem;flex-direction:column;gap:.5rem}.header-icon{font-size:3rem}.recommendations-content{padding:1.5rem 1rem 1rem}.recommendation-card{max-width:300px}.movie-info-section{padding:1.25rem}.movie-title{font-size:1.3rem}.action-buttons{gap:.75rem}.action-btn{min-width:100px;padding:.875rem 1.25rem}.auth-actions{flex-direction:column;align-items:center}.auth-actions .btn{width:100%;max-width:200px}.empty-actions{flex-direction:column;align-items:center}.empty-actions .btn{width:100%;max-width:200px}}@media (max-width: 480px){.recommendations-header{padding:1rem}.header-content h1{font-size:2rem}.header-icon{font-size:2.5rem}.recommendations-content{padding:1rem}.recommendation-card{max-width:280px}.movie-info-section{padding:1rem}.movie-title{font-size:1.2rem;margin-bottom:.6rem}.movie-meta{gap:.6rem;margin-bottom:.8rem}.movie-year,.movie-genre{font-size:.75rem;padding:.3rem .6rem}.movie-overview{font-size:.85rem;margin-bottom:.8rem;-webkit-line-clamp:2}.recommendation-reason{padding:.8rem;margin-bottom:.6rem}.recommendation-reason h4{font-size:.8rem;margin-bottom:.3rem}.recommendation-reason p{font-size:.75rem}.based-on-movie{padding:.8rem}.based-on-movie h4{font-size:.8rem;margin-bottom:.3rem}.based-on-movie p{font-size:.75rem}.action-buttons{grid-template-columns:repeat(2,1fr);display:grid;gap:.5rem}.modal-overlay{padding:.375rem}.movie-details-modal{padding:.875rem;border-radius:16px}.movie-details-modal h3{font-size:1.1rem}.detail-row{margin-bottom:1rem;padding-bottom:.4rem}.detail-row strong{font-size:.9rem}.detail-row p{font-size:.95rem;line-height:1.4}.modal-actions .btn{padding:8px 16px;font-size:.85rem;margin-top:.75rem}.auth-required{margin:1rem;padding:2rem 1rem}.empty-recommendations{padding:2rem 1rem}}*{margin:0;padding:0;box-sizing:border-box}:root{--title-font: "DM Sans", sans-serif;--body-font: "DM Sans", sans-serif;--header-height: 80px;--footer-height: 66px;--primary-dark: #1a1a2e;--secondary-dark: #16213e;--accent-dark: #0f3460;--primary-blue: #667eea;--secondary-purple: #764ba2;--accent-orange: #ff6b6b;--accent-yellow: #feca57;--success-green: #20c997;--danger-red: #dc3545;--glass-bg: rgba(255, 255, 255, .1);--glass-border: rgba(255, 255, 255, .2);--glass-hover: rgba(255, 255, 255, .15)}body,html{margin:0;padding:0;font-family:var(--body-font);background:linear-gradient(135deg,var(--primary-dark) 0%,var(--secondary-dark) 50%,var(--accent-dark) 100%);color:#fff;min-height:100vh;overflow-x:hidden;line-height:1.6}#root{min-height:100vh;width:100%;display:flex;flex-direction:column}.app-content{flex:1 0 auto;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-family:var(--title-font);font-weight:600;letter-spacing:-.025em;line-height:1.2}h1{font-size:3rem}h2{font-size:2.5rem}h3{font-size:2rem}h4{font-size:1.5rem}h5{font-size:1.25rem}h6{font-size:1rem}p{line-height:1.6;margin-bottom:1rem}.btn{display:inline-flex;align-items:center;justify-content:center;padding:1rem 2rem;border-radius:12px;font-weight:600;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);border:none;cursor:pointer;font-size:1rem;font-family:var(--body-font);position:relative;overflow:hidden;white-space:nowrap}.btn-primary{background:linear-gradient(135deg,var(--primary-blue),var(--secondary-purple));color:#fff;box-shadow:0 4px 15px #667eea4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea66;text-decoration:none;color:#fff}.btn-secondary{background:var(--glass-bg);color:#fff;border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-secondary:hover{background:var(--glass-hover);border-color:#ffffff80;transform:translateY(-2px);text-decoration:none;color:#fff}.btn-logout{background:linear-gradient(135deg,var(--danger-red),#c82333);color:#fff}.btn-logout:hover{box-shadow:0 6px 20px #dc354566;transform:translateY(-2px);text-decoration:none;color:#fff}.btn-ghost{background:transparent;color:#fffc;border:1px solid rgba(255,255,255,.2)}.btn-ghost:hover{background:var(--glass-bg);color:#fff;border-color:#ffffff4d;transform:translateY(-1px);text-decoration:none}a{color:inherit;text-decoration:none;transition:all .3s ease}a:hover{text-decoration:none}input,textarea,select{font-family:inherit;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:8px;padding:.75rem 1rem;color:#fff;transition:all .3s ease}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #667eea1a;background:var(--glass-hover)}input::placeholder,textarea::placeholder{color:#ffffff80}html{scroll-behavior:smooth}.loading{display:flex;justify-content:center;align-items:center;min-height:200px;color:#fff;font-size:1.2rem}.error{color:#fff;background:#dc354533;border:1px solid rgba(220,53,69,.3);border-radius:12px;padding:1.5rem;margin:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);text-align:center}.card{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:16px;padding:1.5rem;transition:all .3s ease}.card:hover{background:var(--glass-hover);transform:translateY(-2px);box-shadow:0 10px 30px #0003}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mb-0{margin-bottom:0}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mt-0{margin-top:0}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.p-0{padding:0}.p-1{padding:.5rem}.p-2{padding:1rem}.p-3{padding:1.5rem}.p-4{padding:2rem}@media (max-width: 768px){h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}.btn{padding:.875rem 1.5rem;font-size:.9rem}}@media (max-width: 480px){h1{font-size:2rem}h2{font-size:1.75rem}h3{font-size:1.25rem}.btn{padding:.75rem 1.25rem;font-size:.875rem}}
