*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--pink: #FFB6C1;--pink-dark: #e8929f;--pink-light: #ffe0e6;--lavender: #E6E6FA;--lavender-dark: #c5c5e0;--blue: #B0E0E6;--blue-dark: #8ac4cc;--cream: #FFF8DC;--cream-dark: #f0e6b8;--peach: #FFDAB9;--peach-dark: #e8bc94;--text: #4a3f3f;--text-light: #7a6d6d;--text-heading: #5a4040;--bg: #fef9f0;--white: #ffffff;--shadow-soft: 0 2px 12px rgba(180, 140, 140, .15);--shadow-hover: 0 6px 24px rgba(180, 140, 140, .25);--radius: 16px;--radius-sm: 10px;--radius-lg: 24px;--transition: .25s ease}html{font-size:16px;scroll-behavior:smooth}body{font-family:Nunito,Segoe UI,sans-serif;color:var(--text);background-color:var(--bg);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}.page-bg{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:-1;background-image:repeating-linear-gradient(0deg,transparent,transparent 31px,rgba(200,180,180,.08) 31px,rgba(200,180,180,.08) 32px);background-size:100% 32px}.app{max-width:1060px;margin:0 auto;padding:0 24px 40px;min-height:100vh;display:flex;flex-direction:column}.tab-nav{display:flex;gap:8px;justify-content:center;padding:20px 0 0}.tab-btn{font-family:Patrick Hand,cursive;font-size:1.2rem;padding:10px 28px;border:2.5px solid var(--lavender-dark);border-bottom:none;background:var(--white);color:var(--text-light);border-radius:var(--radius) var(--radius) 0 0;cursor:pointer;transition:background var(--transition),color var(--transition),border-color var(--transition),transform var(--transition);position:relative;margin-bottom:-2.5px;letter-spacing:.3px;z-index:1}.tab-btn:hover{background:var(--lavender);color:var(--text-heading);transform:translateY(-2px)}.tab-btn.active{background:var(--cream);color:var(--text-heading);border-color:var(--peach-dark);font-weight:700;box-shadow:0 -3px 8px #b48c8c1a;z-index:2}.tab-icon{margin-right:6px}.main-content{background:var(--cream);border:2.5px solid var(--peach-dark);border-radius:0 0 var(--radius-lg) var(--radius-lg);padding:32px 28px 40px;flex:1;box-shadow:var(--shadow-soft),inset 0 1px #ffffffb3;position:relative}.main-content:before,.main-content:after{content:"";position:absolute;bottom:-6px;width:60px;height:18px;background:#ffdab98c;border-radius:3px;transform:rotate(-2deg);z-index:10}.main-content:before{left:30px;transform:rotate(-3deg)}.main-content:after{right:30px;transform:rotate(2deg)}.recommend-header{display:flex;align-items:center;gap:18px;margin-bottom:28px;flex-wrap:wrap}.header-mascot{flex-shrink:0;filter:drop-shadow(0 3px 6px rgba(180,140,140,.2));animation:mascot-float 3s ease-in-out infinite}@keyframes mascot-float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.header-text{flex:1;min-width:200px}.site-title{font-family:Patrick Hand,cursive;font-size:2.6rem;color:var(--text-heading);line-height:1.15;letter-spacing:.5px;text-shadow:1px 1px 0 rgba(255,182,193,.35)}.site-subtitle{font-size:1.05rem;color:var(--text-light);margin-top:4px;font-style:italic}.filter-label-text{font-family:Patrick Hand,cursive;font-size:1.15rem;color:var(--text-light);font-style:italic;margin-bottom:8px;text-align:center}.filter-bar{display:flex;flex-wrap:wrap;gap:18px;padding:18px 20px;background:var(--white);border:2px dashed var(--pink);border-radius:var(--radius);margin-bottom:24px;box-shadow:inset 0 1px 4px #ffb6c11f}.filter-group{display:flex;flex-direction:column;gap:5px;min-width:140px}.filter-label{font-family:Patrick Hand,cursive;font-size:1rem;color:var(--text-heading);letter-spacing:.3px}.filter-select,.filter-input{font-family:Nunito,sans-serif;font-size:.9rem;padding:7px 12px;border:2px solid var(--lavender-dark);border-radius:var(--radius-sm);background:var(--white);color:var(--text);outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.filter-select:focus,.filter-input:focus{border-color:var(--pink);box-shadow:0 0 0 3px #ffb6c140}.filter-input{width:80px}.filter-year-inputs{display:flex;align-items:center;gap:6px}.filter-dash{color:var(--text-light);font-weight:700}.filter-toggle-group{display:flex;gap:4px}.filter-toggle-btn{font-family:Nunito,sans-serif;font-size:.82rem;font-weight:600;padding:6px 14px;border:2px solid var(--lavender-dark);border-radius:999px;background:var(--white);color:var(--text-light);cursor:pointer;transition:background var(--transition),border-color var(--transition),color var(--transition)}.filter-toggle-btn:hover{background:var(--lavender);border-color:var(--lavender)}.filter-toggle-btn.active{background:var(--pink-light);border-color:var(--pink);color:var(--text-heading)}.recommend-action{text-align:center;margin-bottom:32px}.recommend-btn{font-family:Patrick Hand,cursive;font-size:1.45rem;padding:14px 40px;background:linear-gradient(135deg,var(--pink),var(--peach));color:var(--text-heading);border:3px solid var(--pink-dark);border-bottom-width:5px;border-radius:var(--radius-lg);cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),background var(--transition);letter-spacing:.4px;box-shadow:0 4px 12px #ffb6c14d;position:relative;overflow:hidden}.recommend-btn:hover:not(:disabled){transform:translateY(-3px) scale(1.02);box-shadow:0 8px 24px #ffb6c166;background:linear-gradient(135deg,var(--peach),var(--pink))}.recommend-btn:active:not(:disabled){transform:translateY(0);border-bottom-width:3px;margin-top:2px}.recommend-btn:disabled{opacity:.7;cursor:wait}.btn-mouse-icon{font-size:1.3em;margin-right:8px;display:inline-block;animation:btn-mouse-wiggle 1.5s ease-in-out infinite}@keyframes btn-mouse-wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-8deg)}75%{transform:rotate(8deg)}}.btn-loading{display:inline-flex;align-items:center;gap:10px}.btn-spinner{display:inline-block;width:20px;height:20px;border:3px solid rgba(255,255,255,.4);border-top-color:var(--text-heading);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-area{text-align:center;padding:48px 20px}.loading-area.small{padding:24px 10px}.loading-mouse{margin-bottom:12px}.loading-mascot-bounce{animation:mascot-bounce .6s ease-in-out infinite alternate;display:inline-block}@keyframes mascot-bounce{0%{transform:translateY(0) rotate(-3deg)}to{transform:translateY(-14px) rotate(3deg)}}.loading-text{font-family:Patrick Hand,cursive;font-size:1.15rem;color:var(--text-light);font-style:italic}.error-box{display:flex;align-items:center;gap:12px;padding:14px 20px;background:#fff0f0;border:2px dashed var(--pink-dark);border-radius:var(--radius);margin-bottom:20px;color:#8b4545}.error-icon{font-size:1.6rem;flex-shrink:0}.error-dismiss{margin-left:auto;font-family:Nunito,sans-serif;font-size:.8rem;background:none;border:1px solid #d4909a;border-radius:999px;padding:3px 12px;cursor:pointer;color:#8b4545;transition:background var(--transition)}.error-dismiss:hover{background:#ffe0e0}.results-section{margin-top:8px}.results-heading{font-family:Patrick Hand,cursive;font-size:1.6rem;color:var(--text-heading);margin-bottom:20px;text-align:center}.results-heading-icon{display:inline-block;animation:wiggle 2s ease-in-out infinite}@keyframes wiggle{0%,to{transform:rotate(0)}20%{transform:rotate(12deg)}40%{transform:rotate(-12deg)}60%{transform:rotate(6deg)}80%{transform:rotate(-4deg)}}.movie-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}.movie-card{background:var(--white);border:2px solid var(--lavender-dark);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-soft),3px 3px 0 var(--lavender);transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);position:relative;cursor:default}.movie-card:hover{transform:translateY(-6px) rotate(-.5deg);box-shadow:var(--shadow-hover),5px 5px 0 var(--pink-light);border-color:var(--pink)}.movie-card-tape{position:absolute;width:50px;height:14px;background:#ffdab980;border-radius:2px;z-index:5;top:-4px}.movie-card-tape-left{left:16px;transform:rotate(-4deg)}.movie-card-tape-right{right:16px;transform:rotate(3deg)}.movie-card-poster-wrap{width:100%;aspect-ratio:2 / 3;overflow:hidden;background:var(--lavender);position:relative}.movie-card-poster{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.movie-card:hover .movie-card-poster{transform:scale(1.04)}.movie-card-body{padding:16px 18px 20px}.movie-card-title{font-family:Patrick Hand,cursive;font-size:1.25rem;color:var(--text-heading);line-height:1.3;margin-bottom:8px}.movie-card-year{font-size:.9rem;color:var(--text-light);font-weight:400}.movie-card-genres{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.genre-pill{display:inline-block;font-size:.72rem;font-weight:700;padding:3px 10px;border-radius:999px;letter-spacing:.3px;text-transform:uppercase}.genre-pill:nth-child(3n+1){background:var(--pink-light);color:#9a5060}.genre-pill:nth-child(3n+2){background:#e0e8ff;color:#5a6090}.genre-pill:nth-child(3n){background:#d4f5e0;color:#3a7050}.movie-card-desc{font-size:.9rem;color:var(--text-light);line-height:1.55;margin-top:6px}.movie-card-actions{margin-top:10px;padding-top:8px;border-top:1px dashed var(--lavender-dark);display:flex;align-items:center;justify-content:space-between;gap:8px}.movie-card-trailer{font-family:Patrick Hand,cursive;font-size:.95rem;color:var(--text-light);text-decoration:none;padding:4px 12px;border:1.5px solid var(--lavender-dark);border-radius:999px;transition:background var(--transition),border-color var(--transition),color var(--transition);white-space:nowrap}.movie-card-trailer:hover{background:var(--pink-light);border-color:var(--pink);color:var(--text-heading)}.more-action{text-align:center;margin-top:28px}.more-btn{font-family:Patrick Hand,cursive;font-size:1.2rem;padding:10px 30px;background:var(--white);color:var(--text-heading);border:2.5px solid var(--lavender-dark);border-bottom-width:4px;border-radius:var(--radius-lg);cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition)}.more-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #b48c8c33;border-color:var(--pink)}.empty-state,.initial-state{text-align:center;padding:48px 20px}.empty-mascot{opacity:.7;margin-bottom:12px}.empty-text,.initial-text{font-size:1.05rem;color:var(--text-light);max-width:420px;margin:0 auto;line-height:1.6}.initial-doodles{margin-top:18px;display:flex;justify-content:center;gap:18px;font-size:2rem;opacity:.5}.initial-doodles span{animation:doodle-bob 2s ease-in-out infinite}.initial-doodles span:nth-child(2){animation-delay:.3s}.initial-doodles span:nth-child(3){animation-delay:.6s}.initial-doodles span:nth-child(4){animation-delay:.9s}@keyframes doodle-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.rate-header{display:flex;align-items:center;gap:14px;margin-bottom:24px}.rate-header-mascot{flex-shrink:0}.rate-title{font-family:Patrick Hand,cursive;font-size:2rem;color:var(--text-heading)}.rate-subtitle{font-size:.95rem;color:var(--text-light);font-style:italic}.search-autocomplete-wrap{position:relative;margin-bottom:28px}.search-input-wrap{position:relative}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:1.1rem;pointer-events:none}.search-input{width:100%;font-family:Nunito,sans-serif;font-size:1rem;padding:11px 14px 11px 42px;border:2.5px solid var(--lavender-dark);border-radius:var(--radius);background:var(--white);color:var(--text);outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.search-input:focus{border-color:var(--pink);box-shadow:0 0 0 4px #ffb6c133}.search-input::placeholder{color:#bfaaaa}.search-spinner{position:absolute;right:14px;top:50%;transform:translateY(-50%);display:inline-block;width:18px;height:18px;border:2.5px solid var(--lavender-dark);border-top-color:var(--pink);border-radius:50%;animation:spin .7s linear infinite}.search-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:var(--white);border:2px solid var(--lavender-dark);border-radius:var(--radius-sm);box-shadow:0 8px 24px #6450502e;max-height:360px;overflow-y:auto;z-index:50;list-style:none}.search-dropdown-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid var(--lavender);transition:background var(--transition)}.search-dropdown-item:last-child{border-bottom:none}.search-dropdown-item:hover{background:var(--pink-light)}.search-dropdown-poster{width:36px;height:54px;border-radius:5px;overflow:hidden;flex-shrink:0;background:var(--lavender)}.search-dropdown-poster img{width:100%;height:100%;object-fit:cover}.search-dropdown-no-poster{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;background:var(--lavender)}.search-dropdown-info{flex:1;min-width:0}.search-dropdown-title{font-weight:700;font-size:.92rem;color:var(--text-heading);display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-dropdown-year{color:var(--text-light);font-weight:400}.search-dropdown-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.section-heading{font-family:Patrick Hand,cursive;font-size:1.35rem;color:var(--text-heading);margin-bottom:14px;padding-bottom:8px;border-bottom:2px dashed var(--lavender-dark)}.ratings-count{font-size:.9em;color:var(--text-light);font-weight:400}.saving-indicator{font-size:.75rem;color:var(--pink-dark);font-style:italic;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.ratings-section{margin-top:8px}.ratings-list{list-style:none;display:flex;flex-direction:column;gap:6px}.rating-item{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--white);border:1.5px solid var(--lavender);border-radius:var(--radius-sm);transition:border-color var(--transition),box-shadow var(--transition)}.rating-item:hover{border-color:var(--peach-dark);box-shadow:0 2px 8px #b48c8c1a}.rating-item-poster{width:70px;height:105px;border-radius:6px;overflow:hidden;flex-shrink:0;background:var(--lavender)}.rating-item-poster img{width:100%;height:100%;object-fit:cover}.rating-item-no-poster{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;background:var(--lavender)}.rating-item-info{flex:1;min-width:0}.rating-item-title{font-weight:700;font-size:.9rem;color:var(--text-heading);display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:2px}.rating-delete-btn{width:30px;height:30px;border-radius:50%;border:2px solid var(--lavender-dark);background:var(--white);color:var(--text-light);font-size:1.4rem;cursor:pointer;transition:background var(--transition),border-color var(--transition),color var(--transition),transform var(--transition);display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:0 0 2px}.rating-delete-btn:hover{background:#ffe0e0;border-color:var(--pink-dark);color:#8b4545;transform:scale(1.15)}.empty-ratings{text-align:center;padding:30px 20px;color:var(--text-light)}.empty-ratings-icon{display:block;font-size:2.5rem;margin-top:10px;opacity:.4}.star-rating{display:inline-flex;align-items:center;gap:1px;-webkit-user-select:none;user-select:none}.star{display:inline-block;transition:transform .15s ease,color .15s ease;line-height:1}.star-full{color:#f5c518}.star-half{color:#d4c9b0}.star-half-wrap{position:relative;display:inline-block}.star-half-empty{color:#d4c9b0}.star-half-filled{position:absolute;left:0;top:0;color:#f5c518;clip-path:inset(0 50% 0 0);pointer-events:none}.star-empty{color:#d4c9b0}.star-interactive:hover{transform:scale(1.25)}.star-value{font-size:.78em;color:var(--text-light);margin-left:6px;font-weight:600;background:var(--lavender);padding:1px 7px;border-radius:999px}.site-footer{text-align:center;padding:20px 0 12px;font-family:Patrick Hand,cursive;font-size:.95rem;color:var(--text-light);opacity:.7}@media(max-width:700px){.app{padding:0 12px 24px}.main-content{padding:24px 16px 28px}.site-title{font-size:2rem}.recommend-header{flex-direction:column;text-align:center}.filter-bar{flex-direction:column}.movie-grid{grid-template-columns:1fr;gap:18px}.tab-btn{font-size:1rem;padding:8px 18px}.recommend-btn{font-size:1.2rem;padding:12px 28px}.search-result-item{flex-wrap:wrap}}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--cream)}::-webkit-scrollbar-thumb{background:var(--pink);border-radius:999px;border:2px solid var(--cream)}::-webkit-scrollbar-thumb:hover{background:var(--pink-dark)}::selection{background:var(--pink-light);color:var(--text-heading)}
