*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}html,body{overflow-x:hidden}:root{--bg: #d399e6;--fg: #111111}:root.dark{--bg: #0b0a0a;--fg: #fffefe}body{margin:0;width:100%;min-height:100vh;position:relative;background:var(--bg);color:var(--fg);font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400}button{border-radius:8px;border:1px solid var(--fg);padding:.6em 1.2em;font:inherit;background:transparent;color:var(--fg);cursor:pointer;transition:border-color .25s}.main-content{flex:1;padding:2rem;width:100%;display:flex;flex-direction:column;background:var(--bg);color:var(--fg)}.main-content{flex:1;padding:2rem;box-sizing:border-box;width:100%;display:flex;flex-direction:column;background:var(--bg);color:var(--fg)}.favourites{padding:2rem;width:100%;box-sizing:border-box}.favourites h2{margin-bottom:2rem;text-align:center;font-size:2.5rem;color:#f1dc7c;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.favourites-empty{text-align:center;padding:4rem 2rem;background-color:#ffffff0d;border-radius:12px;margin:2rem auto;max-width:600px}.favourites-empty h2{margin-bottom:1rem;font-size:2rem;color:#e50914}.favourites-empty p{color:#999;font-size:1.2rem;line-height:1.6}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.movies-grid>*{animation:fadeIn .3s ease-out forwards}.movie-card{position:relative;border-radius:8px;overflow:hidden;background-color:#e8d78a;transition:transform .2s;height:100%;display:flex;flex-direction:column}.movie-card:hover{transform:translateY(-5px)}.movie-poster{position:relative;aspect-ratio:2/3;width:100%}.movie-poster img{width:100%;height:100%;object-fit:cover}.movie-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,#f6cdf91a,#cd95ddcc);opacity:0;transition:opacity .2s;display:flex;flex-direction:column;justify-content:flex-end;padding:1rem}.movie-card:hover .movie-overlay{opacity:1}.favourite-btn{position:absolute;top:1rem;right:4.5rem;color:#fff;font-size:1.5rem;padding:.2rem;background-color:#00000080;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.favourite-btn:hover{background-color:#d38aebcc}.favourite-btn.active{color:#f90258}.watchlist-btn{position:absolute;top:1rem;right:1rem;color:#fff;font-size:1.5rem;padding:.2rem;background-color:#00000080;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.watchlist-btn:hover{background-color:#d38aebcc}.watchlist-btn.active{color:#ece33a}.rating-select{background-color:#000000b3;color:#fff;border:none;padding:.5rem;border-radius:4px;cursor:pointer;margin-top:.5rem}.movie-info{padding:1rem;flex:1;display:flex;flex-direction:column;gap:.5rem}.movie-info h3{font-size:1rem;margin:0}.movie-info p{color:#2d2222;font-size:.9rem}.user-rating{color:gold;font-size:.9rem;margin-top:auto}@media (max-width: 768px){.movie-card{font-size:.9rem}.movie-info{padding:.75rem}.favourite-btn,.watchlist-btn{width:32px;height:32px;font-size:1.2rem}}.home{padding:2rem 0;width:100%;box-sizing:border-box}.search-form{max-width:600px;margin:0 auto 2rem;display:flex;gap:1rem;padding:0 1rem;box-sizing:border-box}.search-input{flex:1;padding:.75rem 1rem;border:1px solid;border-radius:4px;border-color:#e8d78a;background:#e8d78a;color:#000;font-size:1rem}.search-input:focus{outline:none;box-shadow:0 0 0 2px}.search-button{padding:.75rem 1.5rem;background:#e8d78a;color:#1f1f1c;border:1px solid;border-radius:4px;font-weight:500;white-space:nowrap}@media (max-width: 639px){.home{padding:1rem 0}.search-form{margin-bottom:1rem}}.movies-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;padding:1rem;width:100%;box-sizing:border-box}.watchlist h2{margin-bottom:2rem;text-align:center;font-size:2.5rem;color:#f1dc7c;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.navbar{background-color:#f1dc7c;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a}.navbar-brand{font-size:1.5rem;font-weight:700}.navbar-links{display:flex;gap:2rem}.nav-link{font-size:1rem;padding:.5rem 1rem;border-radius:4px;transition:background-color .2s}.nav-link:hover{background-color:#ffffff1a}@media (max-width: 768px){.navbar{padding:1rem}.navbar-brand{font-size:1.2rem}.navbar-links{gap:1rem}.nav-link{padding:.5rem}}
