*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--orange:#ff914d;--orange-light:#ffb347;--orange-pale:#fff0e6;--cream:#fff8ee;--cream-dark:#f2e7d4;--dark:#1a1a1a;--dark-mid:#2c2c2c;--gray:#6b6b6b;--gray-light:#e8e8e8;--white:#fff;--text-primary:#1a1a1a;--text-secondary:#555;--text-tertiary:#999;--success:#1d9e75;--danger:#e24b4a;--font:"DM Sans", sans-serif;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 12px #0000001a;--nav-height:64px}html{-webkit-text-size-adjust:100%;font-size:16px}body{font-family:var(--font);background-color:var(--cream);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.6}a{color:inherit;text-decoration:none}button{font-family:var(--font);cursor:pointer;border:none;outline:none}input,textarea,select{font-family:var(--font);outline:none}img{max-width:100%;display:block}#root{flex-direction:column;min-height:100vh;display:flex}.de-container{background:var(--cream);flex-direction:column;align-items:center;min-height:100vh;padding:40px 16px 100px;display:flex}.de-header{text-align:center;margin-bottom:40px}.de-logo-img{object-fit:contain;width:auto;height:90px}.de-card{background:var(--white);border-radius:var(--radius-xl);width:100%;max-width:520px;box-shadow:var(--shadow-md);padding:28px 24px}.de-section{margin-bottom:28px}.de-section-more{margin-bottom:24px}.de-section-more:last-child{margin-bottom:8px}.de-section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.de-section-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;font-size:.8rem;font-weight:500}.de-section-hint{color:var(--orange);font-size:.75rem;font-weight:500}.de-mood-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.de-mood-chip{border-radius:var(--radius-md);border:1.5px solid var(--gray-light);background:var(--white);color:var(--text-primary);cursor:pointer;font-size:.9rem;font-weight:500;font-family:var(--font);align-items:center;gap:8px;padding:12px 14px;transition:all .15s;display:flex}.de-mood-chip:hover:not(.selected){border-color:var(--orange);background:var(--orange-pale)}.de-mood-emoji{font-size:1.1rem}.de-type-row{gap:10px;display:flex}.de-type-chip{border-radius:var(--radius-md);border:1.5px solid var(--gray-light);background:var(--white);cursor:pointer;font-family:var(--font);flex-direction:column;flex:1;align-items:center;gap:4px;padding:16px 12px;transition:all .15s;display:flex}.de-type-chip:hover:not(.selected){border-color:var(--orange);background:var(--orange-pale)}.de-type-chip.selected{border-color:var(--orange);background:var(--orange);color:var(--white)}.de-type-emoji{margin-bottom:2px;font-size:1.4rem}.de-type-label{font-size:.95rem;font-weight:600}.de-type-sub{opacity:.7;font-size:.72rem}.de-time-row{gap:8px;display:flex}.de-time-chip{border-radius:var(--radius-md);border:1.5px solid var(--gray-light);background:var(--white);cursor:pointer;font-family:var(--font);flex-direction:column;flex:1;align-items:center;gap:2px;padding:12px 8px;transition:all .15s;display:flex}.de-time-chip:hover:not(.selected){border-color:var(--orange);background:var(--orange-pale)}.de-time-chip.selected{border-color:var(--orange);background:var(--orange);color:var(--white)}.de-time-label{font-size:.9rem;font-weight:500}.de-cta{border-radius:var(--radius-md);background:var(--gray-light);width:100%;color:var(--text-tertiary);font-size:.95rem;font-weight:600;font-family:var(--font);margin-bottom:12px;padding:14px;transition:all .2s}.de-cta.ready{background:var(--orange);color:var(--white)}.de-cta.ready:hover{background:var(--orange-light);transform:translateY(-1px)}.de-more-toggle{border-radius:var(--radius-md);border:1.5px dashed var(--gray-light);width:100%;color:var(--text-tertiary);cursor:pointer;font-size:.85rem;font-weight:500;font-family:var(--font);background:0 0;justify-content:center;align-items:center;gap:6px;padding:10px;transition:all .15s;display:flex}.de-more-toggle:hover{border-color:var(--orange);color:var(--orange);background:var(--orange-pale)}.de-more-badge{background:var(--orange);color:var(--white);border-radius:10px;margin-left:6px;padding:1px 7px;font-size:.7rem;font-weight:600;display:inline-block}.de-more-arrow{font-size:.9rem;transition:transform .25s;display:inline-block}.de-more-arrow.open{transform:rotate(180deg)}.de-more-panel{opacity:0;max-height:0;transition:max-height .35s,opacity .25s;overflow:hidden}.de-more-panel.open{opacity:1;max-height:600px}.de-more-inner{border-top:1px solid var(--gray-light);margin-top:16px;padding-top:20px}.de-time-scroll{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:8px;padding-bottom:6px;display:flex;overflow-x:auto}.de-time-scroll::-webkit-scrollbar{display:none}.de-scroll-chip{border:1.5px solid var(--gray-light);background:var(--white);color:var(--text-primary);cursor:pointer;scroll-snap-align:start;white-space:nowrap;font-size:.85rem;font-weight:500;font-family:var(--font);border-radius:20px;flex-shrink:0;padding:8px 16px;transition:all .15s}.de-scroll-chip:hover:not(.selected){border-color:var(--orange);background:var(--orange-pale)}.de-scroll-chip.selected{border-color:var(--orange);background:var(--orange);color:var(--white)}.de-genre-grid{grid-template-columns:1fr 1fr 1fr;gap:7px;display:grid}.de-genre-chip{border-radius:var(--radius-sm);border:1.5px solid var(--gray-light);background:var(--white);color:var(--text-primary);cursor:pointer;text-align:center;font-size:.8rem;font-weight:500;font-family:var(--font);padding:9px 6px;transition:all .15s}.de-genre-chip:hover:not(.selected){border-color:var(--orange);background:var(--orange-pale)}.de-genre-chip.selected{border-color:var(--orange);background:var(--orange);color:var(--white)}.de-genre-chip.any.selected{background:var(--dark);border-color:var(--dark);color:var(--white)}@media (width>=768px){.de-card{padding:36px 32px}}.rec-loading{background:var(--cream);flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;display:flex}.rec-loading-logo{width:auto;height:60px}.rec-loading-text{color:var(--text-tertiary);font-size:1rem}.rec-spinner{border:3px solid var(--gray-light);border-top-color:var(--orange);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.rec-container{background:var(--cream);min-height:100vh;padding:0 0 80px}.rec-header{background:var(--white);border-bottom:1px solid var(--gray-light);z-index:10;justify-content:space-between;align-items:center;padding:12px 20px;display:flex;position:sticky;top:0}.rec-back{color:var(--orange);cursor:pointer;font-size:.9rem;font-weight:500;font-family:var(--font);text-align:left;background:0 0;border:none;width:60px}.rec-logo{width:auto;height:56px}.rec-title{color:var(--text-primary);text-align:center;padding:24px 20px 4px;font-size:1.5rem;font-weight:700}.rec-subtitle{color:var(--text-tertiary);text-transform:capitalize;text-align:center;padding:0 20px 20px;font-size:.85rem}.rec-list{flex-direction:column;gap:16px;max-width:720px;margin:0 auto;padding:0 16px;display:flex}.rec-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);opacity:1;transition:transform .32s cubic-bezier(.4,0,.2,1),opacity .32s;position:relative;overflow:hidden;transform:translate(0)}.rec-card.leaving{opacity:0;transform:translate(-110%)}.rec-card.entering{animation:.35s cubic-bezier(.4,0,.2,1) forwards slideInRight}@keyframes slideInRight{0%{opacity:0;transform:translate(110%)}to{opacity:1;transform:translate(0)}}.rec-card-inner{display:flex}.rec-poster-wrap{border-radius:var(--radius-lg) 0 0 var(--radius-lg);flex-shrink:0;width:120px;min-height:185px;overflow:hidden}.rec-poster{object-fit:cover;width:100%;height:100%;image-rendering:-webkit-optimize-contrast;display:block}.rec-poster-placeholder{background:var(--orange-pale);width:100%;height:185px;color:var(--orange);justify-content:center;align-items:center;font-size:2rem;font-weight:700;display:flex}.rec-info{flex-direction:column;flex:1;gap:4px;padding:14px 14px 12px;display:flex}.rec-top-row{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.rec-title-text{color:var(--text-primary);flex:1;font-size:.95rem;font-weight:700;line-height:1.3}.rec-imdb-badge{background:#f5c518;border-radius:6px;flex-shrink:0;align-items:center;padding:4px 8px;display:flex}.rec-imdb-text{color:#1a1a1a;white-space:nowrap;font-size:.78rem;font-weight:700;line-height:1}.rec-meta-row{justify-content:space-between;align-items:center;gap:5px;display:flex}.rec-meta-left{flex-wrap:wrap;flex:1;align-items:center;gap:5px;display:flex}.rec-type-badge{text-transform:uppercase;letter-spacing:.04em;border-radius:10px;padding:2px 8px;font-size:.7rem;font-weight:600}.rec-type-badge.movie{background:var(--orange-pale);color:var(--orange)}.rec-type-badge.series{color:#378add;background:#e8f4fd}.rec-year{color:var(--text-tertiary);font-size:.8rem;font-weight:500}.rec-dot{color:var(--text-tertiary);font-size:.8rem;line-height:1}.rec-genre-tag{color:var(--text-tertiary);font-size:.8rem}.rec-credits{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;font-weight:600;line-height:1.4;overflow:hidden}.rec-overview{color:var(--text-secondary);flex:1;font-size:.8rem;line-height:1.5}.rec-bottom-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.rec-providers{align-items:center;gap:6px;display:flex}.rec-provider-logo{object-fit:cover;width:28px;height:28px;image-rendering:-webkit-optimize-contrast;border-radius:6px}.rec-bms-btn{color:#e0143c;white-space:nowrap;background:#fff0f3;border:1.5px solid #e0143c;border-radius:20px;padding:4px 12px;font-size:.75rem;font-weight:600;text-decoration:none;transition:all .15s}.rec-bms-btn:hover{color:#fff;background:#e0143c}.rec-watched-btn{color:var(--text-tertiary);background:var(--cream);border:1.5px solid var(--gray-light);cursor:pointer;font-size:.78rem;font-family:var(--font);border-radius:20px;align-self:flex-start;align-items:center;gap:6px;padding:5px 14px;font-weight:500;transition:all .2s;display:flex}.rec-watched-btn:hover:not(:disabled),.rec-watched-btn.confirmed{border-color:var(--success);color:var(--success);background:#e8f7f2}.rec-empty{text-align:center;flex-direction:column;align-items:center;gap:8px;padding:60px 20px;display:flex}.rec-empty-icon{margin-bottom:8px;font-size:2.5rem}.rec-empty-text{color:var(--text-primary);font-size:1rem;font-weight:600}.rec-empty-sub{color:var(--text-tertiary);font-size:.85rem}.rec-refresh{border-radius:var(--radius-md);border:1.5px solid var(--orange);color:var(--orange);cursor:pointer;font-size:.9rem;font-weight:600;font-family:var(--font);background:0 0;margin:24px auto 0;padding:12px 32px;transition:all .15s;display:block}.rec-refresh:hover{background:var(--orange);color:var(--white)}.rec-back-btn{border-radius:var(--radius-md);background:var(--orange);color:var(--white);cursor:pointer;font-size:.9rem;font-weight:600;font-family:var(--font);border:none;padding:10px 24px}@media (width>=768px){.rec-list{padding:0 24px}.rec-poster-wrap{width:130px;min-height:195px}}.app{background:var(--cream);flex-direction:column;min-height:100vh;display:flex}
