@import"https://fonts.googleapis.com/css2?family=Dancing+Script:wght@600;700&family=Nunito:wght@400;500;600;700&family=Quicksand:wght@500;600;700&display=swap";:root{--bg: #fff8fb;--card: #ffffff;--text: #3b4568;--muted: #66708f;--line: #ffd3e7;--primary: #ff2f8d;--primary-deep: #f42063;--danger: #ef476f;--soft-shadow: 0 16px 34px rgba(255, 47, 141, .14);--font-body: "Nunito", sans-serif;--font-ui: "Quicksand", sans-serif;--font-display: "Dancing Script", cursive;font-family:var(--font-body)}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:var(--font-body);color:var(--text);background:radial-gradient(circle at 8% 8%,#ffd3e8 0%,transparent 32%),radial-gradient(circle at 94% 0%,#ffe5ef 0%,transparent 28%),var(--bg)}h1,h2{font-family:var(--font-ui);font-weight:600}h3,button{font-family:var(--font-ui)}.wishlist-shell{min-height:100vh;padding-bottom:4rem}.topbar{background:linear-gradient(95deg,#ff2f8d 10%,#ff3f59 90%);box-shadow:0 10px 30px #ff3f5947}.topbar__content{max-width:1160px;margin:0 auto;padding:1rem 1.25rem;display:flex;justify-content:space-between;align-items:center}.topbar h1{margin:0;font-size:1.95rem;color:#fff;letter-spacing:.2px;font-family:var(--font-display);font-weight:700}.logout-button,.add-button,.add-modal button,.login-form button{border:none;padding:.62rem 1.05rem;border-radius:.75rem;background:linear-gradient(135deg,var(--primary),var(--primary-deep));color:#fff;font-weight:600;font-size:.9rem;cursor:pointer;box-shadow:0 10px 22px #ff2f8d38;transition:transform .15s ease,box-shadow .15s ease}.logout-button{background:transparent;box-shadow:none;padding:.2rem;border-radius:.6rem}.logout-button:hover{transform:none;box-shadow:none;background:#ffffff1f}.logout-button:hover,.add-button:hover,.add-modal button:hover,.login-form button:hover{transform:translateY(-1px);box-shadow:0 14px 28px #ff2f8d47}.wishlist-panel{max-width:1160px;margin:0 auto;padding:2rem 1.25rem}.wishlist-heading-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem}.wishlist-heading-row h2{margin:0;font-family:var(--font-display);font-size:2.2rem;font-weight:700;color:#e70f67}.panel-actions{display:flex;justify-content:flex-start;gap:1rem;flex-wrap:wrap;align-items:center}.filters{display:flex;gap:.65rem;flex-wrap:wrap}.filters button{border:2px solid var(--line);background:#fff;padding:.55rem .9rem;border-radius:.65rem;font-size:.88rem;font-weight:600;color:var(--text);cursor:pointer;transition:all .15s ease;min-width:7rem}.filters button.active{border-color:transparent;background:linear-gradient(140deg,#ff2f8d,#ff4d6d);color:#fff;box-shadow:0 10px 24px #ff2f8d45}.modal-backdrop{position:fixed;inset:0;background:#1b1d2e47;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:center;padding:1.2rem;z-index:20;animation:pop-in .22s ease}.modal-dismiss{position:absolute;inset:0;border:0;padding:0;background:transparent;box-shadow:none;cursor:default}.add-modal{position:relative;z-index:1;width:min(880px,100%);background:#ddd;border:2px solid #f4bbdb;border-radius:1.2rem;overflow:hidden;box-shadow:0 24px 40px #15172c38;padding:0}.add-modal__header{background:#eee8eb;border-bottom:1px solid #f0bad8;padding:1.25rem 1.5rem;display:flex;justify-content:space-between;align-items:center}.add-modal__header h2{margin:0;font-size:2rem;line-height:1;color:#eb165f}.close-x{background:transparent;box-shadow:none;font-size:2rem;line-height:1;color:#8b96ac;padding:.2rem}.add-modal__body{padding:1.5rem;display:grid;gap:1rem}label{display:grid;gap:.35rem;font-weight:700;font-size:.95rem;font-family:var(--font-ui)}.add-modal label{font-size:1rem;font-family:var(--font-ui);font-weight:700;color:#3f4b64}input,textarea,select{padding:.65rem .75rem;border:2px solid #e9b9d8;border-radius:1rem;font:inherit;color:var(--text);background:#fcfcfc}.urgency-picker{display:grid;gap:.6rem}.urgency-picker p{margin:0;font-family:var(--font-ui);font-size:1rem;font-weight:700}.urgency-picker>div{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.7rem}.urgency-picker button{border:2px solid #e7b4d3;background:#efefef;color:#3e4a62;box-shadow:none;padding:.85rem;font-size:1.2rem}.urgency-picker button.active{background:#e8d6e5;border-color:#ef3f95;color:#b11463}.add-modal__actions{display:flex;gap:.8rem;margin-top:.25rem}.add-modal__actions button{flex:1;padding:.82rem;font-size:1.3rem}.ghost{background:transparent;color:var(--text);box-shadow:none;border:2px solid #e7b4d3}.message{margin:.7rem 0;padding:.65rem .8rem;border-radius:.6rem;font-weight:700}.message.error{background:#ffe8ed;color:#b03057}.message.success{background:#ffeef6;color:#bf2d78}.empty-state{margin-top:5.5rem;text-align:center;color:var(--muted);animation:pop-in .4s ease}.empty-heart{font-size:5rem;line-height:1;color:#ff9ec8}.items-grid{list-style:none;padding:0;margin:1.5rem 0 0;display:grid;gap:1.05rem}.urgency-heading{margin:1.2rem 0 0;display:inline-flex;align-items:center;gap:.6rem;font-size:1rem;font-family:var(--font-ui);font-weight:500;color:#1f2636}.urgency-dot{width:.8rem;height:.8rem;border-radius:999px;display:inline-block}.urgency-dot--high{background:#f2557d}.urgency-dot--medium{background:#e53597}.urgency-dot--low{background:#6bb56f}.wishlist-card{background:#fff;border:2px solid #efbddc;border-radius:1.05rem;padding:1.15rem 1.25rem;display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}.wishlist-card__main{flex:1;min-width:0;display:grid;gap:.6rem}.wishlist-card__title-row{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap}.wishlist-card__title-row h3{margin:0;font-size:1rem;font-weight:500;color:#1f2636}.wishlist-link{color:#ea1876;text-decoration:none;font-size:.95rem;line-height:1.45;word-break:break-all}.wishlist-link:hover{text-decoration:underline}.wishlist-notes{margin:0;font-size:1.05rem;color:#4f5871}.wishlist-date{margin:0;font-size:.82rem;color:#7e879b}.priority{display:inline-flex;padding:.25rem .72rem;border-radius:.45rem;font-size:.72rem;font-weight:600;letter-spacing:.2px;border:2px solid transparent}.priority--high{background:#ffe0e7;color:#a81f48;border-color:#f6b5c8}.priority--medium{background:#edd9ea;color:#b21a73;border-color:#f08cc4}.priority--low{background:#e9f7df;color:#3c8a43;border-color:#b8dfb0}.wishlist-card__actions{display:flex;align-items:center;gap:.6rem}.icon-button{width:2.35rem;height:2.35rem;display:inline-flex;align-items:center;justify-content:center;border-radius:.75rem;border:2px solid #ef8cc5;background:#f7f1f5;color:#eb1e7e;box-shadow:none;padding:0}.icon-button svg{display:block}.icon-button--ghost{border:none;background:transparent;color:#8f97ab}.icon-button--ghost svg{display:block}.icon-button:hover{transform:translateY(-1px)}.login-shell{min-height:100vh;display:grid;place-items:center;padding:1.5rem}.login-card{max-width:460px;width:100%;padding:1.35rem;background:#fff;border:1px solid #ffd9eb;border-radius:1.1rem;box-shadow:var(--soft-shadow);display:grid;gap:.8rem;animation:pop-in .35s ease}.login-card h1,.login-card p{margin:0}.login-card h1{font-size:2.3rem;font-family:var(--font-display)}.login-card__kicker{display:inline-block;padding:.3rem .65rem;background:#ffe2ef;color:#b12f6e;font-weight:700;border-radius:999px;justify-self:start;font-size:.82rem}.login-form{display:grid;gap:.75rem}@keyframes pop-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:700px){.topbar h1{font-size:1.5rem}.wishlist-panel{padding-top:1.25rem}.wishlist-heading-row{margin-bottom:.9rem}.wishlist-heading-row h2{font-size:2rem}.panel-actions{justify-content:flex-start}.filters{width:auto}.filters button{min-width:8.4rem}.add-button{margin-left:auto;padding-inline:1.15rem}.panel-actions{align-items:center}.add-modal__header h2{font-size:1.6rem}.add-modal label,.urgency-picker p{font-size:1rem}.urgency-picker>div{grid-template-columns:1fr}.add-modal__actions{flex-direction:column-reverse}.urgency-heading{font-size:.95rem}.wishlist-card{flex-direction:column}.wishlist-card__title-row h3{font-size:1rem}.wishlist-link,.wishlist-date,.priority{font-size:.82rem}.wishlist-card__actions{justify-content:flex-end;width:100%}}
