:root{color:#ffffffe6;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--surface:#ffffff12;--surface-strong:#ffffff1f;--border:#ffffff21;--accent:#e50914;--accent-strong:#ff2f3c;--text-muted:#ffffffa3;--shadow:0 24px 70px #0000006b;background:radial-gradient(circle at 0 0,#e509142e,#0000 32rem),radial-gradient(circle at 100% 0,#1e88e529,#0000 28rem),linear-gradient(135deg,#07080d 0%,#11131d 48%,#06070b 100%);font-family:SF Pro Display,Avenir Next,Segoe UI,system-ui,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box;margin:0;padding:0}html,body{overflow-x:hidden}body{width:100%;min-height:100vh;margin:0;position:relative}body:before{content:"";pointer-events:none;background-image:linear-gradient(#ffffff06 1px,#0000 1px),linear-gradient(90deg,#ffffff05 1px,#0000 1px);background-size:72px 72px;position:fixed;inset:0;-webkit-mask-image:linear-gradient(#000000e6,#0000 85%);mask-image:linear-gradient(#000000e6,#0000 85%)}#root{flex-direction:column;width:100%;min-height:100vh;display:flex}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit;font-weight:500}a:hover{color:#fff}h1{font-size:3.2em;line-height:1.1}button{color:inherit;cursor:pointer;background-color:#ffffff1a;border:1px solid #0000;border-radius:6px;padding:.6em 1.2em;font-family:inherit;font-size:1em;font-weight:500;transition:border-color .2s,background-color .2s,transform .2s}button:hover{border-color:#fff3}button:focus,button:focus-visible{outline-offset:3px;outline:2px solid #fffc}.main-content{box-sizing:border-box;flex-direction:column;flex:1;width:100%;padding:2.25rem clamp(1rem,3vw,3rem) 3.5rem;display:flex}@media (width<=640px){.main-content{padding:1rem .75rem 2rem}}.home{box-sizing:border-box;width:100%;padding:1.5rem 0 2rem}.home-header{text-align:center;max-width:900px;margin:0 auto 1.65rem}.eyebrow{color:var(--accent-strong);letter-spacing:.12em;text-transform:uppercase;margin-bottom:.55rem;font-size:.78rem;font-weight:900}.home-header h1{color:#fff;letter-spacing:0;margin:0;font-size:clamp(2.25rem,5vw,4.2rem);line-height:.98}.search-form{box-sizing:border-box;border:1px solid var(--border);max-width:720px;box-shadow:var(--shadow);background:linear-gradient(135deg,#ffffff21,#ffffff0d);border-radius:999px;gap:.75rem;margin:0 auto 2.5rem;padding:.45rem;display:flex}.search-input{color:#fff;background-color:#ffffff12;border:none;border-radius:999px;flex:1;min-width:0;padding:.85rem 1.1rem;font-size:1rem;transition:background-color .2s,box-shadow .2s}.search-input::placeholder{color:#ffffff73}.search-input:focus{background-color:#ffffff1c;outline:none;box-shadow:inset 0 0 0 1px #ffffff2e}.search-button{background:linear-gradient(135deg, var(--accent), var(--accent-strong));color:#fff;white-space:nowrap;border-radius:999px;padding:.85rem 1.6rem;font-weight:800;transition:transform .2s,box-shadow .2s,filter .2s;box-shadow:0 12px 30px #e5091459}.search-button:hover{filter:brightness(1.08);transform:translateY(-1px);box-shadow:0 16px 36px #e509146b}.error-message,.loading,.empty-results{border:1px solid var(--border);background:var(--surface);color:#ffffffc7;border-radius:8px;width:fit-content;max-width:min(90vw,680px);margin:0 auto 1.5rem;padding:.85rem 1.1rem;box-shadow:0 12px 30px #0003}.error-message{color:#ffb3b9;border-color:#ff2f3c59}.empty-results{text-align:center;width:min(90vw,680px);padding:3rem 1.5rem}.empty-results h2{color:#fff;margin-bottom:.75rem;font-size:clamp(1.8rem,4vw,2.6rem)}.empty-results p{color:var(--text-muted);margin-bottom:1.5rem}.empty-results button{background:linear-gradient(135deg, var(--accent), var(--accent-strong));color:#fff;font-weight:800;box-shadow:0 12px 30px #e5091452}.empty-results button:hover{transform:translateY(-1px)}@media (width<=639px){.home{padding:.5rem 0 1.5rem}.search-form{border-radius:18px;flex-direction:column;margin-bottom:1rem}.search-input,.search-button{width:100%}}.movies-grid{box-sizing:border-box;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:clamp(1rem,2vw,1.6rem);width:100%;padding:.5rem 0;display:grid}.movie-card{background:linear-gradient(#ffffff17,#ffffff09);border:1px solid #ffffff1a;border-radius:8px;flex-direction:column;height:100%;transition:transform .24s,border-color .24s,box-shadow .24s;display:flex;position:relative;overflow:hidden;box-shadow:0 18px 45px #00000042}.movie-card:hover{border-color:#ffffff38;transform:translateY(-7px)scale(1.01);box-shadow:0 28px 65px #0000006b}.movie-poster{aspect-ratio:2/3;width:100%;position:relative}.movie-poster img{object-fit:cover;width:100%;height:100%;transition:transform .35s,filter .35s;transform:scale(1.001)}.movie-card:hover .movie-poster img{filter:saturate(1.08)contrast(1.04);transform:scale(1.045)}.movie-overlay{opacity:0;background:linear-gradient(#00000005,#00000038 42%,#000000d1);flex-direction:column;justify-content:flex-end;padding:1rem;transition:opacity .24s;display:flex;position:absolute;inset:0}.movie-card:hover .movie-overlay{opacity:1}.favorite-btn{color:#fff;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background-color:#07080dad;border:1px solid #ffffff2e;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;padding:.5rem;font-size:1.5rem;transition:background-color .2s,transform .2s,color .2s;display:flex;position:absolute;top:1rem;right:1rem}.favorite-btn:hover{background-color:#07080de6;transform:scale(1.08)}.favorite-btn.active{color:#ff4757;background-color:#ff475729;border-color:#ff475773}.rating-select{color:#fff;cursor:pointer;background-color:#000000b3;border:none;border-radius:4px;margin-top:.5rem;padding:.5rem}.movie-info{flex-direction:column;flex:1;gap:.5rem;padding:1rem 1rem 1.1rem;display:flex}.movie-info h3{color:#fff;margin:0;font-size:1rem;line-height:1.25}.movie-info p{color:var(--text-muted);font-size:.9rem}.user-rating{color:gold;margin-top:auto;font-size:.9rem}@media (width<=768px){.movie-card{font-size:.9rem}.movie-info{padding:.75rem}.favorite-btn{width:32px;height:32px;font-size:1.2rem}}.modal-backdrop{z-index:50;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000b8;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.movie-modal{border:1px solid var(--border);background:linear-gradient(135deg,#151722,#08090f);border-radius:8px;grid-template-columns:minmax(180px,280px) minmax(280px,1fr);gap:1.5rem;width:min(900px,100%);max-height:86vh;padding:1rem;display:grid;position:relative;overflow:auto;box-shadow:0 30px 90px #0009}.modal-close{color:#fff;background:#ffffff1f;border-radius:50%;width:38px;height:38px;padding:0;font-size:1.6rem;line-height:1;position:absolute;top:.75rem;right:.75rem}.modal-poster img{object-fit:cover;border-radius:8px;width:100%;height:100%;max-height:520px}.modal-info{flex-direction:column;justify-content:center;padding:1.5rem 1rem;display:flex}.modal-info h2{margin:0 2.5rem .75rem 0;font-size:clamp(2rem,5vw,3.25rem);line-height:1}.modal-meta{color:var(--text-muted);margin-bottom:1.5rem;font-weight:700}.modal-overview{color:#ffffffc7;line-height:1.8}@media (width<=720px){.movie-modal{grid-template-columns:1fr}.modal-poster img{max-height:420px}.modal-info{padding:.75rem .25rem .5rem}}.favorites{box-sizing:border-box;width:100%;padding:1rem 0 2rem}.favorites h2{text-align:center;color:#fff;text-shadow:0 16px 45px #0000007a;margin-bottom:2rem;font-size:clamp(2rem,5vw,3.2rem)}.favorites-empty{text-align:center;border:1px solid var(--border);max-width:680px;box-shadow:var(--shadow);background:linear-gradient(135deg,#ffffff1a,#ffffff0b);border-radius:8px;margin:2rem auto;padding:clamp(3rem,8vw,5rem) 2rem}.favorites-empty h2{color:#fff;margin-bottom:1rem;font-size:clamp(1.8rem,4vw,2.4rem)}.favorites-empty p{color:var(--text-muted);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:.3s ease-out forwards fadeIn}.navbar{z-index:20;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#06070cc7;justify-content:space-between;align-items:center;padding:.85rem clamp(1rem,4vw,3rem);display:flex;position:sticky;top:0;box-shadow:0 18px 50px #00000038}.navbar-brand{letter-spacing:0;font-size:clamp(1.05rem,2vw,1.35rem);font-weight:800}.navbar-brand a{color:#fff;align-items:center;gap:.7rem;display:inline-flex}.brand-mark{background:linear-gradient(135deg, var(--accent), #ff8a5c);color:#fff;letter-spacing:0;border-radius:8px;justify-content:center;align-items:center;width:2.25rem;height:2.25rem;font-size:.8rem;font-weight:900;display:inline-flex;box-shadow:0 12px 28px #e5091447}.navbar-links{border:1px solid var(--border);background:#ffffff0d;border-radius:999px;align-items:center;gap:.25rem;padding:.25rem;display:flex}.nav-link{color:var(--text-muted);border-radius:999px;padding:.55rem .95rem;font-size:.95rem;transition:background-color .2s,color .2s,transform .2s}.nav-link:hover{color:#fff;background-color:var(--surface-strong);transform:translateY(-1px)}.nav-link.active{color:#fff;background:#ffffff24;box-shadow:inset 0 0 0 1px #ffffff14}@media (width<=768px){.navbar{padding:.85rem 1rem}.navbar-brand{font-size:1rem}.navbar-links{gap:.25rem}.nav-link{padding:.5rem .7rem}}@media (width<=520px){.navbar{flex-direction:column;align-items:flex-start;gap:.85rem}.navbar-links{justify-content:space-between;width:100%}.nav-link{text-align:center;flex:1}}
