*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Helvetica Neue,Arial,Hiragino Kaku Gothic ProN,Yu Gothic,sans-serif;background:#f7f8fc;color:#2c3e50;min-height:100vh;-webkit-font-smoothing:antialiased}.header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 0 1.2rem;border-bottom:1px solid #e8ecf0}.header__title{font-size:1.4rem;font-weight:700;color:#2c3e50;letter-spacing:-.02em}.header__add-btn{background:#4f7ef7;color:#fff;border:none;border-radius:8px;padding:.6rem 1.2rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s ease,transform .1s ease;white-space:nowrap}.header__add-btn:hover{background:#3a66e0}.header__add-btn:active{transform:scale(.97)}.filter-tabs{display:flex;gap:0;border-bottom:2px solid #e8ecf0;margin-bottom:1.5rem}.filter-tabs__tab{background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;padding:.65rem 1.3rem;font-size:.92rem;font-weight:500;color:#7f8c8d;cursor:pointer;transition:color .2s ease,border-color .2s ease;letter-spacing:.02em}.filter-tabs__tab:hover{color:#4f7ef7}.filter-tabs__tab--active{color:#4f7ef7;border-bottom-color:#4f7ef7;font-weight:700}.movie-card{background:#fff;border-radius:12px;padding:1.2rem 1rem 1rem 1.2rem;box-shadow:0 2px 8px #00000012;position:relative;transition:box-shadow .2s ease,transform .2s ease;display:flex;flex-direction:column;gap:.5rem}.movie-card:hover{box-shadow:0 6px 20px #0000001c;transform:translateY(-2px)}.movie-card__delete{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:#c0c9d4;font-size:1.1rem;line-height:1;width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer;transition:background .2s ease,color .2s ease}.movie-card__delete:hover{background:#fff0f0;color:#e74c3c}.movie-card__title{font-size:1rem;font-weight:700;color:#2c3e50;line-height:1.4;margin-right:1.6rem}.movie-card__memo{font-size:.83rem;color:#7f8c8d;line-height:1.55}.movie-card__badge{display:inline-block;font-size:.75rem;font-weight:600;padding:.22rem .75rem;border-radius:20px;margin-top:.2rem;align-self:flex-start}.movie-card__badge--watchlist{background:#ebf2ff;color:#4f7ef7}.movie-card__badge--watched{background:#e9faf2;color:#27ae60}.movie-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.movie-list__empty{text-align:center;padding:5rem 1rem;color:#aab4be}.movie-list__empty-text{font-size:1rem;font-weight:600;margin-bottom:.4rem}.movie-list__empty-sub{font-size:.85rem}.modal-overlay{position:fixed;inset:0;background:#0000007a;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal{background:#fff;border-radius:16px;padding:2rem;width:100%;max-width:480px;box-shadow:0 24px 64px #0003}.modal__title{font-size:1.15rem;font-weight:700;color:#2c3e50;margin-bottom:1.5rem}.modal__field{margin-bottom:1.1rem}.modal__label{display:block;font-size:.82rem;font-weight:600;color:#555;margin-bottom:.4rem;letter-spacing:.02em}.modal__required{color:#e74c3c}.modal__input,.modal__textarea{width:100%;border:1.5px solid #e0e5ec;border-radius:8px;padding:.65rem .85rem;font-size:.95rem;font-family:inherit;color:#2c3e50;outline:none;transition:border-color .2s ease;resize:vertical;background:#fafbfc}.modal__input:focus,.modal__textarea:focus{border-color:#4f7ef7;background:#fff}.modal__radio-group{display:flex;gap:1.5rem;margin-top:.2rem}.modal__radio{display:flex;align-items:center;gap:.45rem;font-size:.93rem;cursor:pointer;color:#444}.modal__actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.6rem}.modal__btn-cancel{background:none;border:1.5px solid #e0e5ec;color:#7f8c8d;border-radius:8px;padding:.6rem 1.2rem;font-size:.9rem;cursor:pointer;transition:background .2s ease}.modal__btn-cancel:hover{background:#f5f7fa}.modal__btn-submit{background:#4f7ef7;color:#fff;border:none;border-radius:8px;padding:.6rem 1.4rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s ease}.modal__btn-submit:hover:not(:disabled){background:#3a66e0}.modal__btn-submit:disabled{background:#c0c9d4;cursor:not-allowed}.app{max-width:960px;margin:0 auto;padding:0 1.5rem 3rem}.main{margin-top:1.5rem}
