@font-face {
    font-family: "PickListBrand";
    src: url("/assets/fonts/FloridaVibes.woff2") format("woff2");
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

:root {
    --color-bg-surface: linear-gradient(180deg, #ffffff 0%, #f7f9fd 100%);
    --color-bg-surface-soft: linear-gradient(180deg, rgba(255, 255, 255, 0.95) 0%, rgba(247, 249, 253, 0.95) 100%);
    --color-bg-surface-input: linear-gradient(180deg, rgba(255, 255, 255, 0.9) 0%, rgba(247, 249, 253, 0.9) 100%);
    --color-bg-surface-strong: linear-gradient(180deg, rgba(255, 255, 255, 0.88) 0%, rgba(247, 249, 253, 0.88) 100%);
    --color-surface-raised: rgba(255, 255, 255, 0.84);
    --color-surface-raised-strong: rgba(248, 250, 255, 0.9);
    --color-chip-soft: rgba(47, 63, 93, 0.14);
    --color-chip-strong: rgba(47, 63, 93, 0.24);
    --color-warm-soft: rgba(255, 188, 99, 0.16);
    --color-action-primary-gradient: linear-gradient(150deg, #4a638d 0%, #3b537a 60%, #314767 100%);
    --color-action-ghost: rgba(47, 63, 93, 0.12);
    --color-text-main: #333;
    --color-text-muted: #555;
    --color-link: #273145;
    --color-border-soft: rgba(51, 51, 51, 0.1);
    --color-surface-border: rgba(255, 255, 255, 0.55);
    --color-success: #2f8a46;
    --color-danger: #d9363e;
    --radius-md: 12px;
    --radius-lg: 24px;
    --radius-xl: 32px;
    --shadow-card: 0 10px 24px rgba(51, 51, 51, 0.08), 0 2px 8px rgba(51, 51, 51, 0.05);
    --shadow-soft: 0 8px 20px rgba(51, 51, 51, 0.06);
}

* {
    box-sizing: border-box;
}

[hidden] {
    display: none !important;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    min-height: 100vh;
    font-family: Arial, sans-serif;
    color: var(--color-text-main);
    background:
        radial-gradient(120% 80% at 10% -10%, rgba(255, 180, 82, 0.16) 0%, rgba(255, 180, 82, 0) 55%),
        radial-gradient(90% 70% at 100% 0%, rgba(88, 91, 255, 0.07) 0%, rgba(88, 91, 255, 0) 60%),
        radial-gradient(110% 90% at 50% 18%, rgba(51, 51, 51, 0.05) 0%, rgba(51, 51, 51, 0) 68%),
        linear-gradient(180deg, #fbfaf8 0%, #f7f6f8 48%, #f3f4f7 100%);
    background-attachment: fixed;
}

a {
    color: inherit;
    text-decoration: none;
}

button,
input {
    font: inherit;
}

.page-shell {
    width: min(1320px, calc(100% - 48px));
    margin: 0 auto;
    padding: 28px 0 56px;
}

.page-shell--narrow {
    width: min(760px, calc(100% - 32px));
}

.site-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    margin-bottom: 34px;
}

.brand {
    font-family: "PickListBrand", Arial, sans-serif;
    font-size: clamp(48px, 5vw, 76px);
    line-height: 0.9;
    color: var(--color-text-main);
}

.header-nav {
    display: flex;
    align-items: center;
    gap: 12px;
}

.header-link,
.header-button,
.hero-cta,
.link-like {
    border: 0;
    background: transparent;
    cursor: pointer;
}

.header-link,
.header-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 0 18px;
    border-radius: 999px;
    color: var(--color-link);
    font-size: 15px;
    font-weight: 700;
}

.header-button {
    background: var(--color-chip-soft);
    border: 1px solid rgba(47, 63, 93, 0.16);
}

.landing-main {
    display: grid;
    gap: 30px;
}

.hero-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(410px, 470px);
    gap: 30px;
    align-items: start;
}

.hero-copy,
.auth-card,
.step-card,
.wishlist-card,
.feature-card,
.final-cta-section {
    border: 1px solid var(--color-surface-border);
    background: var(--color-bg-surface);
    box-shadow: var(--shadow-card);
}

.step-card,
.wishlist-card,
.feature-card {
    content-visibility: auto;
    contain-intrinsic-size: 320px;
}

.hero-copy {
    padding: 42px;
    border-radius: var(--radius-xl);
}

.hero-badge,
.section-kicker,
.feature-card__label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0 14px;
    border-radius: 999px;
    background: var(--color-chip-soft);
    color: var(--color-link);
    border: 1px solid rgba(47, 63, 93, 0.14);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.hero-title {
    margin: 22px 0 16px;
    max-width: 12ch;
    font-size: clamp(54px, 6vw, 86px);
    line-height: 0.96;
}

.hero-subtitle {
    max-width: 720px;
    margin: 0;
    font-size: 19px;
    line-height: 1.7;
    color: var(--color-text-muted);
}

.hero-actions,
.final-cta-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 28px;
}

.hero-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 56px;
    padding: 0 24px;
    border-radius: 16px;
    font-size: 15px;
    font-weight: 700;
    line-height: 1.2;
}

.hero-cta__icon {
    width: 18px;
    height: 18px;
    flex: 0 0 18px;
    object-fit: contain;
    margin-right: 8px;
}

.hero-cta-main,
.action-btn {
    background: var(--color-action-primary-gradient);
    color: #fff;
    box-shadow: 0 8px 18px rgba(45, 67, 106, 0.24), inset 0 1px 0 rgba(255, 255, 255, 0.3);
}

.hero-cta-ghost {
    border: 1px solid rgba(47, 63, 93, 0.24);
    background: var(--color-bg-surface-soft);
    color: var(--color-link);
}

.hero-cta-edit-muted {
    background: rgba(255, 255, 255, 0.82);
    border-color: rgba(208, 217, 233, 0.82);
    color: #667089;
}

.hero-cta-edit-muted:hover,
.hero-cta-edit-muted:focus-visible {
    background: rgba(248, 250, 255, 0.92);
    border-color: rgba(89, 105, 139, 0.45);
    color: #5c667a;
}

.hero-proof {
    margin: 16px 0 0;
    color: var(--color-text-muted);
    font-size: 14px;
    font-weight: 600;
}

.trust-section {
    margin-top: 34px;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.trust-item {
    padding: 20px;
    border-radius: 20px;
    background: var(--color-surface-raised);
    border: 1px solid rgba(79, 96, 129, 0.18);
    box-shadow: inset 0 1px 0 rgba(255, 248, 240, 0.45);
}

.trust-value {
    font-size: 24px;
    font-weight: 700;
    line-height: 1.15;
}

.trust-label {
    margin-top: 8px;
    color: var(--color-text-muted);
    font-size: 15px;
    line-height: 1.5;
}

.auth-shell {
    position: sticky;
    top: 24px;
}

.auth-card {
    padding: 28px;
    border-radius: var(--radius-lg);
}

.auth-card--pulse {
    animation: auth-card-pulse 0.9s ease-out;
}

.auth-card__top {
    margin-bottom: 24px;
}

.auth-card__overline {
    margin: 0 0 8px;
    color: #697389;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.auth-card h2 {
    margin: 0;
    font-size: 34px;
}

.auth-card__lead {
    margin: 10px 0 0;
    color: var(--color-text-muted);
    font-size: 15px;
    line-height: 1.6;
}

.auth-switcher {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    padding: 6px;
    margin-bottom: 20px;
    border-radius: 16px;
    background: var(--color-chip-soft);
    border: 1px solid rgba(47, 63, 93, 0.12);
}

.auth-switcher__tab {
    min-height: 46px;
    border: 1px solid transparent;
    border-radius: 12px;
    background: transparent;
    color: var(--color-text-muted);
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
}

.auth-switcher__tab.is-active {
    border-color: rgba(47, 63, 93, 0.2);
    background: var(--color-bg-surface-strong);
    color: var(--color-link);
    box-shadow: 0 6px 14px rgba(34, 49, 78, 0.12);
}

.auth-form {
    display: none;
    flex-direction: column;
    gap: 10px;
}

.auth-form.is-active {
    display: flex;
}

.field {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.auth-form__intro {
    margin: 0 0 4px;
    color: var(--color-text-muted);
    font-size: 14px;
    line-height: 1.6;
}

.field span {
    font-size: 14px;
    font-weight: 700;
    color: var(--color-text-main);
}

.field input {
    width: 100%;
    min-height: 52px;
    padding: 0 16px;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border-soft);
    background: var(--color-bg-surface-input);
    box-shadow: inset 0 1px 0 rgba(255, 248, 240, 0.36);
    color: var(--color-text-main);
    font-size: 16px;
}

.field input::placeholder {
    color: #6d7888;
}

.field input:focus,
.auth-switcher__tab:focus-visible,
.action-btn:focus-visible,
.oauth-btn:focus-visible,
.header-button:focus-visible,
.hero-cta:focus-visible,
.header-link:focus-visible,
.link-like:focus-visible {
    outline: none;
    border-color: rgba(61, 93, 165, 0.55);
    box-shadow: 0 0 0 3px rgba(51, 75, 136, 0.14);
}

.field-hint {
    display: none;
    margin: -2px 0 2px;
    font-size: 13px;
    line-height: 1.4;
    color: var(--color-text-muted);
}

.field-hint:not(:empty) {
    display: block;
}

.field-hint.success {
    color: var(--color-success);
}

.field-hint.error {
    color: var(--color-danger);
}

.remember-me,
.consent-field {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    color: var(--color-text-muted);
    font-size: 14px;
    line-height: 1.5;
}

.remember-me input[type="checkbox"],
.consent-field input[type="checkbox"] {
    width: 16px;
    height: 16px;
    margin: 2px 0 0;
    accent-color: var(--color-text-main);
    flex-shrink: 0;
}

.action-btn,
.oauth-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 52px;
    padding: 0 18px;
    border-radius: 12px;
    font-size: 15px;
    font-weight: 700;
}

.action-btn {
    border: 1px solid rgba(74, 103, 159, 0.44);
    cursor: pointer;
}

.oauth-btn {
    border: 1px solid rgba(37, 37, 37, 0.1);
}

.oauth-btn-yandex {
    background: linear-gradient(180deg, #ffdb4d 0%, #ffcc00 100%);
    color: #1f1f1f;
    box-shadow: 0 8px 18px rgba(217, 170, 0, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.45);
}

.oauth-note {
    margin: 2px 0 0;
    font-size: 13px;
    line-height: 1.5;
    text-align: center;
    color: var(--color-text-muted);
}

.oauth-note a,
.consent-field a,
.links-row a,
.link-like {
    color: var(--color-link);
    font-weight: 700;
}

.links-row {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    padding-top: 4px;
    flex-wrap: wrap;
}

.links-row--single {
    justify-content: center;
}

.link-like {
    padding: 0;
    font-size: 15px;
}

.steps-section,
.demo-section,
.features-section {
    padding-top: 8px;
}

.section-heading {
    margin-bottom: 22px;
}

.section-heading h2 {
    margin: 16px 0 0;
    font-size: clamp(34px, 4vw, 52px);
    line-height: 1.05;
}

.steps-grid,
.features-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.step-card,
.feature-card {
    padding: 24px;
    border-radius: 22px;
}

.step-num {
    display: inline-flex;
    margin-bottom: 16px;
    color: #3b537a;
    font-size: 14px;
    font-weight: 800;
    letter-spacing: 0.1em;
}

.step-card strong,
.feature-card strong {
    display: block;
    font-size: 22px;
    line-height: 1.35;
}

.step-card p {
    margin: 12px 0 0;
    color: var(--color-text-muted);
    font-size: 16px;
    line-height: 1.6;
}

.demo-layout {
    display: grid;
    grid-template-columns: minmax(280px, 340px) minmax(0, 1fr);
    gap: 18px;
    align-items: start;
}

.landing-demo-shell {
    padding: 18px;
    border-radius: 32px;
    border: 1px solid rgba(79, 96, 129, 0.2);
    background:
        radial-gradient(circle at top left, rgba(216, 151, 58, 0.16), transparent 26%),
        linear-gradient(180deg, rgba(231, 237, 245, 0.94) 0%, rgba(247, 241, 233, 0.98) 100%);
    box-shadow: 0 30px 70px rgba(20, 28, 43, 0.12);
}

.landing-demo-screen {
    display: grid;
    gap: 14px;
}

.landing-demo-screen .wishlist-view-stage,
.landing-demo-screen .wishlist-view-collection {
    position: relative;
}

.landing-demo-screen .wishlist-view-stage__main,
.landing-demo-screen .wishlist-view-collection {
    border-radius: 22px;
}

.landing-demo-owner {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-height: 34px;
    padding: 4px 12px 4px 8px;
    border-radius: 999px;
    background: rgba(34, 46, 68, 0.14);
    color: var(--color-text-main);
    font-size: 13px;
    font-weight: 700;
}

.landing-demo-owner__avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border-radius: 30%;
    background: rgba(124, 79, 34, 0.12);
    color: #7c4f22;
    font-size: 12px;
    font-weight: 800;
    flex-shrink: 0;
}

.demo-items {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.wishlist-card {
    padding: 22px;
    border-radius: 22px;
}

.wishlist-card--cover {
    min-height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    background:
        linear-gradient(180deg, rgba(247, 240, 231, 0.92) 0%, rgba(233, 239, 247, 0.96) 100%),
        radial-gradient(circle at top right, rgba(230, 173, 74, 0.22), rgba(230, 173, 74, 0));
}

.wishlist-title {
    font-size: 28px;
    font-weight: 700;
}

.wishlist-desc {
    margin-top: 8px;
    color: var(--color-text-muted);
    font-size: 15px;
    line-height: 1.55;
}

.wishlist-card-header,
.item-header-main,
.item-meta,
.item-footer {
    display: flex;
}

.wishlist-card-header {
    justify-content: space-between;
    gap: 10px;
}

.item-header-main {
    align-items: center;
    gap: 10px;
}

.wishlist-item-title {
    font-size: 20px;
    font-weight: 700;
    line-height: 1.35;
}

.wishlist-item-reserved-label {
    display: inline-flex;
    margin-left: 8px;
    padding: 4px 8px;
    border-radius: 999px;
    background: var(--color-chip-soft);
    color: var(--color-link);
    border: 1px solid rgba(47, 63, 93, 0.12);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.04em;
    vertical-align: middle;
}

.item-priority-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    flex-shrink: 0;
}

.item-priority-dot.high,
.item-priority.high {
    background: rgba(217, 54, 62, 0.14);
    color: #a52e3b;
}

.item-priority-dot.medium,
.item-priority.medium {
    background: rgba(255, 204, 0, 0.2);
    color: #8a6600;
}

.item-priority-dot.low,
.item-priority.low {
    background: rgba(95, 174, 83, 0.14);
    color: #3f7f37;
}

.item-priority-dot.high {
    background-color: #d9363e;
}

.item-priority-dot.medium {
    background-color: #ffcc00;
}

.item-priority-dot.low {
    background-color: #5fae53;
}

.item-meta {
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-top: 16px;
}

.item-link {
    color: var(--color-link);
    font-size: 14px;
    font-weight: 700;
}

.item-price {
    font-size: 15px;
    font-weight: 700;
}

.item-footer {
    margin-top: 16px;
}

.item-priority {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0 12px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 700;
}

.features-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.final-cta-section {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 20px;
    align-items: center;
    padding: 30px 32px;
    border-radius: var(--radius-xl);
}

.final-cta-section h2 {
    margin: 16px 0 12px;
    font-size: clamp(32px, 4vw, 46px);
    line-height: 1.05;
}

.final-cta-section p {
    margin: 0;
    max-width: 620px;
    color: var(--color-text-muted);
    font-size: 17px;
    line-height: 1.65;
}

.site-footer {
    padding-top: 18px;
}

.support-page-main {
    display: grid;
    gap: 26px;
}

.support-hero,
.support-card,
.support-faq-item {
    border: 1px solid var(--color-surface-border);
    background: var(--color-bg-surface);
    box-shadow: var(--shadow-card);
}

.support-card,
.support-faq-item {
    content-visibility: auto;
    contain-intrinsic-size: 280px;
}

.support-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(280px, 360px);
    gap: 22px;
    padding: 34px;
    border-radius: var(--radius-xl);
    align-items: start;
}

.support-hero__title {
    margin: 16px 0 14px;
    font-size: clamp(38px, 5vw, 62px);
    line-height: 1.02;
}

.support-hero__text,
.support-card p,
.support-platform p,
.support-faq-item p {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 16px;
    line-height: 1.7;
}

.support-hero__aside {
    display: grid;
    gap: 14px;
}

.support-highlight {
    padding: 18px 20px;
    border-radius: 22px;
    background: var(--color-surface-raised);
    border: 1px solid rgba(79, 96, 129, 0.18);
    box-shadow: inset 0 1px 0 rgba(255, 248, 240, 0.48);
}

.support-highlight strong {
    display: block;
    margin-bottom: 8px;
    font-size: 16px;
}

.support-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
}

.support-card {
    padding: 28px;
    border-radius: var(--radius-lg);
}

.header-link--badge {
    gap: 10px;
}

.header-link__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 24px;
    height: 24px;
    padding: 0 7px;
    border-radius: 999px;
    background: #314767;
    color: #fff;
    font-size: 12px;
    line-height: 1;
}

.site-header--app {
    align-items: flex-start;
}

.app-header-actions {
    display: flex;
    align-items: center;
    gap: 16px;
}

.app-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-end;
}

.app-nav__link,
.profile-pill {
    display: inline-flex;
    align-items: center;
    min-height: 44px;
    padding: 0 16px;
    border-radius: 999px;
    border: 1px solid rgba(79, 96, 129, 0.26);
    background: var(--color-surface-raised);
    color: var(--color-link);
    font-size: 14px;
    font-weight: 700;
}

.app-nav__link--active {
    background: var(--color-chip-strong);
    color: var(--color-text-main);
    border-color: rgba(47, 63, 93, 0.32);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.app-nav__link--cta {
    background: var(--color-action-primary-gradient);
    color: #fff;
    border-color: rgba(74, 103, 159, 0.44);
    box-shadow: 0 8px 18px rgba(45, 67, 106, 0.16), inset 0 1px 0 rgba(255, 255, 255, 0.24);
}

.profile-pill {
    gap: 10px;
}

.profile-pill--active {
    background: var(--color-chip-strong);
    color: var(--color-text-main);
    border-color: rgba(47, 63, 93, 0.32);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.profile-pill__name {
    max-width: 160px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.wishlists-page-main {
    display: grid;
    gap: 18px;
}

.wishlists-top-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 280px;
    gap: 10px;
    align-items: stretch;
}

.wishlists-overview-panel,
.wishlists-alert,
.wishlists-empty-card,
.desktop-wishlist-card {
    border: 1px solid var(--color-surface-border);
    background: var(--color-bg-surface);
    box-shadow: var(--shadow-card);
}

.desktop-wishlist-card {
    content-visibility: auto;
    contain-intrinsic-size: 260px;
}

.wishlists-alert p,
.wishlists-empty-card p,
.desktop-wishlist-card__description {
    color: var(--color-text-muted);
    font-size: 16px;
    line-height: 1.7;
    margin: 0;
}

.profile-page-main {
    display: grid;
    gap: 18px;
}

.events-page-main {
    gap: 16px;
}

.switch {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
}

.switch input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.switch .slider {
    position: relative;
    width: 44px;
    height: 26px;
    border-radius: 999px;
    background: rgba(79, 96, 129, 0.24);
    transition: background 0.2s ease;
    flex-shrink: 0;
}

.switch .slider::before {
    content: "";
    position: absolute;
    top: 3px;
    left: 3px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 2px 6px rgba(10, 18, 32, 0.2);
    transition: transform 0.2s ease;
}

.switch input:checked + .slider {
    background: #314767;
}

.switch input:checked + .slider::before {
    transform: translateX(18px);
}

.switch .switch-text {
    color: var(--color-text-main);
    font-size: 14px;
    font-weight: 600;
    line-height: 1.4;
}

.events-overview {
    display: grid;
    grid-template-columns: minmax(0, 1.3fr) minmax(220px, 0.35fr) minmax(220px, 0.35fr);
    gap: 14px;
}

.events-hero-card,
.events-upcoming-card,
.events-calendar,
.events-empty-state {
    border: 1px solid var(--color-surface-border);
    background: var(--color-bg-surface);
    box-shadow: var(--shadow-card);
}

.events-hero-card {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(300px, 0.9fr);
    gap: 16px;
    padding: 20px;
    border-radius: var(--radius-xl);
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.16), transparent 42%),
        linear-gradient(180deg, rgba(255, 253, 249, 0.98) 0%, rgba(242, 247, 253, 0.96) 100%);
}

.events-hero-card__copy {
    display: grid;
    align-content: start;
    gap: 12px;
}

.events-hero-card__title {
    margin: 0;
    font-size: clamp(28px, 3.2vw, 44px);
    line-height: 0.98;
}

.events-hero-card__text {
    margin: 0;
    max-width: 64ch;
    color: var(--color-text-muted);
    font-size: 15px;
    line-height: 1.6;
}

.events-hero-card__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.events-hero-card__spotlight {
    display: grid;
    gap: 12px;
    align-content: start;
}

.events-summary-card {
    min-height: 100%;
}

.events-summary-card--accent {
    background:
        radial-gradient(circle at top right, rgba(198, 132, 55, 0.16), transparent 38%),
        linear-gradient(180deg, rgba(255, 252, 247, 0.98) 0%, rgba(241, 246, 253, 0.98) 100%);
}

.events-summary-card__value {
    font-size: clamp(28px, 3.2vw, 42px);
    line-height: 1;
}

.events-spotlight-card,
.events-empty-panel {
    min-height: 100%;
    padding: 14px;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.62);
    border: 1px solid rgba(79, 96, 129, 0.18);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.events-spotlight-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 12px;
    align-items: center;
}

.events-spotlight-card__media {
    display: flex;
    align-items: center;
    justify-content: center;
}

.events-spotlight-card__avatar,
.events-spotlight-card__avatar--placeholder {
    width: 72px;
    height: 72px;
    border-radius: 18px;
}

.events-spotlight-card__avatar {
    object-fit: cover;
    border: 1px solid rgba(79, 96, 129, 0.18);
    background: rgba(255, 255, 255, 0.72);
}

.events-spotlight-card__avatar--placeholder,
.events-upcoming-card__avatar--placeholder {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.24), transparent 48%),
        linear-gradient(180deg, rgba(255, 251, 245, 0.98) 0%, rgba(233, 241, 252, 0.96) 100%);
    border: 1px solid rgba(79, 96, 129, 0.18);
}

.events-spotlight-card__fallback,
.events-upcoming-card__fallback {
    width: 58%;
    height: 58%;
    object-fit: contain;
    opacity: 0.88;
}

.events-avatar-placeholder-mark {
    color: var(--color-link);
    font-size: 16px;
    font-weight: 800;
    letter-spacing: 0.08em;
}

.events-spotlight-card__body {
    display: grid;
    gap: 6px;
    min-width: 0;
}

.events-spotlight-card__body strong,
.events-upcoming-card__copy strong,
.events-calendar-item__copy strong {
    font-size: 15px;
    line-height: 1.35;
}

.events-spotlight-card__body p,
.events-empty-panel p,
.events-upcoming-card__copy span,
.events-calendar-item__copy span {
    margin: 0;
    color: var(--color-text-muted);
    line-height: 1.45;
}

.events-spotlight-card__timer,
.events-upcoming-card__timer {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-height: 30px;
    padding: 0 10px;
    border-radius: 999px;
    background: rgba(47, 63, 93, 0.1);
    color: var(--color-link);
    font-size: 12px;
    font-weight: 700;
}

.events-empty-panel {
    display: grid;
    gap: 10px;
    align-content: center;
}

.events-upcoming-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.events-layer-panel {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 16px;
    border-radius: 22px;
    border: 1px solid var(--color-surface-border);
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.14), transparent 42%),
        linear-gradient(180deg, rgba(255, 252, 246, 0.98) 0%, rgba(244, 248, 253, 0.98) 100%);
    box-shadow: var(--shadow-card);
}

.events-layer-panel__switch {
    flex-shrink: 0;
}

.events-layer-panel__switch--compact {
    justify-content: flex-end;
}

.events-layer-panel__actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-start;
}

.events-layer-panel__side {
    margin-left: auto;
    display: flex;
    align-items: center;
}

.events-upcoming-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 16px;
    border-radius: 20px;
}

.events-upcoming-card--static,
.events-list-compact__item--static {
    cursor: default;
}

.events-upcoming-card__identity {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 10px;
    align-items: center;
    min-width: 0;
}

.events-upcoming-card__identity--no-avatar {
    grid-template-columns: minmax(0, 1fr);
}

.events-upcoming-card__avatar,
.events-upcoming-card__avatar--placeholder {
    width: 52px;
    height: 52px;
    border-radius: 14px;
}

.events-upcoming-card__avatar {
    object-fit: cover;
    border: 1px solid rgba(79, 96, 129, 0.18);
    background: rgba(255, 255, 255, 0.72);
}

.events-upcoming-card__copy {
    display: grid;
    gap: 4px;
    min-width: 0;
}

.events-my-alert {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 18px 22px;
    border: 1px solid rgba(198, 132, 55, 0.28);
    border-radius: 24px;
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.16), transparent 42%),
        linear-gradient(180deg, rgba(255, 252, 246, 0.98) 0%, rgba(244, 248, 253, 0.98) 100%);
    box-shadow: var(--shadow-card);
}

.events-my-alert__copy {
    display: grid;
    gap: 6px;
}

.events-my-alert__copy strong {
    font-size: 18px;
    line-height: 1.2;
}

.events-my-alert__copy p {
    margin: 0;
    color: var(--color-text-muted);
    line-height: 1.6;
}

.events-my-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
}

.events-my-card {
    min-height: 100%;
}

.events-my-card--create {
    display: grid;
    place-items: center;
    border-style: dashed;
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.18), transparent 42%),
        linear-gradient(180deg, rgba(255, 252, 246, 0.98) 0%, rgba(244, 248, 253, 0.98) 100%);
}

.events-my-card--create:hover {
    transform: translateY(-1px);
    box-shadow: 0 18px 32px rgba(48, 64, 92, 0.12);
}

.events-my-card--past {
    opacity: 0.88;
}

.events-my-card__icon {
    font-size: 22px;
    line-height: 1;
}

.events-my-card__footer {
    margin-top: auto;
    justify-content: flex-end;
}

.events-my-card__footer .events-my-card__edit-link::after {
    content: none !important;
}

.events-my-card__edit-link {
    justify-content: center;
    width: 100%;
    text-align: center;
}

.events-my-card-create__inner {
    display: grid;
    justify-items: center;
    gap: 10px;
    align-content: center;
    min-height: 100%;
    text-align: center;
}

.events-my-card-create__plus {
    color: var(--color-link);
    font-size: clamp(54px, 5vw, 72px);
    line-height: 1;
    font-weight: 300;
}

.events-my-card-create__plus .add-icon-image {
    width: clamp(54px, 5vw, 72px);
    height: clamp(54px, 5vw, 72px);
    display: block;
    object-fit: contain;
}

.events-my-card-create__label {
    color: var(--color-text-muted);
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.04em;
}

.events-my-empty-state {
    display: grid;
    gap: 18px;
    padding: 24px;
    border-radius: 24px;
}

.events-my-empty-state__actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.event-create-card {
    gap: 20px;
}

.event-create-form__grid {
    align-items: start;
}

.event-create-switches {
    display: grid;
    gap: 12px;
}

.event-toggle {
    display: grid;
    grid-template-columns: auto auto minmax(0, 1fr);
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    border: 1px solid rgba(79, 96, 129, 0.16);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.54);
    cursor: pointer;
}

.event-toggle input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.event-toggle__ui {
    position: relative;
    width: 44px;
    height: 26px;
    border-radius: 999px;
    background: rgba(79, 96, 129, 0.24);
    transition: background 0.2s ease;
}

.event-toggle__ui::after {
    content: "";
    position: absolute;
    top: 3px;
    left: 3px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 2px 6px rgba(10, 18, 32, 0.2);
    transition: transform 0.2s ease;
}

.event-toggle input:checked + .event-toggle__ui {
    background: #314767;
}

.event-toggle input:checked + .event-toggle__ui::after {
    transform: translateX(18px);
}

.event-toggle__copy {
    display: grid;
    gap: 4px;
}

.event-toggle__copy strong {
    font-size: 14px;
    line-height: 1.3;
}

.event-toggle__copy span {
    color: var(--color-text-muted);
    font-size: 13px;
    line-height: 1.5;
}

.event-access-fieldset {
    display: grid;
    gap: 14px;
    margin: 0;
    padding: 0;
    border: 0;
}

.event-access-fieldset legend {
    padding: 0;
    color: var(--color-text-main);
    font-size: 14px;
    font-weight: 700;
}

.event-access-fieldset--spaced legend {
    margin-bottom: 6px;
}

.event-access-grid,
.event-friends-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.event-access-card,
.event-friend-card {
    display: grid;
    gap: 8px;
    padding: 16px 18px;
    border: 1px solid rgba(79, 96, 129, 0.16);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.54);
    cursor: pointer;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease, transform 0.2s ease;
    position: relative;
    overflow: hidden;
}

.event-access-card input,
.event-friend-card input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.event-access-card::before,
.event-friend-card::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 0;
    background: linear-gradient(180deg, #314767 0%, #c68437 100%);
    opacity: 0.95;
    transition: width 0.2s ease;
}

.event-access-card::after,
.event-friend-card::after {
    content: "✓";
    position: absolute;
    top: 12px;
    right: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border-radius: 999px;
    background: #314767;
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    opacity: 0;
    transform: scale(0.85);
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.event-access-card:hover,
.event-friend-card:hover {
    border-color: rgba(49, 71, 103, 0.24);
}

.event-access-card.is-selected,
.event-friend-card.is-selected {
    border-color: rgba(49, 71, 103, 0.5);
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.18), transparent 48%),
        linear-gradient(180deg, rgba(245, 249, 255, 0.98) 0%, rgba(255, 249, 241, 0.98) 100%);
    box-shadow:
        0 0 0 3px rgba(49, 71, 103, 0.1),
        0 14px 28px rgba(49, 71, 103, 0.12);
    transform: translateY(-1px);
}

.event-access-card.is-selected::before,
.event-friend-card.is-selected::before {
    width: 6px;
}

.event-access-card.is-selected::after,
.event-friend-card.is-selected::after {
    opacity: 1;
    transform: scale(1);
}

.event-access-card__title,
.event-friend-card__name {
    color: var(--color-text-main);
    font-size: 15px;
    font-weight: 700;
    line-height: 1.35;
}

.event-access-card__text {
    color: var(--color-text-muted);
    font-size: 13px;
    line-height: 1.5;
}

.event-access-card.is-selected .event-access-card__title,
.event-friend-card.is-selected .event-friend-card__name {
    color: #243148;
}

.event-access-card.is-selected .event-access-card__text {
    color: #48566f;
}

.event-create-alert {
    margin-bottom: 2px;
}

.event-danger-zone {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 18px 20px;
    border: 1px solid rgba(185, 63, 78, 0.22);
    border-radius: 24px;
    background:
        radial-gradient(circle at top left, rgba(196, 78, 92, 0.12), transparent 42%),
        linear-gradient(180deg, rgba(255, 246, 247, 0.98) 0%, rgba(253, 240, 242, 0.98) 100%);
}

.event-danger-zone__copy {
    display: grid;
    gap: 6px;
}

.event-danger-zone__copy strong {
    font-size: 18px;
    line-height: 1.2;
    color: #8f2633;
}

.event-danger-zone__copy p {
    margin: 0;
    color: #7c4c55;
    line-height: 1.6;
}

.event-danger-zone__button {
    border-color: rgba(185, 63, 78, 0.3);
    color: #8f2633;
    background: rgba(255, 255, 255, 0.82);
}

.event-danger-zone__button:hover {
    border-color: rgba(185, 63, 78, 0.42);
    background: rgba(255, 248, 249, 0.96);
}

@media (max-width: 1420px) {
    .events-my-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.events-month-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 12px 16px;
    border: 1px solid var(--color-surface-border);
    border-radius: 22px;
    background: var(--color-bg-surface);
    box-shadow: var(--shadow-card);
}

.events-month-toolbar__nav {
    display: grid;
    grid-template-columns: 34px minmax(220px, auto) 34px;
    align-items: center;
    gap: 12px;
}

.events-month-toolbar__title {
    display: grid;
    justify-items: center;
    min-width: 0;
    text-align: center;
}

.events-month-toolbar__title strong {
    font-size: 16px;
    line-height: 1.2;
}

.events-month-toolbar__arrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: 999px;
    border: 1px solid rgba(79, 96, 129, 0.22);
    background: rgba(255, 255, 255, 0.64);
    color: var(--color-link);
    font-size: 16px;
    font-weight: 700;
}

.events-month-toolbar__arrow--disabled {
    opacity: 0.38;
}

.events-month-toolbar__picker {
    display: flex;
    align-items: center;
    gap: 10px;
}

.events-month-toolbar__label {
    color: var(--color-text-muted);
    font-size: 13px;
    font-weight: 700;
}

.events-month-toolbar__select {
    min-width: 220px;
    min-height: 36px;
    padding: 0 12px;
    border-radius: 999px;
    border: 1px solid rgba(79, 96, 129, 0.24);
    background: rgba(255, 255, 255, 0.7);
    color: var(--color-link);
}

.events-calendar {
    padding: 10px;
    border-radius: var(--radius-xl);
}

.events-calendar__scroller {
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 4px;
}

.events-calendar__weekdays {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 6px;
    margin-bottom: 6px;
    min-width: 760px;
}

.events-calendar__weekdays span {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 28px;
    border-radius: 10px;
    background: rgba(47, 63, 93, 0.08);
    color: var(--color-text-muted);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.events-calendar__grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 6px;
    min-width: 760px;
}

.events-calendar-day {
    display: grid;
    align-content: start;
    gap: 6px;
    min-height: 108px;
    padding: 8px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.7);
    border: 1px solid rgba(79, 96, 129, 0.18);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.events-calendar-day--muted {
    background: rgba(240, 244, 249, 0.55);
    color: rgba(66, 80, 99, 0.78);
}

.events-calendar-day--today {
    border-color: rgba(53, 87, 134, 0.42);
    box-shadow:
        0 10px 20px rgba(45, 67, 106, 0.08),
        inset 0 0 0 1px rgba(255, 255, 255, 0.72);
}

.events-calendar-day__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.events-calendar-day__head strong {
    font-size: 15px;
    line-height: 1;
}

.events-calendar-day--today .events-calendar-day__head strong {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    min-height: 32px;
    padding: 0 8px;
    border-radius: 999px;
    background: linear-gradient(150deg, #4a638d 0%, #344d74 100%);
    color: #fff;
    box-shadow: 0 6px 14px rgba(45, 67, 106, 0.22);
}

.events-calendar-day__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    border-radius: 999px;
    background: rgba(47, 63, 93, 0.12);
    color: var(--color-link);
    font-size: 10px;
    font-weight: 700;
}

.events-calendar-day__items {
    display: grid;
    gap: 4px;
}

.events-calendar-item {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 6px;
    align-items: start;
    padding: 5px 6px;
    border-radius: 10px;
    background: rgba(237, 243, 251, 0.88);
    border: 1px solid rgba(79, 96, 129, 0.14);
}

.events-calendar-item--birthday {
    background: rgba(255, 243, 229, 0.88);
    border-color: rgba(198, 132, 55, 0.2);
}

.events-calendar-item--holiday {
    background: rgba(238, 246, 255, 0.9);
    border-color: rgba(77, 118, 181, 0.2);
}

.events-calendar-item__icon {
    font-size: 12px;
    line-height: 1.3;
}

.events-calendar-item__copy {
    display: grid;
    gap: 2px;
    min-width: 0;
}

.events-calendar-item__copy strong {
    font-size: 11px;
    line-height: 1.25;
}

.events-calendar-item__copy span {
    font-size: 10px;
    line-height: 1.25;
}

.events-empty-state {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 18px;
    align-items: center;
    padding: 24px;
    border-radius: var(--radius-xl);
}

.events-empty-state__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 112px;
    min-height: 112px;
    padding: 16px;
    border-radius: 28px;
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.24), transparent 48%),
        linear-gradient(180deg, rgba(255, 251, 245, 0.98) 0%, rgba(233, 241, 252, 0.96) 100%);
    border: 1px solid rgba(79, 96, 129, 0.18);
    color: var(--color-link);
    font-size: 18px;
    font-weight: 700;
}

.events-empty-state__copy h2 {
    margin: 0 0 8px;
    font-size: 30px;
    line-height: 1.1;
}

.events-empty-state__copy p {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 16px;
    line-height: 1.7;
}

.events-list-disclosure {
    border: 1px solid var(--color-surface-border);
    border-radius: 22px;
    background: var(--color-bg-surface);
    box-shadow: var(--shadow-card);
    overflow: hidden;
}

.events-list-disclosure__summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 18px 22px;
    cursor: pointer;
    list-style: none;
    font-size: 17px;
    font-weight: 700;
}

.events-list-disclosure__summary::-webkit-details-marker {
    display: none;
}

.events-list-disclosure__meta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 30px;
    height: 30px;
    padding: 0 10px;
    border-radius: 999px;
    background: rgba(47, 63, 93, 0.12);
    color: var(--color-link);
    font-size: 14px;
    font-weight: 700;
}

.events-list-compact {
    display: grid;
    gap: 10px;
    padding: 0 16px 16px;
}

.events-list-compact__item {
    display: grid;
    grid-template-columns: auto auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.62);
    border: 1px solid rgba(79, 96, 129, 0.14);
}

.events-list-compact__date,
.events-list-compact__timer {
    color: var(--color-link);
    font-size: 14px;
    font-weight: 700;
    white-space: nowrap;
}

.events-list-compact__icon {
    font-size: 18px;
    line-height: 1;
}

.events-list-compact__main {
    display: grid;
    gap: 4px;
    min-width: 0;
}

.events-list-compact__main strong {
    font-size: 16px;
    line-height: 1.35;
}

.events-list-compact__main span {
    color: var(--color-text-muted);
    font-size: 14px;
    line-height: 1.45;
}

.public-holidays-hidden [data-event-layer="public-holidays"] {
    display: none !important;
}

@media (max-width: 1180px) {
    .events-overview {
        grid-template-columns: 1fr;
    }

    .events-summary-card {
        min-height: auto;
    }

    .events-layer-panel {
        flex-direction: column;
        align-items: stretch;
    }

    .events-layer-panel__actions {
        justify-content: flex-start;
    }

    .events-layer-panel__side {
        margin-left: 0;
        justify-content: flex-start;
    }
}

@media (max-width: 920px) {
    .events-hero-card,
    .events-upcoming-grid {
        grid-template-columns: 1fr;
    }

    .events-month-toolbar {
        align-items: flex-start;
        flex-direction: column;
    }

    .events-month-toolbar__nav {
        width: 100%;
        justify-content: center;
    }

    .events-month-toolbar__picker {
        width: 100%;
    }

    .events-month-toolbar__select {
        min-width: 0;
        width: 100%;
    }

    .events-upcoming-card {
        align-items: flex-start;
        flex-direction: column;
    }

    .events-upcoming-card__timer {
        width: auto;
    }
}

@media (max-width: 720px) {
    .events-spotlight-card,
    .events-empty-state {
        grid-template-columns: 1fr;
    }

    .events-list-compact__item {
        grid-template-columns: auto minmax(0, 1fr);
    }

    .events-list-compact__timer {
        justify-self: start;
    }

    .events-calendar {
        padding: 12px;
    }

    .events-calendar-day {
        min-height: 100px;
    }
}

.profile-page-alert {
    align-items: center;
}

.profile-hero-card,
.profile-link-card,
.profile-summary-card {
    border: 1px solid var(--color-surface-border);
    background: var(--color-bg-surface);
    box-shadow: var(--shadow-card);
}

.profile-hero-card {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(260px, 320px) minmax(260px, 320px);
    gap: 20px;
    padding: 24px;
    border-radius: var(--radius-xl);
}

.profile-hero-card__main {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 24px;
    align-items: stretch;
    min-height: 100%;
    padding: 20px;
    border-radius: 28px;
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.16), transparent 42%),
        linear-gradient(180deg, rgba(255, 253, 249, 0.98) 0%, rgba(242, 247, 253, 0.94) 100%);
    border: 1px solid rgba(79, 96, 129, 0.18);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

.profile-hero-card__avatar-wrap {
    display: flex;
    justify-content: center;
    align-items: center;
    align-self: stretch;
    height: 100%;
}

.profile-hero-card__avatar {
    width: auto;
    height: 100%;
    max-width: 100%;
    border-radius: 28px;
    object-fit: cover;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(79, 96, 129, 0.18);
}

.profile-hero-card__avatar--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: auto;
    height: 100%;
    max-width: 100%;
    border-radius: 28px;
    overflow: hidden;
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.24), transparent 48%),
        linear-gradient(180deg, rgba(255, 251, 245, 0.98) 0%, rgba(233, 241, 252, 0.96) 100%);
    color: var(--color-link);
    font-size: 224px;
    font-weight: 700;
}

.profile-hero-card__avatar--placeholder::before,
.profile-friends-modal-card__avatar--placeholder::before,
.profile-friend-card__avatar--placeholder::before,
.profile-edit-avatar-trigger__image--placeholder::before {
    content: "";
    display: block;
    width: 68%;
    height: 68%;
    background: rgba(47, 63, 93, 0.92);
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath fill='black' d='M32 32c8.837 0 16-7.163 16-16S40.837 0 32 0 16 7.163 16 16s7.163 16 16 16Zm0 6C18.745 38 8 48.745 8 62c0 1.105.895 2 2 2h44c1.105 0 2-.895 2-2 0-13.255-10.745-24-24-24Z'/%3E%3C/svg%3E");
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: contain;
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath fill='black' d='M32 32c8.837 0 16-7.163 16-16S40.837 0 32 0 16 7.163 16 16s7.163 16 16 16Zm0 6C18.745 38 8 48.745 8 62c0 1.105.895 2 2 2h44c1.105 0 2-.895 2-2 0-13.255-10.745-24-24-24Z'/%3E%3C/svg%3E");
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    -webkit-mask-size: contain;
}

.profile-hero-card__avatar-fallback {
    display: none;
}

.profile-hero-card__content {
    display: grid;
    gap: 16px;
    min-width: 0;
    align-content: center;
}

.profile-hero-card__identity {
    display: grid;
    gap: 10px;
}

.profile-hero-card__eyebrow {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(47, 63, 93, 0.1);
    color: var(--color-link);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.profile-hero-card__title {
    margin: 0;
    font-size: clamp(30px, 3.5vw, 48px);
    line-height: 1;
}

.profile-hero-card__handle {
    margin: 0;
    color: var(--color-text-main);
    font-size: 17px;
    font-weight: 700;
}

.profile-hero-card__login-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
}

.profile-hero-card__login-label {
    color: var(--color-text-muted);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.profile-hero-card__bio-box {
    padding: 16px 18px;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.58);
    border: 1px solid rgba(79, 96, 129, 0.14);
}

.profile-hero-card__bio {
    margin: 0;
    color: var(--color-text-main);
    font-size: 17px;
    line-height: 1.65;
}

.profile-hero-card__bio--muted,
.profile-summary-card p,
.profile-link-card p {
    color: var(--color-text-muted);
}

.profile-hero-card__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 8px;
}

.profile-hero-card__logout {
    border-color: rgba(173, 71, 61, 0.22);
    color: #9e3428;
    background: linear-gradient(180deg, rgba(255, 247, 244, 0.96) 0%, rgba(255, 236, 231, 0.96) 100%);
}

.profile-summary-card {
    display: grid;
    gap: 10px;
    align-content: start;
    padding: 20px;
    border-radius: 24px;
    min-height: 100%;
    background:
        radial-gradient(circle at top right, rgba(65, 100, 154, 0.14), transparent 40%),
        linear-gradient(180deg, rgba(255, 253, 249, 0.98) 0%, rgba(241, 246, 253, 0.98) 100%);
}

.profile-summary-card--stats {
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.18), transparent 42%),
        linear-gradient(180deg, rgba(255, 252, 247, 0.98) 0%, rgba(242, 247, 253, 0.98) 100%);
}

.profile-public-link {
    display: grid;
    gap: 6px;
    min-width: 0;
    padding: 14px 15px;
    border-radius: 18px;
    border: 1px solid rgba(79, 96, 129, 0.2);
    background: rgba(255, 255, 255, 0.62);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.profile-public-link__label {
    color: var(--color-text-muted);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.profile-public-link__value {
    display: block;
    min-width: 0;
    overflow: hidden;
    color: var(--color-link);
    font-size: 15px;
    font-weight: 700;
    line-height: 1.4;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.profile-summary-card__button {
    width: 100%;
    margin-top: 8px;
}

.profile-summary-card__divider {
    height: 1px;
    margin-top: 10px;
    background: linear-gradient(90deg, rgba(79, 96, 129, 0), rgba(79, 96, 129, 0.24), rgba(79, 96, 129, 0));
}

.profile-summary-card__button--icon {
    gap: 10px;
}

.profile-summary-card__button--icon img {
    width: 18px;
    height: 18px;
    object-fit: contain;
}

.profile-summary-card__label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-height: 32px;
    padding: 0 12px;
    border-radius: 999px;
    background: var(--color-chip-soft);
    color: var(--color-link);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.profile-summary-card strong,
.profile-link-card strong {
    font-size: 20px;
    line-height: 1.25;
}

.profile-summary-card p,
.profile-link-card p {
    margin: 0;
    font-size: 15px;
    line-height: 1.6;
}

.profile-summary-stats,
.profile-link-grid {
    display: grid;
    gap: 16px;
}

.profile-summary-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.profile-summary-stat {
    display: grid;
    gap: 8px;
    align-content: center;
    justify-items: center;
    min-height: 112px;
    padding: 18px 16px;
    border-radius: 20px;
    border: 1px solid rgba(79, 96, 129, 0.2);
    background: rgba(255, 255, 255, 0.52);
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.profile-summary-stat strong {
    font-size: clamp(28px, 3vw, 38px);
    line-height: 1;
}

.profile-summary-stat__label {
    display: inline-block;
    max-width: none;
    margin: 0;
    color: var(--color-text-muted);
    font-size: 15px;
    font-weight: 700;
    line-height: 1.25;
    text-align: center;
    white-space: nowrap;
}

.profile-summary-stat--alert {
    background: rgba(241, 246, 255, 0.78);
    border-color: rgba(219, 233, 255, 0.85);
}

.profile-summary-stat--alert strong {
    color: #ff3b30;
}

.profile-link-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.friend-events-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.profile-link-card {
    display: grid;
    gap: 10px;
    padding: 22px;
    border-radius: 24px;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.profile-link-card__cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 6px;
    color: var(--color-link);
    font-size: 14px;
    font-weight: 700;
}

.profile-link-card__cta::after {
    content: "›";
    font-size: 18px;
    line-height: 1;
}

.feedback-overview {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
    gap: 18px;
}

.feedback-intro-card,
.feedback-form-card {
    gap: 16px;
}

.feedback-note-list {
    display: grid;
    gap: 12px;
    margin-top: 6px;
}

.feedback-note {
    padding: 14px 16px;
    border-radius: 18px;
    border: 1px solid rgba(79, 96, 129, 0.18);
    background: rgba(255, 255, 255, 0.56);
    color: var(--color-text-main);
    font-size: 14px;
    line-height: 1.6;
}

.feedback-link-grid {
    align-content: stretch;
}

.feedback-link-grid .profile-link-card {
    min-height: 100%;
}

.feedback-divider {
    display: flex;
    align-items: center;
    gap: 16px;
    color: var(--color-text-muted);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.08em;
    justify-content: center;
    text-transform: uppercase;
}

.feedback-divider::before,
.feedback-divider::after {
    content: "";
    flex: 1 1 auto;
    max-width: 180px;
    height: 1px;
    background: linear-gradient(90deg, rgba(79, 96, 129, 0), rgba(79, 96, 129, 0.22), rgba(79, 96, 129, 0));
}

.feedback-divider span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    border: 1px solid rgba(79, 96, 129, 0.16);
    background: rgba(255, 255, 255, 0.68);
}

.feedback-form-grid {
    grid-template-columns: minmax(0, 1fr);
}

.feedback-form-actions {
    padding-top: 0;
}

.profile-section-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--color-link);
    font-size: 14px;
    font-weight: 700;
}

.profile-section-link::after {
    content: "›";
    font-size: 18px;
    line-height: 1;
}

.friend-profile-modal-link {
    padding: 0;
    border: 0;
    background: transparent;
    cursor: pointer;
}

.profile-edit-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(280px, 340px);
    gap: 24px;
    align-items: start;
}

.profile-edit-form-card {
    display: grid;
    gap: 22px;
    min-width: 0;
    padding: 32px;
    border-radius: 28px;
    border: 1px solid var(--color-surface-border);
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.14), transparent 38%),
        linear-gradient(180deg, rgba(255, 253, 249, 0.98) 0%, rgba(241, 246, 253, 0.98) 100%);
    box-shadow: var(--shadow-card);
}

.profile-edit-sidebar {
    display: grid;
    gap: 16px;
    position: sticky;
    top: 24px;
}

.profile-edit-card__intro {
    display: grid;
    gap: 12px;
}

.profile-edit-card__intro p {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 16px;
    line-height: 1.7;
}

.profile-form-notice {
    padding: 16px 18px;
    border-radius: 18px;
    font-size: 15px;
    font-weight: 700;
    line-height: 1.5;
}

.profile-form-notice--success {
    border: 1px solid rgba(47, 138, 70, 0.18);
    background: rgba(235, 249, 238, 0.9);
    color: #256a36;
}

.profile-form-notice--error {
    border: 1px solid rgba(199, 59, 74, 0.18);
    background: rgba(255, 241, 243, 0.94);
    color: #9e2e3a;
}

.profile-settings-form {
    display: grid;
    gap: 22px;
}

.profile-settings-form__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px 20px;
}

.profile-field {
    display: grid;
    gap: 9px;
    align-content: start;
    align-self: start;
}

.profile-field--full {
    grid-column: 1 / -1;
}

.profile-field--left-column {
    grid-column: 1;
}

.profile-field--right-column {
    grid-column: 2;
}

.profile-field--stack-2 {
    grid-row: span 2;
}

.profile-field label,
.profile-field__label {
    color: var(--color-text-main);
    font-size: 14px;
    font-weight: 700;
}

.profile-field input,
.profile-field textarea {
    width: 100%;
    min-height: 50px;
    padding: 14px 16px;
    border-radius: 16px;
    border: 1px solid var(--color-border-soft);
    background: var(--color-bg-surface-input);
    box-shadow: inset 0 1px 0 rgba(255, 248, 240, 0.36);
    color: var(--color-text-main);
    font-size: 15px;
}

.profile-field input[readonly] {
    cursor: default;
    color: var(--color-text-main);
    -webkit-text-fill-color: var(--color-text-main);
}

.profile-field textarea {
    min-height: 168px;
    resize: vertical;
}

.profile-field input:focus,
.profile-field textarea:focus,
.profile-checkbox:focus-within,
.profile-edit-avatar-trigger:focus-visible {
    outline: none;
    border-color: rgba(61, 93, 165, 0.55);
    box-shadow: 0 0 0 3px rgba(51, 75, 136, 0.14);
}

.profile-field--static {
    padding: 16px 18px;
    border-radius: 18px;
    border: 1px solid rgba(79, 96, 129, 0.18);
    background: rgba(255, 255, 255, 0.56);
}

.profile-field__value {
    color: var(--color-link);
    font-size: 16px;
    font-weight: 700;
    line-height: 1.5;
}

.profile-side-note,
.profile-slug-preview,
.profile-bio-counter {
    color: var(--color-text-muted);
    font-size: 13px;
    line-height: 1.5;
}

.profile-bio-counter {
    margin-top: -2px;
}

.profile-side-note {
    display: grid;
    gap: 6px;
    padding: 14px 16px;
    border-radius: 16px;
    border: 1px solid rgba(79, 96, 129, 0.16);
    background: rgba(255, 255, 255, 0.54);
}

.profile-side-note strong {
    color: var(--color-link);
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.profile-slug-preview {
    padding: 12px 14px;
    border-radius: 16px;
    border: 1px dashed rgba(79, 96, 129, 0.3);
    background: rgba(255, 255, 255, 0.5);
}

.profile-slug-preview strong {
    color: var(--color-link);
}

.profile-bio-counter {
    justify-self: end;
    font-weight: 700;
}

.profile-settings-form__actions {
    padding-top: 4px;
}

.profile-settings-form__actions .hero-cta {
    min-width: 240px;
}

.profile-edit-avatar-card {
    gap: 18px;
}

.profile-page .profile-avatar-picker {
    position: relative;
}

.profile-page .is-hidden {
    display: none !important;
}

.profile-edit-avatar-trigger {
    display: grid;
    gap: 14px;
    justify-items: center;
    padding: 18px;
    border-radius: 22px;
    border: 1px dashed rgba(79, 96, 129, 0.32);
    background: rgba(255, 255, 255, 0.5);
    cursor: pointer;
}

.profile-edit-avatar-trigger__image {
    width: 152px;
    height: 152px;
    border-radius: 28px;
    object-fit: cover;
    border: 1px solid rgba(79, 96, 129, 0.18);
    background: rgba(255, 255, 255, 0.72);
}

.profile-edit-avatar-trigger__image--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.24), transparent 48%),
        linear-gradient(180deg, rgba(255, 251, 245, 0.98) 0%, rgba(233, 241, 252, 0.96) 100%);
}

.profile-edit-avatar-trigger__fallback {
    display: none;
}

.profile-edit-avatar-trigger__text {
    color: var(--color-link);
    font-size: 14px;
    font-weight: 700;
    line-height: 1.5;
    text-align: center;
}

.profile-page .wishitem-image-crop-modal {
    position: fixed;
    inset: 0;
    z-index: 1400;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: rgba(20, 28, 44, 0.58);
    backdrop-filter: blur(8px);
}

.profile-page .wishitem-image-crop-modal.is-active {
    display: flex;
}

.profile-page .wishitem-image-crop-card {
    width: min(780px, 100%);
    max-height: calc(100vh - 48px);
    display: grid;
    grid-template-rows: auto minmax(0, 1fr) auto;
    gap: 18px;
    padding: 22px;
    overflow: hidden;
    border-radius: 28px;
    border: 1px solid rgba(79, 96, 129, 0.22);
    background:
        radial-gradient(circle at top right, rgba(198, 132, 55, 0.14), transparent 28%),
        linear-gradient(180deg, rgba(255, 252, 247, 0.99) 0%, rgba(241, 246, 253, 0.99) 100%);
    box-shadow: 0 28px 90px rgba(10, 18, 32, 0.28);
}

.profile-page .wishitem-image-crop-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}

.profile-page .wishitem-image-crop-title {
    font-size: 24px;
    font-weight: 700;
    line-height: 1.15;
}

.profile-page .wishitem-image-crop-text {
    margin-top: 6px;
    color: var(--color-text-muted);
    font-size: 14px;
    line-height: 1.6;
}

.profile-page .wishitem-image-crop-close {
    width: 44px;
    height: 44px;
    border: 1px solid rgba(79, 96, 129, 0.16);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.72);
    color: var(--color-link);
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
}

.profile-page .wishitem-image-crop-stage {
    min-height: 0;
    max-height: min(56vh, 520px);
    border-radius: 24px;
    overflow: hidden;
    background: linear-gradient(180deg, rgba(255, 253, 249, 0.98) 0%, rgba(241, 246, 253, 0.98) 100%);
}

.profile-page .wishitem-image-crop-stage img {
    display: block;
    width: 100%;
    max-width: 100%;
}

.profile-page .wishitem-image-crop-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 4px;
    flex-wrap: wrap;
}

.profile-link-grid--single {
    grid-template-columns: 1fr;
}

.profile-link-card--button {
    width: 100%;
    border: 1px solid var(--color-surface-border);
    background: var(--color-bg-surface);
    box-shadow: var(--shadow-card);
    text-align: left;
    cursor: pointer;
    font: inherit;
}

.profile-checkbox {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    width: fit-content;
    color: var(--color-text-muted);
    font-size: 14px;
    line-height: 1.5;
    cursor: pointer;
}

.profile-checkbox input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: var(--color-text-main);
}

.profile-avatar-crop-card {
    border: 1px solid var(--color-surface-border);
    border-radius: 28px;
    background: var(--color-bg-surface);
    box-shadow: var(--shadow-card);
    padding: 24px;
}

.profile-avatar-crop-stage {
    min-height: min(70vh, 720px);
    border-radius: 22px;
    overflow: hidden;
    background:
        linear-gradient(180deg, rgba(255, 253, 249, 0.98) 0%, rgba(241, 246, 253, 0.98) 100%);
}

.profile-avatar-crop-stage__image {
    display: block;
    width: 100%;
    max-width: 100%;
}

.notification-settings-layout {
    align-items: start;
}

.notification-settings-card,
.notification-summary-card {
    content-visibility: auto;
    contain-intrinsic-size: 320px;
}

.notification-settings-stage__lead {
    max-width: 760px;
    margin: 14px 0 0;
    color: var(--color-text-muted);
    font-size: 17px;
    line-height: 1.7;
}

.notification-settings-form {
    gap: 24px;
}

.notification-settings-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 18px 20px;
    border-radius: 22px;
    border: 1px solid rgba(79, 96, 129, 0.16);
    background: rgba(255, 255, 255, 0.54);
}

.notification-settings-counter {
    color: var(--color-link);
    font-size: 15px;
    font-weight: 700;
    line-height: 1.5;
}

.notification-settings-counter strong {
    font-size: 18px;
}

.notification-settings-toolbar__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-end;
}

.notification-settings-toolbar__button {
    min-height: 44px;
}

.notification-settings-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.notification-setting-card {
    display: grid;
    gap: 24px;
    min-width: 0;
    padding: 24px;
    border-radius: 24px;
    border: 1px solid rgba(79, 96, 129, 0.16);
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.12), transparent 34%),
        linear-gradient(180deg, rgba(255, 253, 249, 0.9) 0%, rgba(241, 246, 253, 0.88) 100%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.52);
}

.notification-setting-card__head {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 16px;
    align-items: start;
}

.notification-setting-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    border-radius: 18px;
    border: 1px solid rgba(79, 96, 129, 0.14);
    background: rgba(255, 255, 255, 0.7);
    color: var(--color-link);
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.notification-setting-card__copy {
    min-width: 0;
}

.notification-setting-card__copy h2 {
    margin: 0;
    color: var(--color-text-main);
    font-size: 22px;
    line-height: 1.2;
}

.notification-setting-card__copy p {
    margin: 10px 0 0;
    color: var(--color-text-muted);
    font-size: 15px;
    line-height: 1.65;
}

.notification-setting-card__options {
    display: grid;
    gap: 12px;
}

.notification-channel-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    min-height: 72px;
    padding: 16px 18px;
    border-radius: 18px;
    border: 1px solid rgba(79, 96, 129, 0.14);
    background: rgba(255, 255, 255, 0.64);
    cursor: pointer;
}

.notification-channel-toggle__label {
    color: var(--color-text-main);
    font-size: 15px;
    font-weight: 700;
    line-height: 1.4;
}

.notification-switch {
    position: relative;
    display: inline-flex;
    align-items: center;
}

.notification-switch input {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.notification-switch__ui {
    position: relative;
    display: inline-flex;
    width: 58px;
    height: 32px;
    border-radius: 999px;
    background: rgba(79, 96, 129, 0.22);
    box-shadow: inset 0 1px 2px rgba(21, 30, 44, 0.1);
    transition: background-color 0.2s ease, box-shadow 0.2s ease;
}

.notification-switch__ui::after {
    content: "";
    position: absolute;
    top: 4px;
    left: 4px;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 4px 10px rgba(21, 30, 44, 0.16);
    transition: transform 0.2s ease;
}

.notification-switch input:checked + .notification-switch__ui {
    background: linear-gradient(135deg, #435d88 0%, #32486d 100%);
    box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.22), 0 6px 16px rgba(45, 67, 106, 0.16);
}

.notification-switch input:checked + .notification-switch__ui::after {
    transform: translateX(26px);
}

.notification-switch input:focus-visible + .notification-switch__ui {
    outline: none;
    box-shadow: 0 0 0 4px rgba(51, 75, 136, 0.14);
}

.notification-settings-sidebar {
    gap: 16px;
}

.avatar-crop-page .avatar-crop-overlay,
.profile-page .avatar-crop-overlay {
    position: fixed;
    inset: 0;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
    background: rgba(22, 32, 47, 0.42);
    backdrop-filter: blur(6px);
    z-index: 1500;
}

.avatar-crop-page .avatar-crop-overlay.is-active,
.profile-page .avatar-crop-overlay.is-active {
    display: flex;
}

.avatar-crop-page .avatar-crop-overlay-card,
.profile-page .avatar-crop-overlay-card {
    width: min(360px, 100%);
    padding: 20px;
    border-radius: 20px;
    border: 1px solid rgba(79, 96, 129, 0.24);
    background: linear-gradient(180deg, rgba(255, 251, 246, 0.99) 0%, rgba(239, 243, 250, 0.99) 100%);
    box-shadow: 0 24px 50px rgba(20, 28, 43, 0.24);
}

.avatar-crop-page .avatar-crop-overlay-title,
.profile-page .avatar-crop-overlay-title {
    font-size: 16px;
    font-weight: 700;
}

.avatar-crop-page .avatar-crop-progress-track,
.profile-page .avatar-crop-progress-track {
    height: 10px;
    margin-top: 14px;
    overflow: hidden;
    border-radius: 999px;
    background: rgba(47, 63, 93, 0.12);
}

.avatar-crop-page .avatar-crop-progress-bar,
.profile-page .avatar-crop-progress-bar {
    width: 0;
    height: 100%;
    border-radius: inherit;
    background: var(--color-action-primary-gradient);
}

.profile-settings-modal {
    width: min(720px, 100%);
}

.profile-settings-modal__section {
    display: grid;
    gap: 18px;
    padding: 18px;
    border: 1px solid rgba(79, 96, 129, 0.14);
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.68);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.profile-settings-modal__intro {
    display: grid;
    gap: 8px;
}

.profile-settings-modal__intro strong {
    font-size: 20px;
    line-height: 1.25;
}

.profile-settings-modal__intro p {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 14px;
    line-height: 1.6;
}

.profile-settings-form--modal .profile-settings-form__actions .hero-cta {
    width: 100%;
}

.profile-modal-open {
    overflow: hidden;
}

.profile-modal {
    position: fixed;
    inset: 0;
    z-index: 1200;
    display: grid;
    place-items: center;
    padding: 24px;
}

.profile-modal[hidden] {
    display: none !important;
}

.profile-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(20, 28, 44, 0.56);
    backdrop-filter: blur(8px);
}

.profile-modal__dialog {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    gap: 18px;
    width: min(980px, 100%);
    max-height: calc(100vh - 48px);
    padding: 24px;
    overflow: hidden;
    border: 1px solid rgba(79, 96, 129, 0.18);
    border-radius: 28px;
    background:
        radial-gradient(circle at top right, rgba(198, 132, 55, 0.12), transparent 26%),
        linear-gradient(180deg, rgba(255, 252, 247, 0.99) 0%, rgba(241, 246, 253, 0.99) 100%);
    box-shadow: 0 28px 90px rgba(10, 18, 32, 0.28);
}

.profile-modal__dialog--compact {
    width: min(760px, 100%);
}

.profile-modal__header,
.profile-friends-modal-card,
.profile-friends-search-result {
    display: grid;
}

.profile-modal__header {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 16px;
    align-items: start;
    padding-bottom: 2px;
    border-bottom: 1px solid rgba(79, 96, 129, 0.1);
}

.profile-modal__heading {
    display: grid;
    gap: 8px;
}

.profile-modal__heading h2 {
    margin: 0;
    font-size: clamp(30px, 3vw, 42px);
    line-height: 1.05;
}

.profile-modal__heading p {
    margin: 0;
    color: var(--color-text-muted);
}

.profile-modal__close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border: 1px solid rgba(79, 96, 129, 0.16);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.72);
    color: var(--color-link);
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
}

.profile-modal__content {
    display: grid;
    gap: 16px;
    min-height: 0;
    padding-right: 4px;
    overflow-y: auto;
    overscroll-behavior: contain;
}

.profile-friends-search,
.profile-friends-modal-section,
.profile-friends-blocked-link,
.profile-notifications-section {
    border: 1px solid rgba(79, 96, 129, 0.14);
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.68);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.profile-friends-search,
.profile-friends-modal-section,
.profile-notifications-section {
    padding: 18px;
}

.profile-notifications-section {
    display: grid;
    gap: 16px;
}

.profile-notifications-section__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.profile-notifications-mark-all {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 16px;
    border: 1px solid rgba(79, 96, 129, 0.16);
    border-radius: 999px;
    background: rgba(247, 250, 255, 0.92);
    color: var(--color-link);
    font: inherit;
    font-weight: 700;
    cursor: pointer;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.profile-notifications-mark-all:hover,
.profile-notifications-mark-all:focus-visible {
    transform: translateY(-1px);
    border-color: rgba(79, 96, 129, 0.28);
    box-shadow: 0 14px 28px rgba(20, 28, 43, 0.1);
}

.profile-notifications-list {
    display: grid;
    gap: 12px;
}

.profile-notifications-empty {
    padding: 28px 20px;
    border: 1px dashed rgba(79, 96, 129, 0.18);
    border-radius: 20px;
    background: rgba(247, 250, 255, 0.65);
    color: var(--color-text-muted);
    text-align: center;
}

.profile-notification-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 14px;
    align-items: start;
    width: 100%;
    padding: 16px 18px;
    border: 1px solid rgba(79, 96, 129, 0.14);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.86);
    color: inherit;
    text-align: left;
    cursor: pointer;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, opacity 0.2s ease;
}

.profile-notification-card:hover,
.profile-notification-card:focus-visible {
    transform: translateY(-1px);
    border-color: rgba(79, 96, 129, 0.24);
    box-shadow: 0 16px 32px rgba(20, 28, 43, 0.08);
}

.profile-notification-card--leaving {
    opacity: 0;
    transform: translateX(24px);
    pointer-events: none;
}

.profile-notification-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: 14px;
    background: rgba(241, 246, 255, 0.92);
    font-size: 22px;
}

.profile-notification-card__content {
    display: grid;
    gap: 6px;
    min-width: 0;
}

.profile-notification-card__title {
    font-weight: 800;
    line-height: 1.3;
}

.profile-notification-card__message {
    color: var(--color-text-muted);
    line-height: 1.5;
}

.profile-notification-card__time {
    color: var(--color-text-muted);
    font-size: 13px;
}

.profile-notification-card__dot {
    width: 10px;
    height: 10px;
    margin-top: 6px;
    border-radius: 999px;
    background: #ff3b30;
    box-shadow: 0 0 0 4px rgba(255, 59, 48, 0.14);
}

.friend-profile-hero-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.friend-profile-status-pill {
    display: inline-flex;
    align-items: center;
    min-height: 36px;
    padding: 0 14px;
    border-radius: 999px;
    background: rgba(241, 246, 255, 0.86);
    color: var(--color-link);
    font-size: 14px;
    font-weight: 700;
}

.friend-profile-status-pill--success {
    background: rgba(228, 248, 235, 0.88);
    color: #17663f;
}

.friend-profile-status-pill--accent {
    background: rgba(255, 243, 220, 0.92);
    color: #8f5a11;
}

.friend-action-panel {
    min-width: 0;
}

.friend-action-panel--hero {
    grid-column: 2 / 4;
    align-self: stretch;
    display: grid;
    grid-template-rows: auto 1fr;
    align-content: start;
    gap: 14px;
    height: 100%;
    min-height: 100%;
    padding: 20px;
    border: 1px solid var(--color-surface-border);
    border-radius: 24px;
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.12), transparent 42%),
        linear-gradient(180deg, rgba(255, 253, 249, 0.98) 0%, rgba(241, 246, 253, 0.98) 100%);
    box-shadow: var(--shadow-card);
}

.friend-action-panel__label {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(47, 63, 93, 0.1);
    color: var(--color-link);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.friend-action-panel__controls {
    display: grid;
    gap: 10px;
    min-width: 0;
    align-content: center;
    justify-items: center;
    height: 100%;
}

.friend-action-panel__primary,
.friend-action-panel__secondary {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
    width: 100%;
}

.friend-action-panel__primary {
    align-items: stretch;
}

.friend-action-panel__secondary {
    padding-top: 10px;
    border-top: 1px solid rgba(79, 96, 129, 0.12);
}

.friend-action-panel__share {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
    padding-top: 10px;
    border-top: 1px solid rgba(79, 96, 129, 0.12);
}

.friend-action-panel__primary .hero-cta,
.friend-action-panel__secondary .hero-cta,
.friend-action-panel__share .hero-cta {
    flex: 1 1 180px;
    justify-content: center;
    min-height: 46px;
}

.friend-action-panel__share-button {
    max-width: 100%;
}

.friend-action-panel__share-icon {
    width: 18px;
    height: 18px;
    flex: 0 0 18px;
    object-fit: contain;
    margin-right: 8px;
}

.friend-action-panel__danger {
    color: #9f2f28;
    border-color: rgba(159, 47, 40, 0.16);
    background: linear-gradient(180deg, rgba(255, 247, 244, 0.96) 0%, rgba(255, 237, 234, 0.96) 100%);
}

.friend-action-panel__report {
    color: #5f687a;
    border-color: rgba(95, 104, 122, 0.16);
    background: linear-gradient(180deg, rgba(248, 250, 253, 0.96) 0%, rgba(240, 244, 249, 0.96) 100%);
}

@media (max-width: 980px) {
    .friend-action-panel--hero {
        grid-column: 1;
    }

    .friend-events-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .friend-events-grid {
        grid-template-columns: minmax(0, 1fr);
    }
}

.profile-friends-search {
    display: grid;
    gap: 14px;
}

.profile-friends-search__copy {
    display: grid;
    gap: 6px;
}

.profile-friends-search__copy strong,
.profile-friends-modal-section__title {
    color: var(--color-text-main);
    font-size: 20px;
    line-height: 1.25;
}

.profile-friends-search__copy p,
.profile-friends-search-note,
.profile-friends-modal-empty {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 14px;
    line-height: 1.6;
}

.profile-friends-search-note {
    padding: 12px 14px;
    border-radius: 16px;
    background: rgba(47, 63, 93, 0.06);
}

.profile-friends-search-note--warning {
    color: #8f2f24;
    background: rgba(201, 90, 64, 0.1);
    border: 1px solid rgba(201, 90, 64, 0.18);
}

.profile-friends-search__input {
    min-height: 52px;
    padding: 0 16px;
    border: 1px solid rgba(79, 96, 129, 0.18);
    border-radius: 16px;
    background: #fff;
    color: var(--color-text-main);
    font-size: 16px;
}

.profile-friends-search-results,
.profile-friends-modal-list {
    display: grid;
    gap: 12px;
}

.friend-profile-friends-modal-list {
    max-height: min(60vh, 720px);
    padding-right: 6px;
    overflow-y: auto;
    overscroll-behavior: contain;
}

.profile-friends-search-empty,
.profile-friends-modal-empty {
    padding: 14px 16px;
    border-radius: 16px;
    background: rgba(47, 63, 93, 0.06);
}

.profile-friends-search-result {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
    padding: 12px 14px;
    border: 1px solid rgba(79, 96, 129, 0.14);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.76);
}

.profile-friends-search-result__main {
    display: grid;
    grid-template-columns: 48px minmax(0, 1fr);
    gap: 12px;
    align-items: center;
    padding: 0;
    background: transparent;
    border: 0;
    text-align: left;
}

.profile-friends-search-result__avatar,
.profile-friends-search-result__avatar img {
    width: 48px;
    height: 48px;
    border-radius: 16px;
}

.profile-friends-search-result__avatar img {
    object-fit: cover;
    border: 1px solid rgba(79, 96, 129, 0.14);
    background: rgba(255, 255, 255, 0.72);
}

.profile-friends-search-result__copy {
    display: grid;
    gap: 4px;
}

.profile-friends-search-result__copy strong {
    color: var(--color-text-main);
    font-size: 16px;
}

.profile-friends-search-result__copy span,
.profile-friends-search-result__badge {
    color: var(--color-text-muted);
    font-size: 13px;
}

.profile-friends-search-result__side {
    display: flex;
    align-items: center;
}

.profile-friends-search-result__button,
.profile-friends-modal-action {
    min-height: 40px;
    padding: 0 14px;
    border: 0;
    border-radius: 999px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
}

.profile-friends-search-result__button,
.profile-friends-modal-action--primary {
    background: var(--color-link);
    color: #fff;
}

.profile-friends-search-result__badge {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(47, 63, 93, 0.08);
}

.profile-friends-blocked-link {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 18px;
    color: var(--color-link);
    font-size: 14px;
    font-weight: 700;
}

.profile-friends-modal-section {
    display: grid;
    gap: 14px;
}

.profile-friends-modal-section summary {
    cursor: pointer;
    color: var(--color-text-main);
    font-size: 18px;
    font-weight: 700;
}

.profile-friends-modal-section--disclosure {
    gap: 0;
    padding: 0;
    overflow: hidden;
}

.profile-friends-modal-section__summary {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 18px;
    list-style: none;
    font-size: 15px;
    font-weight: 700;
    transition: background-color 0.18s ease, color 0.18s ease;
}

.profile-friends-modal-section__summary::-webkit-details-marker {
    display: none;
}

.profile-friends-modal-section__summary::after {
    content: "";
    width: 10px;
    height: 10px;
    margin-left: 10px;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(45deg) translateY(-1px);
    transform-origin: center;
    transition: transform 0.18s ease;
}

.profile-friends-modal-section--disclosure[open] .profile-friends-modal-section__summary::after {
    transform: rotate(225deg) translateY(-1px);
}

.profile-friends-modal-section__summary:hover,
.profile-friends-modal-section__summary:focus-visible {
    background: rgba(247, 250, 255, 0.82);
}

.profile-friends-modal-section__meta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 24px;
    height: 24px;
    padding: 0 7px;
    margin-left: auto;
    border-radius: 999px;
    background: rgba(47, 63, 93, 0.12);
    color: var(--color-link);
    font-size: 12px;
    font-weight: 700;
}

.profile-friends-modal-section--disclosure .profile-friends-modal-list {
    padding: 0 18px 18px;
    border-top: 1px solid rgba(79, 96, 129, 0.1);
}

.profile-friends-modal-card {
    grid-template-columns: 64px minmax(0, 1fr) auto;
    gap: 14px;
    align-items: center;
    padding: 14px;
    border: 1px solid rgba(79, 96, 129, 0.12);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.8);
}

.profile-friends-modal-card__avatar-wrap {
    display: flex;
    text-decoration: none;
}

.profile-friends-modal-card__avatar,
.profile-friends-modal-card__avatar--placeholder {
    width: 64px;
    height: 64px;
    border-radius: 20px;
}

.profile-friends-modal-card__avatar {
    object-fit: cover;
    border: 1px solid rgba(79, 96, 129, 0.14);
    background: rgba(255, 255, 255, 0.72);
}

.profile-friends-modal-card__avatar--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.24), transparent 50%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.95) 0%, rgba(236, 243, 252, 0.95) 100%);
    border: 1px solid rgba(79, 96, 129, 0.14);
}

.profile-friends-modal-card__avatar-fallback {
    display: none;
}

.profile-friends-modal-card__avatar--image-placeholder::before {
    display: none;
}

.profile-friends-modal-card__avatar--image-placeholder .profile-friends-modal-card__avatar-fallback {
    display: block;
    width: 68%;
    height: 68%;
    object-fit: contain;
}

.profile-friends-modal-card__body {
    display: grid;
    gap: 4px;
}

.profile-friends-modal-card__name {
    color: var(--color-text-main);
    font-size: 17px;
    font-weight: 700;
}

.profile-friends-modal-card__meta,
.profile-friends-modal-card__bio {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 14px;
    line-height: 1.55;
}

.profile-friends-modal-card__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 8px;
}

.profile-friends-modal-action--danger {
    color: #9e3428;
    background: rgba(255, 239, 234, 0.95);
    border: 1px solid rgba(173, 71, 61, 0.18);
}

.profile-link-card--danger .profile-link-card__cta,
.profile-link-card--danger strong {
    color: var(--color-danger);
}

.profile-summary-stat:hover,
.profile-link-card:hover {
    transform: translateY(-2px);
    border-color: rgba(47, 63, 93, 0.34);
    box-shadow: 0 16px 30px rgba(24, 34, 52, 0.12), 0 6px 12px rgba(24, 34, 52, 0.05);
}

.profile-wishlists-empty-card {
    grid-template-columns: minmax(0, 1fr);
    gap: 16px;
    padding: 22px;
    border: 1px solid rgba(79, 96, 129, 0.18);
    border-radius: 24px;
    justify-items: center;
    align-content: center;
    min-height: 220px;
    background:
        radial-gradient(circle at top right, rgba(198, 132, 55, 0.16), transparent 34%),
        linear-gradient(180deg, rgba(255, 252, 247, 0.98) 0%, rgba(241, 246, 253, 0.98) 100%);
    box-shadow: var(--shadow-card);
}

.profile-wishlists-empty-card--compact {
    min-height: 0;
    padding: 28px 24px;
}

.profile-wishlists-empty-card__badge {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(47, 63, 93, 0.08);
    color: var(--color-link);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.profile-wishlists-empty-card__intro {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
    justify-items: center;
    text-align: center;
}

.profile-wishlists-empty-card__copy {
    display: grid;
    gap: 8px;
    justify-items: center;
}

.profile-wishlists-empty-card__copy h3 {
    margin: 0;
    color: var(--color-text-main);
    font-size: 24px;
    line-height: 1.2;
}

.profile-wishlists-empty-card__copy p {
    margin: 0;
    max-width: 440px;
    color: var(--color-text-muted);
    font-size: 15px;
    line-height: 1.6;
    text-align: center;
}

.profile-friends-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 16px;
}

.profile-friend-card {
    display: grid;
    gap: 14px;
    position: relative;
    padding: 20px 18px;
    border: 1px solid var(--color-surface-border);
    border-radius: 24px;
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.12), transparent 38%),
        linear-gradient(180deg, rgba(255, 253, 249, 0.98) 0%, rgba(241, 246, 253, 0.98) 100%);
    box-shadow: var(--shadow-card);
    text-decoration: none;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.profile-friend-card:hover {
    transform: translateY(-2px);
    border-color: rgba(47, 63, 93, 0.34);
    box-shadow: 0 16px 30px rgba(24, 34, 52, 0.12), 0 6px 12px rgba(24, 34, 52, 0.05);
}

.profile-friend-card--cta {
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.18), transparent 40%),
        linear-gradient(180deg, rgba(255, 251, 245, 0.98) 0%, rgba(236, 244, 253, 0.98) 100%);
}

.profile-friend-card__alert-badge {
    position: absolute;
    top: 12px;
    right: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border-radius: 999px;
    background: #d93a3a;
    color: #fff;
    font-size: 16px;
    font-weight: 800;
    line-height: 1;
    box-shadow: 0 10px 18px rgba(217, 58, 58, 0.28);
}

.profile-friend-card__avatar-wrap {
    display: flex;
    justify-content: center;
}

.profile-friend-card__avatar {
    width: 78px;
    height: 78px;
    border-radius: 24px;
    object-fit: cover;
    border: 1px solid rgba(79, 96, 129, 0.16);
    background: rgba(255, 255, 255, 0.72);
}

.profile-friend-card__avatar--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 78px;
    height: 78px;
    border-radius: 24px;
    overflow: hidden;
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.24), transparent 50%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.95) 0%, rgba(236, 243, 252, 0.95) 100%);
    color: var(--color-link);
    font-size: 30px;
    font-weight: 700;
}

.profile-friend-card__avatar-fallback {
    display: none;
}

.profile-friend-card__avatar--image-placeholder::before {
    display: none;
}

.profile-friend-card__avatar--image-placeholder .profile-friend-card__avatar-fallback {
    display: block;
    width: 68%;
    height: 68%;
    object-fit: contain;
}

.profile-friend-card__avatar--cta {
    font-size: 34px;
}

.profile-friend-card__avatar--cta::before {
    display: none;
}

.profile-friend-card__avatar--cta .add-icon-image {
    width: 34px;
    height: 34px;
    display: block;
    object-fit: contain;
}

.profile-friend-card__body {
    display: grid;
    gap: 6px;
    justify-items: center;
    text-align: center;
}

.profile-friend-card__body strong {
    color: var(--color-text-main);
    font-size: 18px;
    line-height: 1.3;
}

.profile-friend-card__meta {
    color: var(--color-text-muted);
    font-size: 14px;
    line-height: 1.45;
}

.profile-wishlists-empty-card__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    border-radius: 20px;
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.24), transparent 50%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.95) 0%, rgba(236, 243, 252, 0.95) 100%);
    border: 1px solid rgba(79, 96, 129, 0.14);
    color: var(--color-link);
    font-size: 32px;
    font-weight: 600;
    line-height: 1;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

.profile-wishlists-empty-card__icon .add-icon-image {
    width: 32px;
    height: 32px;
    display: block;
    object-fit: contain;
}

.wishlists-empty-card__actions,
.wishlists-alert__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

.wishlists-alert--accent {
    position: relative;
    overflow: hidden;
    padding-left: 30px;
    border-color: rgba(197, 81, 61, 0.28);
    background:
        radial-gradient(circle at top left, rgba(214, 112, 67, 0.18), transparent 34%),
        linear-gradient(180deg, rgba(255, 250, 246, 0.98) 0%, rgba(255, 241, 236, 0.98) 100%);
    box-shadow: 0 14px 30px rgba(190, 93, 60, 0.12), 0 4px 12px rgba(24, 34, 52, 0.04);
}

.wishlists-alert--accent::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 6px;
    background: linear-gradient(180deg, #e06b42 0%, #c94637 100%);
}

.wishlists-alert--accent strong {
    color: #8f2f24;
}

.wishlists-alert--accent .header-link {
    background: rgba(201, 90, 64, 0.1);
    border: 1px solid rgba(201, 90, 64, 0.18);
}

.wishlists-empty-card__intro {
    display: grid;
    gap: 8px;
}

.wishlists-empty-card__primary,
.wishlists-empty-card__secondary {
    display: grid;
    align-content: start;
    gap: 16px;
}

.wishlists-empty-card__primary {
    min-height: 100%;
    padding: 24px;
    border: 1px solid rgba(208, 217, 233, 0.82);
    border-radius: 24px;
    justify-items: center;
    align-content: center;
    background:
        radial-gradient(120% 120% at 0% 0%, rgba(255, 188, 99, 0.08) 0%, rgba(255, 188, 99, 0) 55%),
        radial-gradient(110% 120% at 100% 0%, rgba(79, 110, 183, 0.08) 0%, rgba(79, 110, 183, 0) 60%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(247, 249, 253, 0.96) 100%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.78);
}

.wishlists-empty-card__secondary {
    padding: 18px;
    border: 1px solid rgba(208, 217, 233, 0.82);
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.82);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.wishlists-empty-card__tips-header {
    display: grid;
    gap: 6px;
}

.wishlists-empty-card__intro {
    max-width: 360px;
    text-align: center;
}

.wishlists-empty-card__tips-header strong {
    color: var(--color-text-main);
    font-size: 20px;
    line-height: 1.2;
}

.wishlists-empty-card__tips-header p {
    margin: 0;
}

.wishlists-empty-card__tips {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}

.wishlists-empty-tip {
    display: grid;
    gap: 10px;
    align-content: start;
    padding: 16px 18px;
    border: 1px solid rgba(208, 217, 233, 0.82);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.82);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.wishlists-empty-tip strong {
    color: var(--color-text-main);
    font-size: 18px;
    line-height: 1.35;
}

.wishlists-empty-tip__link {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 38px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1px solid rgba(208, 217, 233, 0.82);
    color: var(--color-link);
    font-size: 14px;
    font-weight: 700;
    text-decoration: none;
    background: rgba(255, 255, 255, 0.72);
    transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.wishlists-empty-tip__link:hover {
    transform: translateY(-1px);
    border-color: rgba(89, 105, 139, 0.45);
    background: rgba(255, 255, 255, 0.9);
}

.wishlists-empty-card__actions {
    justify-content: center;
}

.wishlists-empty-card__button {
    min-height: 52px;
    padding: 0 24px;
    border-radius: 16px;
    box-shadow: 0 14px 28px rgba(45, 67, 106, 0.16);
}

.wishlists-overview-panel {
    display: grid;
    gap: 6px;
    padding: 10px;
    border-radius: 22px;
    align-content: start;
    background: var(--color-bg-surface-soft);
}

.wishlists-overview-panel__header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 10px;
}

.wishlists-overview-panel__label {
    color: #697389;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.wishlists-overview-panel__hint {
    color: var(--color-text-muted);
    font-size: 12px;
    line-height: 1.4;
    text-align: right;
}

.wishlists-overview {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
    width: 100%;
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
}

.wishlists-stat-card {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 8px;
    border-radius: 14px;
    border: 1px solid var(--color-surface-border);
    background: var(--color-surface-raised-strong);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.4);
    min-width: 0;
    min-height: 80px;
}

.wishlists-stat-card span {
    display: block;
    margin-bottom: 6px;
    color: var(--color-text-muted);
    font-size: 12px;
    line-height: 1.3;
    text-align: center;
}

.wishlists-stat-card strong {
    display: block;
    color: var(--color-text-main);
    font-size: 24px;
    line-height: 1;
    letter-spacing: -0.02em;
    text-align: center;
}

.wishlists-stat-card--alert {
    border-color: rgba(199, 59, 74, 0.18);
    background: linear-gradient(180deg, rgba(199, 59, 74, 0.12) 0%, rgba(243, 235, 227, 0.92) 100%);
}

.wishlists-stat-card--alert span,
.wishlists-stat-card--alert strong {
    color: #a52e3b;
}

.wishlists-alert,
.wishlists-empty-card {
    padding: 14px 16px;
    border-radius: var(--radius-lg);
}

.wishlists-alert.wishlists-alert--accent {
    padding-left: 30px;
}

.wishlists-empty-card {
    display: grid;
    grid-template-columns: minmax(280px, 0.92fr) minmax(0, 1.4fr);
    align-items: start;
    gap: 18px;
}

.wishlists-alert {
    display: flex;
    justify-content: space-between;
    gap: 18px;
}

.wishlists-alert strong,
.wishlists-empty-card h3 {
    display: block;
    margin: 0 0 8px;
    color: var(--color-text-main);
    font-size: 24px;
    line-height: 1.2;
}

.wishlists-alert span {
    color: var(--color-link);
    font-weight: 700;
}

.wishlists-alert__button,
.wishlists-empty-card__button {
    width: auto;
}

.wishlists-section {
    display: grid;
    gap: 18px;
}

.wishlists-section__heading {
    display: flex;
    align-items: center;
    gap: 12px;
}

.wishlists-section__heading--between {
    justify-content: space-between;
}

.wishlists-section__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    padding: 0 12px;
    margin-left: 8px;
    border-radius: 999px;
    background: var(--color-chip-soft);
    color: var(--color-link);
    font-size: 15px;
    font-weight: 700;
    vertical-align: middle;
}

.wishlists-section__heading h1,
.wishlists-section__heading h2 {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0;
    margin: 8px 0 0;
    font-size: clamp(28px, 3.2vw, 38px);
    line-height: 1.05;
}

.desktop-wishlist-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.desktop-wishlist-card {
    display: grid;
    gap: 14px;
    padding: 20px;
    border-radius: 24px;
    height: 100%;
}

.desktop-wishlist-card__header,
.desktop-wishlist-card__body,
.desktop-wishlist-owner,
.desktop-wishlist-card__meta,
.desktop-wishlist-card__meta-row,
.desktop-wishlist-occasion {
    display: flex;
}

.desktop-wishlist-card__header {
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
}

.desktop-wishlist-card__body {
    flex: 1 1 auto;
}

.desktop-wishlist-card__main {
    display: flex;
    flex-direction: column;
    min-width: 0;
    flex: 1 1 auto;
    min-height: 100%;
}

.desktop-wishlist-owner {
    align-items: center;
    gap: 10px;
    min-width: 0;
}

.desktop-wishlist-owner__avatar,
.desktop-wishlist-owner__placeholder {
    width: 38px;
    height: 38px;
    border-radius: 30%;
    flex-shrink: 0;
}

.desktop-wishlist-owner__avatar {
    object-fit: cover;
}

.desktop-wishlist-owner__placeholder,
.desktop-wishlist-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--color-chip-soft);
    color: var(--color-link);
    border: 1px solid rgba(47, 63, 93, 0.12);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.04em;
}

.desktop-wishlist-owner__placeholder {
    font-size: 16px;
}

.desktop-wishlist-owner__name {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--color-text-main);
    font-size: 14px;
    font-weight: 700;
}

.desktop-wishlist-chip {
    min-height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    white-space: nowrap;
}

.desktop-wishlist-chip--muted {
    background: rgba(71, 84, 108, 0.14);
    color: #576375;
}

.desktop-wishlist-lock {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.desktop-wishlist-lock .wishlist-lock-icon {
    display: block;
}

.desktop-wishlist-card__title {
    margin: 0;
    font-size: 21px;
    line-height: 1.1;
}

.desktop-wishlist-card__title a {
    color: var(--color-text-main);
}

.desktop-wishlist-card__description--empty {
    visibility: hidden;
}

.desktop-wishlist-card__meta {
    flex-wrap: wrap;
    gap: 8px;
    color: var(--color-link);
    font-size: 13px;
    font-weight: 700;
}

.desktop-wishlist-card__meta-row {
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: auto;
}

.desktop-wishlist-card__meta span {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 11px;
    border-radius: 999px;
    background: var(--color-chip-soft);
    border: 1px solid rgba(47, 63, 93, 0.12);
}

.desktop-wishlist-card__link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--color-link);
    font-size: 13px;
    font-weight: 700;
    white-space: nowrap;
    flex-shrink: 0;
}

.desktop-wishlist-card__link::after {
    content: "\2192";
    font-size: 14px;
    line-height: 1;
}

.desktop-wishlist-card__link:hover {
    color: #243148;
}

.desktop-wishlist-occasion {
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 12px 14px;
    border-radius: 16px;
    background: var(--color-surface-raised);
    border: 1px solid rgba(79, 96, 129, 0.18);
    box-shadow: inset 0 1px 0 rgba(255, 248, 240, 0.5);
    margin-top: 2px;
}

.desktop-wishlist-occasion__copy {
    display: grid;
    gap: 4px;
    min-width: 0;
}

.desktop-wishlist-occasion__label {
    color: #697389;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.desktop-wishlist-occasion__copy strong {
    color: var(--color-text-main);
    font-size: 14px;
    line-height: 1.35;
}

.desktop-wishlist-occasion__copy span:last-child {
    color: var(--color-text-muted);
    font-size: 13px;
}

.desktop-wishlist-occasion__timer {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    padding: 0 12px;
    border-radius: 999px;
    background: #314767;
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    white-space: nowrap;
}

.desktop-activity-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.desktop-activity-card {
    display: block;
    min-width: 0;
}

.desktop-activity-card.hidden-card {
    display: none;
}

.desktop-activity-card__inner {
    display: grid;
    gap: 14px;
    height: 100%;
    padding: 20px;
    border-radius: 24px;
    background: var(--color-bg-surface);
    border: 1px solid var(--color-surface-border);
    box-shadow: var(--shadow-card);
}

.desktop-activity-card__head,
.desktop-activity-card__user,
.desktop-activity-card__body {
    display: flex;
}

.desktop-activity-card__head {
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.desktop-activity-card__user {
    align-items: center;
    gap: 10px;
    min-width: 0;
}

.desktop-activity-card__avatar,
.desktop-activity-card__avatar-placeholder {
    width: 38px;
    height: 38px;
    border-radius: 30%;
    flex-shrink: 0;
}

.desktop-activity-card__avatar {
    object-fit: cover;
}

.desktop-activity-card__avatar-placeholder,
.desktop-activity-card__time,
.desktop-activity-card__wishlist {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(47, 63, 93, 0.12);
    background: var(--color-chip-soft);
}

.desktop-activity-card__avatar-placeholder {
    overflow: hidden;
}

.desktop-activity-card__avatar-fallback {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.desktop-activity-card__user-name {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--color-text-main);
    font-size: 14px;
    font-weight: 700;
}

.desktop-activity-card__time {
    min-height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    color: var(--color-link);
    font-size: 12px;
    font-weight: 700;
    white-space: nowrap;
}

.desktop-activity-card__body {
    flex: 1 1 auto;
}

.desktop-activity-card__copy {
    display: grid;
    gap: 6px;
    min-width: 0;
    width: 100%;
    align-content: start;
}

.desktop-activity-card__summary {
    color: var(--color-text-muted);
    font-size: 14px;
    line-height: 1.4;
    font-weight: 600;
}

.desktop-activity-card__subject {
    color: var(--color-text-main);
    font-size: 21px;
    line-height: 1.15;
    font-weight: 700;
    word-break: break-word;
}

.desktop-activity-card__details {
    color: var(--color-text-muted);
    font-size: 13px;
    line-height: 1.45;
}

.desktop-activity-card__meta-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: 2px;
}

.desktop-activity-card__wishlist {
    width: fit-content;
    max-width: 100%;
    min-height: 30px;
    padding: 0 11px;
    border-radius: 999px;
    color: var(--color-link);
    font-size: 13px;
    font-weight: 700;
}

.desktop-activity-card__link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--color-link);
    font-size: 13px;
    font-weight: 700;
    white-space: nowrap;
    flex-shrink: 0;
}

.desktop-activity-card__link::after {
    content: "\2192";
    font-size: 14px;
    line-height: 1;
}

.desktop-activity-more-card {
    display: grid;
    align-content: center;
    justify-items: start;
    gap: 6px;
    min-height: 100%;
    padding: 20px;
    border-radius: 24px;
    border: 1px dashed rgba(47, 63, 93, 0.22);
    background:
        linear-gradient(180deg, rgba(255, 252, 247, 0.98) 0%, rgba(241, 246, 253, 0.98) 100%);
    box-shadow: var(--shadow-card);
    color: var(--color-text-main);
    cursor: pointer;
    text-align: left;
    font: inherit;
}

.desktop-activity-more-card:hover {
    border-color: rgba(47, 63, 93, 0.34);
}

.desktop-activity-more-card__label {
    color: var(--color-link);
    font-size: 20px;
    font-weight: 700;
    line-height: 1.15;
}

.desktop-activity-more-card__meta {
    color: var(--color-text-muted);
    font-size: 14px;
    line-height: 1.45;
}

@media (min-width: 1360px) {
    .desktop-wishlist-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 1100px) {
    .wishlists-top-row,
    .desktop-wishlist-grid,
    .desktop-activity-grid {
        grid-template-columns: 1fr;
    }

    .site-header--app,
    .app-header-actions,
    .desktop-wishlist-card__body {
        flex-direction: column;
        align-items: flex-start;
    }

    .wishlists-overview {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

}

@media (max-width: 1440px) {
    .desktop-activity-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 1240px) {
    .desktop-activity-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 860px) {
    .events-my-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .event-access-grid,
    .event-friends-grid {
        grid-template-columns: 1fr;
    }

    .wishlists-alert,
    .wishlists-section__heading,
    .desktop-wishlist-card__meta-row {
        flex-direction: column;
        align-items: flex-start;
    }

    .wishlists-overview {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .wishlists-overview-panel__header {
        flex-direction: column;
        align-items: flex-start;
    }

    .wishlists-overview-panel__hint {
        text-align: left;
    }

    .profile-friends-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .profile-edit-layout {
        grid-template-columns: 1fr;
    }

    .profile-edit-sidebar {
        position: static;
    }

    .profile-settings-form__grid {
        grid-template-columns: 1fr;
    }

    .profile-field--full {
        grid-column: auto;
    }

    .profile-field--left-column,
    .profile-field--right-column {
        grid-column: auto;
    }

    .profile-field--stack-2 {
        grid-row: auto;
    }

    .profile-modal {
        padding: 16px;
    }

    .profile-modal__dialog {
        padding: 18px;
        border-radius: 24px;
    }

    .profile-friends-modal-card,
    .profile-friends-search-result {
        grid-template-columns: 1fr;
    }

    .profile-friends-modal-card__actions {
        justify-content: flex-start;
    }
}

@media (max-width: 640px) {
    .events-my-alert,
    .events-my-empty-state__actions,
    .event-danger-zone {
        flex-direction: column;
        align-items: stretch;
    }

    .events-my-grid {
        grid-template-columns: 1fr;
    }

    .event-toggle {
        grid-template-columns: auto minmax(0, 1fr);
    }

    .wishlists-overview-panel,
    .wishlists-alert,
    .wishlists-empty-card {
        padding: 24px;
    }

    .desktop-wishlist-card {
        padding: 20px;
    }

    .wishlists-alert.wishlists-alert--accent {
        padding-left: 30px;
    }

    .desktop-wishlist-card__header,
    .desktop-wishlist-occasion,
    .app-nav {
        flex-direction: column;
        align-items: flex-start;
    }

    .wishlists-overview {
        grid-template-columns: 1fr;
    }

    .profile-pill {
        width: 100%;
        justify-content: space-between;
    }

    .profile-edit-form-card,
    .profile-avatar-crop-card {
        padding: 22px;
    }

    .profile-edit-avatar-trigger__image {
        width: 132px;
        height: 132px;
        border-radius: 28px;
    }

    .profile-settings-form__actions .hero-cta {
        width: 100%;
        min-width: 0;
    }

    .profile-wishlists-empty-card {
        padding: 18px;
        min-height: 0;
    }

    .profile-wishlists-empty-card__intro {
        grid-template-columns: 1fr;
        justify-items: center;
    }

    .profile-wishlists-empty-card__copy {
        gap: 6px;
    }

    .profile-wishlists-empty-card__icon {
        width: 52px;
        height: 52px;
        border-radius: 16px;
        font-size: 26px;
    }

    .profile-friends-grid {
        grid-template-columns: 1fr;
    }

    .profile-modal {
        padding: 10px;
    }

    .profile-modal__dialog {
        max-height: calc(100vh - 20px);
        padding: 16px;
        border-radius: 20px;
    }

    .profile-modal__header {
        grid-template-columns: minmax(0, 1fr) 40px;
    }

    .profile-friends-search,
    .profile-friends-modal-section {
        padding: 14px;
    }

    .profile-friends-search-result__side,
    .profile-friends-modal-card__actions {
        width: 100%;
    }

    .profile-friends-search-result__button,
    .profile-friends-modal-action {
        width: 100%;
        justify-content: center;
    }
}

.wishlist-view-main {
    display: grid;
    gap: 16px;
}

.wishlist-view-stage {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 0;
    align-items: start;
}

.wishlist-view-stage__main,
.wishlist-view-collection,
.wishlist-view-empty,
.wishlist-view-archive {
    border: 1px solid rgba(208, 217, 233, 0.82);
    background: rgba(255, 255, 255, 0.9);
    box-shadow: 0 16px 36px rgba(51, 51, 51, 0.08);
}

.wishlist-view-stage__main {
    display: grid;
    gap: 14px;
    padding: 24px;
    border-radius: 26px;
    background:
        radial-gradient(120% 120% at 0% 0%, rgba(255, 188, 99, 0.08) 0%, rgba(255, 188, 99, 0) 55%),
        radial-gradient(110% 120% at 100% 0%, rgba(79, 110, 183, 0.08) 0%, rgba(79, 110, 183, 0) 60%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(247, 249, 253, 0.96) 100%);
}

.wishlist-view-stage__crumbs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    color: #667089;
    font-size: 11px;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.wishlist-view-stage__crumbs a {
    color: var(--color-link);
    font-weight: 700;
}

.wishlist-view-stage__eyebrow {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
}

.wishlist-view-badge,
.wishlist-view-stage__owner,
.wishlist-view-summary__meta span,
.wishlist-view-filter-chip,
.wishlist-view-card__priority,
.wishlist-view-card__price {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
}

.wishlist-view-badge {
    min-height: 30px;
    padding: 0 12px;
    background: rgba(51, 51, 51, 0.08);
    color: var(--color-link);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.wishlist-view-stage__owner {
    gap: 8px;
    min-height: 34px;
    padding: 0 12px 0 8px;
    background: rgba(51, 51, 51, 0.08);
    color: var(--color-text-main);
    font-size: 13px;
    font-weight: 700;
}

.wishlist-view-stage__owner--self {
    padding: 0 12px;
}

.wishlist-view-stage__owner-avatar,
.wishlist-view-stage__owner-fallback {
    width: 24px;
    height: 24px;
    border-radius: 30%;
    flex-shrink: 0;
}

.wishlist-view-stage__owner-avatar {
    object-fit: cover;
}

.wishlist-view-stage__owner-fallback {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background:
        radial-gradient(120% 120% at 0% 0%, rgba(255, 199, 93, 0.12) 0%, rgba(255, 199, 93, 0) 58%),
        radial-gradient(95% 120% at 100% 0%, rgba(71, 122, 255, 0.1) 0%, rgba(71, 122, 255, 0) 60%),
        linear-gradient(170deg, rgba(255, 255, 255, 0.9) 0%, rgba(248, 250, 255, 0.8) 100%);
    color: var(--color-link);
    font-size: 12px;
    font-weight: 700;
}

.wishlist-view-stage__header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 18px;
    align-items: start;
}

.wishlist-view-stage__title {
    margin: 0;
    font-size: clamp(30px, 3.8vw, 46px);
    line-height: 1.02;
    letter-spacing: -0.04em;
}

.wishlist-view-stage__lock {
    display: inline-flex;
    vertical-align: text-top;
    margin-left: 0;
    line-height: 1;
}

.wishlist-view-stage__description {
    margin: 10px 0 0;
    max-width: 700px;
    color: var(--color-text-muted);
    font-size: 15px;
    line-height: 1.6;
}

.wishlist-view-stage__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-end;
}

.wishlist-view-stage__actions .hero-cta {
    min-height: 46px;
    padding: 0 18px;
    border-radius: 14px;
    font-size: 14px;
}

.wishlist-public-stage {
    position: relative;
    overflow: hidden;
}

.wishlist-public-stage__actions {
    align-content: start;
}

.wishlist-public-stage__note,
.wishlist-public-promo {
    border: 1px solid rgba(208, 217, 233, 0.82);
    background: rgba(255, 255, 255, 0.82);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55);
}

.wishlist-public-stage__note {
    display: grid;
    gap: 8px;
    padding: 16px 18px;
    border-radius: 18px;
    color: var(--color-text-muted);
    font-size: 14px;
    line-height: 1.55;
}

.wishlist-public-stage__note strong {
    color: var(--color-text-main);
    font-size: 15px;
}

.wishlist-view-summary__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.wishlist-view-summary__meta span {
    min-height: 32px;
    padding: 0 12px;
    background: rgba(51, 51, 51, 0.08);
    color: var(--color-link);
    font-size: 12px;
    font-weight: 700;
}

.wishlist-view-stage__events {
    display: grid;
    gap: 8px;
}

.wishlist-view-event-pill {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(208, 217, 233, 0.82);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.wishlist-view-event-pill__content {
    min-width: 0;
}

.wishlist-view-event-pill__label,
.wishlist-view-collection__kicker,
.wishlist-view-panel__label {
    display: block;
    margin-bottom: 4px;
    color: #667089;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.wishlist-view-event-pill strong {
    display: block;
    color: var(--color-text-main);
    font-size: 14px;
    line-height: 1.35;
}

.wishlist-view-event-pill__timer {
    align-self: center;
    justify-self: end;
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 0 12px;
    border-radius: 999px;
    background: var(--color-action-primary-gradient);
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    white-space: nowrap;
}

.wishlist-view-collection {
    display: grid;
    gap: 14px;
    padding: 20px;
    border-radius: 24px;
    background:
        radial-gradient(120% 120% at 0% 0%, rgba(255, 188, 99, 0.08) 0%, rgba(255, 188, 99, 0) 55%),
        radial-gradient(110% 120% at 100% 0%, rgba(79, 110, 183, 0.08) 0%, rgba(79, 110, 183, 0) 60%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(247, 249, 253, 0.96) 100%);
}

.wishlist-view-collection__header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 12px;
}

.wishlist-view-collection__header h2 {
    margin: 0;
    font-size: clamp(24px, 2.8vw, 34px);
    line-height: 1.08;
    letter-spacing: -0.03em;
}

.wishlist-view-filter-wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.wishlist-view-filter-chip {
    min-height: 36px;
    padding: 0 12px;
    background: rgba(51, 51, 51, 0.08);
    color: var(--color-link);
    border: 1px solid rgba(47, 63, 93, 0.14);
    font-size: 13px;
    font-weight: 700;
    transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.wishlist-view-filter-chip:hover,
.wishlist-view-filter-chip--active {
    background: var(--color-action-primary-gradient);
    color: #fff;
    transform: translateY(-1px);
}

.wishlist-view-items {
    display: grid;
    gap: 14px;
}

.wishlist-view-list {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.wishlist-view-card {
    display: grid;
    position: relative;
    padding: 14px;
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(247, 249, 253, 0.96) 100%);
    border: 1px solid rgba(208, 217, 233, 0.82);
    box-shadow: 0 8px 20px rgba(51, 51, 51, 0.06);
    overflow: visible;
}

.wishlist-view-card--create {
    place-items: center;
    min-height: 100%;
    border-style: dashed;
    text-decoration: none;
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.18), transparent 42%),
        linear-gradient(180deg, rgba(255, 252, 246, 0.98) 0%, rgba(244, 248, 253, 0.98) 100%);
}

.wishlist-view-card--create:hover {
    transform: translateY(-1px);
    box-shadow: 0 18px 32px rgba(48, 64, 92, 0.12);
}

.wishlist-view-card--menu-open {
    z-index: 30;
}

.wishlist-view-card--high {
    border-left: 6px solid #62a83a;
}

.wishlist-view-card--medium {
    border-left: 6px solid #495057;
}

.wishlist-view-card--low {
    border-left: 6px solid #adb5bd;
}

.wishlist-view-card--hidden {
    border-left: 6px solid #95a1b3;
    opacity: 0.92;
}

.wishlist-view-card__priority {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 28px;
    gap: 6px;
    padding: 0 10px;
    background: #d3f9d8;
    color: #1e7e34;
    font-size: 11px;
    font-weight: 700;
    border: 0;
}

.wishlist-view-card--medium .wishlist-view-card__priority {
    background: #edf1f6;
    color: #344054;
}

.wishlist-view-card--low .wishlist-view-card__priority {
    background: #f1f3f5;
    color: #667085;
}

.wishlist-view-card--hidden .wishlist-view-card__priority {
    background: rgba(149, 161, 179, 0.18);
    color: #5f6f85;
}

.wishlist-view-card__priority.wishlist-view-card__priority--reserved,
.wishlist-view-card--medium .wishlist-view-card__priority.wishlist-view-card__priority--reserved,
.wishlist-view-card--low .wishlist-view-card__priority.wishlist-view-card__priority--reserved,
.wishlist-view-card--hidden .wishlist-view-card__priority.wishlist-view-card__priority--reserved {
    background: rgba(154, 18, 57, 0.14);
    color: #9a1239;
    cursor: pointer;
}

.wishlist-view-card--hidden {
    position: relative;
    overflow: visible;
}

.wishlist-view-card--hidden::after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(243, 245, 249, 0.58);
    pointer-events: none;
}

.wishlist-view-card__priority-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: currentColor;
}

.wishlist-view-card__body {
    display: grid;
    grid-template-columns: 72px minmax(0, 1fr);
    gap: 14px;
    align-items: stretch;
}

.wishlist-view-card__body--stacked-meta {
    grid-template-columns: minmax(0, 1fr) 42px;
}

.wishlist-view-card__body--stacked-meta.wishlist-view-card__body--public,
.wishlist-view-card__body--stacked-meta.wishlist-view-card__body--public.wishlist-view-card__body--no-image {
    grid-template-columns: minmax(0, 1fr);
}

.wishlist-view-card__body--with-actions {
    grid-template-columns: 72px minmax(0, 1fr) 42px;
}

.wishlist-view-card__body--with-owner-actions {
    grid-template-columns: 72px minmax(0, 1fr) 42px;
}

.wishlist-view-card__body--no-image {
    grid-template-columns: minmax(0, 1fr);
}

.wishlist-view-card__body--no-image.wishlist-view-card__body--with-actions {
    grid-template-columns: minmax(0, 1fr) 42px;
}

.wishlist-view-card__body--no-image.wishlist-view-card__body--with-owner-actions {
    grid-template-columns: minmax(0, 1fr) 42px;
}

.wishlist-view-card__body--stacked-meta.wishlist-view-card__body--no-image,
.wishlist-view-card__body--stacked-meta.wishlist-view-card__body--with-owner-actions,
.wishlist-view-card__body--stacked-meta.wishlist-view-card__body--no-image.wishlist-view-card__body--with-owner-actions {
    grid-template-columns: minmax(0, 1fr) 42px;
}

.wishlist-view-card__body--stacked-meta.wishlist-view-card__body--with-actions,
.wishlist-view-card__body--stacked-meta.wishlist-view-card__body--no-image.wishlist-view-card__body--with-actions {
    grid-template-columns: minmax(0, 1fr) 42px;
}

.wishlist-view-card__main {
    display: grid;
    grid-template-columns: 72px minmax(0, 1fr);
    grid-template-rows: minmax(0, 1fr) auto;
    grid-template-areas:
        "media content"
        "meta meta";
    gap: 14px;
    min-width: 0;
    height: 100%;
    align-self: stretch;
    align-items: start;
}

.wishlist-view-card__main--no-image {
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: minmax(0, 1fr) auto;
    grid-template-areas:
        "content"
        "meta";
}

.wishlist-view-card__content {
    display: grid;
    grid-template-rows: auto auto minmax(0, 1fr) auto;
    align-self: stretch;
    min-width: 0;
    height: 100%;
}

.wishlist-view-card__content > .wishlist-view-card__priority {
    grid-row: 1;
    margin-bottom: 10px;
}

.wishlist-view-card__badges {
    grid-row: 1;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 10px;
}

.wishlist-view-card__main > .wishlist-view-card__media {
    grid-area: media;
}

.wishlist-view-card__main > .wishlist-view-card__content {
    grid-area: content;
    align-self: start;
}

.wishlist-view-card__main > .wishlist-view-card__meta {
    grid-area: meta;
    grid-row: auto;
    align-self: end;
    padding-top: 4px;
}

.wishlist-view-card__actions {
    display: grid;
    gap: 8px;
    align-content: start;
    justify-items: end;
}

.wishlist-view-card__actions--compact {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
    align-content: flex-start;
}

.wishlist-view-card__actions--compact .wishlist-view-card__action {
    width: 100%;
    min-width: 0;
    min-height: 32px;
    padding: 0 11px;
    border-radius: 999px;
    font-size: 13px;
    line-height: 1;
    white-space: nowrap;
}

.wishlist-public-card__actions {
    min-width: 220px;
    justify-content: flex-start;
}

.wishlist-public-card__actions .wishlist-view-card__action {
    min-width: 0;
}

.wishlist-view-card__actions--owner {
    justify-items: end;
}

.wishlist-view-card--hidden .wishlist-view-card__actions--owner {
    position: relative;
    z-index: 4;
}

.wishlist-view-card__head {
    grid-row: 2;
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: start;
}

.wishlist-view-card__title-group {
    min-width: 0;
}

.wishlist-view-card__title {
    margin: 0;
    font-size: 20px;
    line-height: 1.2;
    letter-spacing: -0.02em;
}

.wishlist-view-card__reserve {
    margin-top: 8px;
    min-height: 24px;
    padding: 0 10px;
    border: 0;
    border-radius: 999px;
    background: var(--color-chip-soft);
    color: var(--color-link);
    border: 1px solid rgba(47, 63, 93, 0.12);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.05em;
}

.wishlist-view-card__menu {
    position: relative;
    z-index: 5;
}

.wishlist-view-card__menu-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    min-width: 42px;
    border-radius: 14px;
    border: 1px solid rgba(42, 57, 87, 0.08);
    background:
        linear-gradient(180deg, rgba(247, 240, 232, 0.98) 0%, rgba(232, 238, 246, 0.98) 100%);
    box-shadow:
        0 10px 24px rgba(20, 28, 43, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.85);
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.wishlist-view-card__menu-btn:hover,
.wishlist-view-card__menu-btn:focus-visible {
    transform: translateY(-1px);
    border-color: rgba(42, 57, 87, 0.14);
    background: linear-gradient(180deg, rgba(248, 241, 234, 1) 0%, rgba(228, 235, 245, 1) 100%);
    box-shadow:
        0 16px 32px rgba(20, 28, 43, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.wishlist-item-create-main {
    display: grid;
    gap: 18px;
}

.wishlist-item-create-stage {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
    align-items: start;
}

.wishlist-item-create-stage__intro,
.wishlist-item-create-panel,
.wishlist-item-create-form-shell {
    border: 1px solid rgba(208, 217, 233, 0.82);
    box-shadow: 0 16px 36px rgba(51, 51, 51, 0.08);
}

.wishlist-item-create-stage__intro {
    display: grid;
    gap: 14px;
    padding: 24px;
    border-radius: 26px;
    background:
        radial-gradient(120% 120% at 0% 0%, rgba(255, 188, 99, 0.08) 0%, rgba(255, 188, 99, 0) 55%),
        radial-gradient(110% 120% at 100% 0%, rgba(79, 110, 183, 0.08) 0%, rgba(79, 110, 183, 0) 60%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(247, 249, 253, 0.96) 100%);
}

.wishlist-item-create-stage__title-block {
    min-width: 0;
}

.wishlist-item-create-panel {
    display: grid;
    gap: 18px;
    padding: 24px;
    border-radius: 24px;
    background:
        radial-gradient(120% 120% at 0% 0%, rgba(255, 188, 99, 0.08) 0%, rgba(255, 188, 99, 0) 55%),
        radial-gradient(110% 120% at 100% 0%, rgba(79, 110, 183, 0.08) 0%, rgba(79, 110, 183, 0) 60%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(247, 249, 253, 0.96) 100%);
}

.wishlist-item-create-panel__title {
    margin: 0;
    font-size: clamp(24px, 2.2vw, 32px);
    line-height: 1.08;
    letter-spacing: -0.03em;
}

.wishlist-item-create-panel__text {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 15px;
    line-height: 1.65;
}

.wishlist-item-create-panel--horizontal {
    grid-template-columns: minmax(280px, 0.9fr) minmax(0, 1.6fr);
    align-items: center;
    gap: 20px;
}

.wishlist-item-create-panel__intro {
    display: grid;
    gap: 10px;
    align-content: center;
    min-height: 100%;
}

.wishlist-item-create-panel__list {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.wishlist-item-create-panel__point {
    display: grid;
    gap: 4px;
    padding: 14px 16px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(208, 217, 233, 0.82);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.wishlist-item-create-panel__point strong {
    font-size: 14px;
}

.wishlist-item-create-panel__point span {
    color: var(--color-text-muted);
    font-size: 14px;
    line-height: 1.5;
}

.wishlist-item-create-form-shell {
    border-radius: 24px;
    background:
        radial-gradient(120% 120% at 0% 0%, rgba(255, 188, 99, 0.08) 0%, rgba(255, 188, 99, 0) 55%),
        radial-gradient(110% 120% at 100% 0%, rgba(79, 110, 183, 0.08) 0%, rgba(79, 110, 183, 0) 60%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(247, 249, 253, 0.96) 100%);
}

.wishlist-item-create-form {
    display: grid;
    gap: 18px;
    padding: 28px;
}

.wishlist-item-create-form-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(320px, 420px);
    gap: 24px;
    align-items: start;
}

.wishlist-item-create-form-main,
.wishlist-item-create-form-side {
    display: grid;
    gap: 18px;
    min-width: 0;
}

.wishlist-item-create-form-side {
    position: sticky;
    top: 24px;
}

.wishlist-item-create-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) minmax(220px, 0.8fr);
    gap: 16px;
}

.wishlist-item-create-field {
    gap: 8px;
}

.wishlist-item-create-field span,
.wishlist-item-create-field__label {
    font-size: 14px;
    font-weight: 700;
    color: var(--color-text-main);
}

.wishlist-item-create-field textarea,
.wishlist-item-create-field input {
    width: 100%;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border-soft);
    background: var(--color-bg-surface-input);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
    color: var(--color-text-main);
    font-size: 16px;
}

.wishlist-item-create-field textarea {
    min-height: 140px;
    padding: 14px 16px;
    resize: vertical;
}

.wishlist-item-create-field textarea::placeholder {
    color: #6d7888;
}

.wishlist-item-create-field textarea:focus-visible {
    outline: none;
    border-color: rgba(61, 93, 165, 0.55);
    box-shadow: 0 0 0 3px rgba(51, 75, 136, 0.14);
}

.wishlist-item-create-error {
    padding: 14px 16px;
    border-radius: 16px;
    border: 1px solid rgba(199, 59, 74, 0.28);
    background: rgba(255, 240, 242, 0.92);
    color: var(--color-danger);
    font-size: 14px;
    line-height: 1.5;
}

.wishlist-item-create-priority {
    display: grid;
    gap: 10px;
    padding: 18px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(208, 217, 233, 0.82);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.wishlist-item-create-details {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.wishlist-item-create-details__item {
    padding: 16px 18px;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(208, 217, 233, 0.82);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.wishlist-item-create-details__item p {
    margin: 8px 0 0;
    color: var(--color-text-muted);
    font-size: 14px;
    line-height: 1.55;
}

.wishlist-item-create-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    flex-wrap: wrap;
    padding: 18px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(208, 217, 233, 0.82);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.wishlist-item-create-submit {
    width: auto;
    min-width: 220px;
}

.wishlist-item-create-page .is-hidden {
    display: none !important;
}

.wishlist-item-create-page .wishitem-image-picker {
    position: relative;
    display: grid;
    gap: 10px;
    padding: 18px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(208, 217, 233, 0.82);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.wishlist-item-create-page .wishitem-image-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
}

.wishlist-item-create-page .wishitem-image-subtitle {
    margin-top: 4px;
    color: var(--color-text-muted);
    font-size: 13px;
    line-height: 1.5;
}

.wishlist-item-create-page .wishitem-image-remove,
.wishlist-item-create-page .confirm-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 16px;
    border-radius: 14px;
    border: 1px solid rgba(47, 63, 93, 0.18);
    background: rgba(255, 255, 255, 0.82);
    color: var(--color-link);
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
}

.wishlist-item-create-page .confirm-btn-ok {
    background: var(--color-action-primary-gradient);
    color: #fff;
    box-shadow: 0 8px 18px rgba(45, 67, 106, 0.24), inset 0 1px 0 rgba(255, 255, 255, 0.3);
}

.wishlist-item-create-page .wishitem-image-dropzone {
    position: relative;
    display: block;
    width: 100%;
    min-height: 260px;
    padding: 0;
    border-radius: 22px;
    border: 1px dashed rgba(208, 217, 233, 0.82);
    background:
        radial-gradient(120% 120% at 0% 0%, rgba(255, 188, 99, 0.08) 0%, rgba(255, 188, 99, 0) 55%),
        radial-gradient(110% 120% at 100% 0%, rgba(79, 110, 183, 0.08) 0%, rgba(79, 110, 183, 0) 60%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(247, 249, 253, 0.96) 100%);
    overflow: hidden;
    cursor: pointer;
}

.wishlist-item-create-page .wishitem-image-preview {
    display: block;
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
}

.wishlist-item-create-page .wishitem-image-empty {
    min-height: 260px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 24px;
    text-align: center;
}

.wishlist-item-create-page .wishitem-image-empty-icon {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.82);
    color: var(--color-link);
    font-size: 28px;
    line-height: 1;
}

.wishlist-item-create-page .wishitem-image-empty-icon .add-icon-image {
    width: 28px;
    height: 28px;
    display: block;
    object-fit: contain;
}

.wishlist-item-create-page .wishitem-image-empty-title {
    font-size: 16px;
    font-weight: 700;
}

.wishlist-item-create-page .wishitem-image-empty-text {
    max-width: 320px;
    color: var(--color-text-muted);
    font-size: 14px;
    line-height: 1.55;
}

.wishlist-item-create-page .wishitem-image-crop-modal {
    position: fixed;
    inset: 0;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
    background: rgba(22, 32, 47, 0.48);
    backdrop-filter: blur(8px);
    z-index: 1400;
}

.wishlist-item-create-page .wishitem-image-crop-modal.is-active {
    display: flex;
}

.wishlist-item-create-page .wishitem-image-crop-card {
    width: min(620px, 100%);
    border-radius: 22px;
    border: 1px solid rgba(208, 217, 233, 0.82);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(247, 249, 253, 0.99) 100%);
    box-shadow: 0 24px 50px rgba(20, 28, 43, 0.24);
    padding: 18px;
}

.wishlist-item-create-page .wishitem-image-crop-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 14px;
}

.wishlist-item-create-page .wishitem-image-crop-title {
    font-size: 18px;
    font-weight: 700;
}

.wishlist-item-create-page .wishitem-image-crop-text {
    margin-top: 4px;
    color: var(--color-text-muted);
    font-size: 13px;
    line-height: 1.5;
}

.wishlist-item-create-page .wishitem-image-crop-close {
    width: 42px;
    height: 42px;
    border-radius: 14px;
    border: 1px solid rgba(47, 63, 93, 0.18);
    background: rgba(255, 255, 255, 0.82);
    color: var(--color-link);
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
}

.wishlist-item-create-page .wishitem-image-crop-stage {
    overflow: hidden;
    border-radius: 18px;
    background: rgba(240, 244, 255, 0.82);
    max-height: min(70vh, 560px);
}

.wishlist-item-create-page .wishitem-image-crop-stage img {
    display: block;
    max-width: 100%;
}

.wishlist-item-create-page .wishitem-image-crop-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 14px;
}

.wishlist-item-create-page .avatar-crop-overlay {
    position: fixed;
    inset: 0;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
    background: rgba(22, 32, 47, 0.42);
    backdrop-filter: blur(6px);
    z-index: 1500;
}

.wishlist-item-create-page .avatar-crop-overlay.is-active {
    display: flex;
}

.wishlist-item-create-page .avatar-crop-overlay-card {
    width: min(360px, 100%);
    padding: 20px;
    border-radius: 20px;
    border: 1px solid rgba(208, 217, 233, 0.82);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(247, 249, 253, 0.99) 100%);
    box-shadow: 0 24px 50px rgba(20, 28, 43, 0.24);
}

.wishlist-item-create-page .avatar-crop-overlay-title {
    font-size: 16px;
    font-weight: 700;
}

.wishlist-item-create-page .avatar-crop-progress-track {
    height: 10px;
    margin-top: 14px;
    overflow: hidden;
    border-radius: 999px;
    background: rgba(47, 63, 93, 0.12);
}

.wishlist-item-create-page .avatar-crop-progress-bar {
    width: 0;
    height: 100%;
    border-radius: inherit;
    background: var(--color-action-primary-gradient);
}

.wishlist-item-create-page .priority-tag-group {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.wishlist-item-create-page .priority-tag {
    position: relative;
    display: block;
    cursor: pointer;
}

.wishlist-item-create-page .priority-tag input[type="radio"] {
    position: absolute;
    inset: 0;
    opacity: 0;
    margin: 0;
}

.wishlist-item-create-page .priority-tag-body {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-height: 86px;
    padding: 16px;
    border-radius: 18px;
    border: 1px solid rgba(208, 217, 233, 0.82);
    background: rgba(255, 255, 255, 0.82);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.wishlist-item-create-page .priority-tag-name {
    font-size: 15px;
    font-weight: 700;
    color: var(--color-text-main);
}

.wishlist-item-create-page .priority-tag-desc {
    color: var(--color-text-muted);
    font-size: 13px;
    line-height: 1.45;
}

.wishlist-item-create-page .priority-tag input[type="radio"]:focus-visible + .priority-tag-body {
    border-color: rgba(61, 93, 165, 0.55);
    box-shadow: 0 0 0 3px rgba(51, 75, 136, 0.14);
}

.wishlist-item-create-page .priority-tag input[type="radio"]:checked + .priority-tag-body {
    transform: translateY(-1px);
}

.wishlist-item-create-page .priority-tag.priority-high input[type="radio"]:checked + .priority-tag-body {
    border-color: rgba(47, 138, 70, 0.32);
    background: linear-gradient(180deg, rgba(232, 248, 236, 0.98) 0%, rgba(220, 244, 228, 0.98) 100%);
    box-shadow: 0 12px 24px rgba(47, 138, 70, 0.12);
}

.wishlist-item-create-page .priority-tag.priority-medium input[type="radio"]:checked + .priority-tag-body {
    border-color: rgba(255, 200, 102, 0.78);
    background: linear-gradient(180deg, rgba(255, 244, 218, 0.96) 0%, rgba(255, 250, 236, 0.92) 100%);
    box-shadow: 0 12px 24px rgba(176, 140, 56, 0.12);
}

.wishlist-item-create-page .priority-tag.priority-low input[type="radio"]:checked + .priority-tag-body {
    border-color: rgba(79, 96, 129, 0.26);
    background: linear-gradient(180deg, rgba(239, 243, 250, 0.98) 0%, rgba(228, 235, 245, 0.98) 100%);
    box-shadow: 0 12px 24px rgba(79, 96, 129, 0.12);
}

.wishlist-item-edit-page .wishlist-item-edit-status-card {
    display: grid;
    gap: 16px;
    padding: 24px;
    border-radius: 24px;
    border: 1px solid rgba(208, 217, 233, 0.82);
    background:
        radial-gradient(120% 120% at 0% 0%, rgba(255, 188, 99, 0.08) 0%, rgba(255, 188, 99, 0) 55%),
        radial-gradient(110% 120% at 100% 0%, rgba(79, 110, 183, 0.08) 0%, rgba(79, 110, 183, 0) 60%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(247, 249, 253, 0.96) 100%);
    box-shadow: 0 16px 36px rgba(51, 51, 51, 0.08);
}

.wishlist-item-edit-page .wishlist-item-edit-status-card__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
}

.wishlist-item-edit-page .wishlist-item-edit-status-card__title {
    margin: 6px 0 0;
    font-size: clamp(24px, 2.2vw, 32px);
    line-height: 1.08;
    letter-spacing: -0.03em;
}

.wishlist-item-edit-page .wishlist-item-edit-status-card__note {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 0 14px;
    border-radius: 999px;
    background: rgba(51, 51, 51, 0.08);
    color: var(--color-link);
    font-size: 13px;
    font-weight: 700;
    white-space: nowrap;
}

.wishlist-item-edit-page .status-active input[type="radio"]:checked + .priority-tag-body {
    border-color: rgba(47, 138, 70, 0.32);
    background: linear-gradient(180deg, rgba(232, 248, 236, 0.98) 0%, rgba(220, 244, 228, 0.98) 100%);
    box-shadow: 0 12px 24px rgba(47, 138, 70, 0.12);
}

.wishlist-item-edit-page .status-gifted input[type="radio"]:checked + .priority-tag-body {
    border-color: rgba(255, 200, 102, 0.78);
    background: linear-gradient(180deg, rgba(255, 244, 218, 0.96) 0%, rgba(255, 250, 236, 0.92) 100%);
    box-shadow: 0 12px 24px rgba(176, 140, 56, 0.12);
}

.wishlist-item-edit-page .status-archived input[type="radio"]:checked + .priority-tag-body {
    border-color: rgba(79, 96, 129, 0.26);
    background: linear-gradient(180deg, rgba(239, 243, 250, 0.98) 0%, rgba(228, 235, 245, 0.98) 100%);
    box-shadow: 0 12px 24px rgba(79, 96, 129, 0.12);
}

.wishlist-item-edit-page .wishlist-item-edit-danger {
    display: grid;
    gap: 14px;
    padding: 18px;
    border-radius: 22px;
    border: 1px solid rgba(199, 59, 74, 0.22);
    background: linear-gradient(180deg, rgba(255, 244, 245, 0.98) 0%, rgba(255, 236, 239, 0.96) 100%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.wishlist-item-edit-page .wishlist-item-edit-danger__copy h3 {
    margin: 6px 0 0;
    font-size: 22px;
    line-height: 1.08;
}

.wishlist-item-edit-page .wishlist-item-edit-danger__copy p {
    margin: 10px 0 0;
    color: #7a5860;
    font-size: 14px;
    line-height: 1.55;
}

.wishlist-item-edit-page .wishlist-item-edit-danger__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    width: 100%;
    padding: 0 18px;
    border: 1px solid rgba(199, 59, 74, 0.32);
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(199, 59, 74, 0.96) 0%, rgba(163, 34, 48, 0.96) 100%);
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    box-shadow: 0 12px 24px rgba(163, 34, 48, 0.18);
}

.wishlist-edit-page .wishlist-edit-main {
    display: grid;
    gap: 18px;
}

.wishlist-edit-page .wishlist-edit-section {
    display: grid;
    gap: 16px;
    padding: 18px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(208, 217, 233, 0.82);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.wishlist-edit-page .wishlist-edit-section__header h2 {
    margin: 0;
    font-size: 22px;
    line-height: 1.15;
}

.wishlist-edit-page .wishlist-edit-section__header p {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 14px;
    line-height: 1.6;
}

.wishlist-edit-page .wishlist-edit-section__header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
    gap: 16px;
    align-items: end;
}

.wishlist-edit-page .wishlist-edit-access-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.wishlist-edit-page .wishlist-edit-choice,
.wishlist-edit-page .wishlist-edit-friend,
.wishlist-edit-page .wishlist-edit-event {
    position: relative;
    display: grid;
    gap: 8px;
    padding: 18px;
    border-radius: 20px;
    border: 1px solid rgba(208, 217, 233, 0.82);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.92) 0%, rgba(247, 249, 253, 0.92) 100%);
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background 0.18s ease;
    cursor: pointer;
}

.wishlist-edit-page .wishlist-edit-choice:hover,
.wishlist-edit-page .wishlist-edit-friend:hover,
.wishlist-edit-page .wishlist-edit-event:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 24px rgba(51, 51, 51, 0.08);
}

.wishlist-edit-page .wishlist-edit-choice input,
.wishlist-edit-page .wishlist-edit-friend input,
.wishlist-edit-page .wishlist-edit-event input {
    position: absolute;
    inset: 0;
    opacity: 0;
    margin: 0;
    cursor: pointer;
}

.wishlist-edit-page .wishlist-edit-choice.is-selected,
.wishlist-edit-page .wishlist-edit-event.is-selected {
    border-color: rgba(255, 200, 102, 0.78);
    background: linear-gradient(180deg, rgba(255, 244, 218, 0.96) 0%, rgba(255, 250, 236, 0.92) 100%);
    box-shadow: 0 0 0 2px rgba(255, 200, 102, 0.16), 0 12px 24px rgba(176, 140, 56, 0.12);
}

.wishlist-edit-page .wishlist-edit-friend.is-selected {
    border-color: rgba(31, 129, 72, 0.72);
    background: linear-gradient(180deg, rgba(220, 248, 232, 0.98) 0%, rgba(210, 243, 224, 1) 100%);
    box-shadow: 0 0 0 2px rgba(31, 129, 72, 0.14), 0 12px 24px rgba(28, 103, 62, 0.1);
}

.wishlist-edit-page .wishlist-edit-choice__title,
.wishlist-edit-page .wishlist-edit-friend__name,
.wishlist-edit-page .wishlist-edit-event strong {
    font-size: 15px;
    font-weight: 700;
    color: var(--color-text-main);
}

.wishlist-edit-page .wishlist-edit-choice__text,
.wishlist-edit-page .wishlist-edit-event__copy span,
.wishlist-edit-page .wishlist-edit-friends__hint,
.wishlist-edit-page .wishlist-edit-inline-hint,
.wishlist-edit-page .wishlist-edit-empty-state__title {
    color: var(--color-text-muted);
    font-size: 14px;
    line-height: 1.55;
}

.wishlist-edit-page .wishlist-edit-inline-hint {
    margin: -4px 0 2px;
    padding: 10px 12px;
    border-radius: 14px;
    background: rgba(255, 244, 218, 0.65);
    border: 1px solid rgba(255, 200, 102, 0.32);
}

.wishlist-edit-page .wishlist-edit-friends {
    display: grid;
    gap: 14px;
}

.wishlist-edit-page .wishlist-edit-friends.is-hidden {
    display: none;
}

.wishlist-edit-page .wishlist-edit-friends__grid,
.wishlist-edit-page .wishlist-edit-events {
    display: grid;
    gap: 12px;
}

.wishlist-edit-page .wishlist-edit-friends__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.wishlist-edit-page .wishlist-edit-friend {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
}

.wishlist-edit-page .wishlist-edit-event__timer {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(51, 51, 51, 0.08);
    color: var(--color-link);
    font-size: 12px;
    font-weight: 700;
}

.wishlist-edit-page .wishlist-edit-choice.is-selected .wishlist-edit-choice__title,
.wishlist-edit-page .wishlist-edit-event.is-selected strong {
    color: var(--color-text-main);
}

.wishlist-edit-page .wishlist-edit-choice.is-selected .wishlist-edit-choice__text,
.wishlist-edit-page .wishlist-edit-event.is-selected .wishlist-edit-event__copy span {
    color: var(--color-text-muted);
}

.wishlist-edit-page .wishlist-edit-event {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 16px;
}

.wishlist-edit-page .wishlist-edit-event__copy {
    display: grid;
    gap: 6px;
}

.wishlist-edit-page .wishlist-edit-event__side {
    display: grid;
    gap: 8px;
    justify-items: end;
}

.wishlist-edit-page .wishlist-edit-event.is-selected .wishlist-edit-event__timer {
    background: rgba(255, 200, 102, 0.22);
    color: #7a5a16;
}

.wishlist-edit-page .wishlist-edit-empty-state {
    display: grid;
    gap: 12px;
    justify-items: start;
    padding: 20px;
    border-radius: 20px;
    border: 1px dashed rgba(208, 217, 233, 0.82);
    background: rgba(255, 255, 255, 0.82);
}

.wishlist-edit-page .wishlist-edit-form-side {
    display: grid;
    gap: 18px;
    align-content: start;
}

.wishlist-edit-page .wishlist-edit-section--side {
    gap: 14px;
}

.wishlist-edit-page .wishlist-edit-section__header--stacked {
    grid-template-columns: 1fr;
    align-items: start;
}

.wishlist-edit-page .wishlist-item-edit-danger {
    display: grid;
    gap: 14px;
    padding: 18px;
    border-radius: 22px;
    border: 1px solid rgba(199, 59, 74, 0.22);
    background: linear-gradient(180deg, rgba(255, 244, 245, 0.98) 0%, rgba(255, 236, 239, 0.96) 100%);
    box-shadow:
        0 16px 36px rgba(163, 34, 48, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.wishlist-edit-page .wishlist-item-edit-danger__copy h3 {
    margin: 6px 0 0;
    font-size: 22px;
    line-height: 1.08;
}

.wishlist-edit-page .wishlist-item-edit-danger__copy p {
    margin: 10px 0 0;
    color: #7a5860;
    font-size: 14px;
    line-height: 1.55;
}

.wishlist-edit-page .wishlist-item-edit-danger__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    width: 100%;
    padding: 0 18px;
    border: 1px solid rgba(199, 59, 74, 0.32);
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(199, 59, 74, 0.96) 0%, rgba(163, 34, 48, 0.96) 100%);
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    box-shadow: 0 12px 24px rgba(163, 34, 48, 0.18);
}

.confirm-modal {
    width: min(520px, calc(100vw - 32px));
    max-width: 100%;
    padding: 24px;
    border-radius: 28px;
    border: 1px solid rgba(42, 57, 87, 0.08);
    background:
        radial-gradient(circle at top right, rgba(216, 151, 58, 0.18), transparent 34%),
        linear-gradient(180deg, rgba(247, 240, 232, 0.98) 0%, rgba(232, 238, 247, 0.98) 100%);
    box-shadow: 0 34px 90px rgba(20, 28, 43, 0.22);
}

.confirm-backdrop {
    position: fixed;
    inset: 0;
    z-index: 9998;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: rgba(20, 28, 43, 0.34);
    backdrop-filter: blur(8px);
}

.confirm-backdrop.is-open {
    display: flex;
}

.confirm-title {
    margin: 0;
    font-size: 28px;
    line-height: 1.05;
    letter-spacing: -0.03em;
    color: #1f2937;
}

.confirm-message {
    margin-top: 18px;
    padding: 16px 18px;
    border-radius: 18px;
    background: rgba(240, 234, 225, 0.82);
    border: 1px solid rgba(42, 57, 87, 0.08);
    color: #2f3b4e;
    font-size: 14px;
    line-height: 1.6;
}

.confirm-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-top: 18px;
}

.confirm-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    border-radius: 14px;
    border: 1px solid rgba(42, 57, 87, 0.1);
    font-size: 14px;
    font-weight: 700;
    text-decoration: none;
    cursor: pointer;
}

.confirm-btn-cancel {
    background: rgba(236, 241, 248, 0.88);
    color: #40526d;
}

.confirm-btn-ok {
    background: #243148;
    color: #fff;
    box-shadow: 0 12px 28px rgba(36, 49, 72, 0.2);
}

.confirm-btn:hover,
.confirm-btn:focus-visible {
    transform: translateY(-1px);
}

@media (max-width: 860px) {
    .wishlist-item-edit-page .wishlist-item-edit-status-card__header {
        flex-direction: column;
        align-items: flex-start;
    }

    .confirm-actions {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 1260px) {
    .wishlist-item-create-form-layout {
        grid-template-columns: 1fr;
    }

    .wishlist-item-create-form-side {
        position: static;
    }

    .wishlist-edit-page .wishlist-edit-section__header {
        grid-template-columns: 1fr;
        align-items: start;
    }
}

@media (max-width: 860px) {
    .wishlist-item-create-details,
    .wishlist-item-create-panel--horizontal,
    .wishlist-item-create-panel__list,
    .wishlist-item-create-grid,
    .wishlist-item-create-page .priority-tag-group {
        grid-template-columns: 1fr;
    }

    .wishlist-edit-page .wishlist-edit-access-grid,
    .wishlist-edit-page .wishlist-edit-friends__grid,
    .wishlist-edit-page .wishlist-edit-event {
        grid-template-columns: 1fr;
    }

    .wishlist-edit-page .wishlist-edit-event__side {
        justify-items: start;
    }

    .wishlist-item-create-form {
        padding: 22px;
    }
}

@media (max-width: 640px) {
    .wishlist-item-create-stage__intro,
    .wishlist-item-create-panel,
    .wishlist-item-create-form {
        padding: 18px;
    }

    .wishlist-item-create-actions,
    .wishlist-item-create-page .wishitem-image-crop-actions {
        flex-direction: column;
    }

    .wishlist-item-create-submit,
    .wishlist-item-create-actions .hero-cta,
    .wishlist-item-create-page .confirm-btn {
        width: 100%;
    }

    .wishlist-item-create-page .wishitem-image-dropzone,
    .wishlist-item-create-page .wishitem-image-empty {
        min-height: 220px;
    }
}

.wishlist-view-card__menu-btn img {
    width: 18px;
    height: 18px;
    opacity: 0.82;
}

.wishlist-view-card__menu-panel {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    display: grid;
    gap: 4px;
    min-width: 190px;
    padding: 8px;
    border-radius: 18px;
    border: 1px solid rgba(42, 57, 87, 0.1);
    background:
        radial-gradient(circle at top right, rgba(216, 151, 58, 0.16), transparent 34%),
        linear-gradient(180deg, rgba(247, 240, 232, 0.99) 0%, rgba(232, 238, 247, 0.99) 100%);
    box-shadow: 0 22px 48px rgba(20, 28, 43, 0.16);
}

.wishlist-view-card__menu-item {
    display: flex;
    align-items: center;
    width: 100%;
    min-height: 40px;
    padding: 0 12px;
    border: 0;
    border-radius: 12px;
    background: transparent;
    color: var(--color-link);
    font-size: 14px;
    font-weight: 700;
    text-align: left;
    text-decoration: none;
    cursor: pointer;
}

.wishlist-view-card__menu-item:hover,
.wishlist-view-card__menu-item:focus-visible {
    background: rgba(255, 255, 255, 0.72);
    outline: none;
}

.wishlist-view-card__menu-item--danger {
    color: #8d2430;
}

.wishlist-view-card__description {
    grid-row: 3;
    margin: 8px 0 0;
    color: #657286;
    font-size: 14px;
    line-height: 1.55;
}

.wishlist-view-card__meta {
    grid-row: 4;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    padding-top: 12px;
}

.wishlist-view-card__price {
    min-height: 30px;
    padding: 0 10px;
    background: rgba(51, 51, 51, 0.08);
    color: var(--color-link);
    font-size: 12px;
    font-weight: 700;
}

.wishlist-view-card__link {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 10px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.82);
    color: var(--color-link);
    border: 1px solid rgba(208, 217, 233, 0.82);
    font-size: 12px;
    font-weight: 700;
}

.wishlist-view-card__action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 38px;
    padding: 0 12px;
    border-radius: 12px;
    border: 1px solid rgba(79, 96, 129, 0.22);
    font-size: 13px;
    font-weight: 700;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, border-color 0.18s ease;
}

.wishlist-view-card__action:hover,
.wishlist-view-card__action:focus-visible {
    transform: translateY(-1px);
}

.wishlist-view-card__action--primary {
    background: var(--color-action-primary-gradient);
    border-color: rgba(74, 103, 159, 0.44);
    color: #fff;
    box-shadow: 0 12px 24px rgba(36, 49, 72, 0.18);
}

.wishlist-view-card__action--edit-muted {
    background: rgba(255, 255, 255, 0.82);
    border-color: rgba(208, 217, 233, 0.82);
    color: #667089;
    box-shadow: none;
}

.wishlist-view-card__action--edit-muted:hover,
.wishlist-view-card__action--edit-muted:focus-visible {
    background: rgba(248, 250, 255, 0.92);
    border-color: rgba(89, 105, 139, 0.45);
    color: #5c667a;
    box-shadow: none;
}

.wishlist-view-card__action--secondary {
    background: rgba(255, 255, 255, 0.82);
    color: var(--color-link);
}

.wishlist-view-card__action--ghost {
    background: rgba(240, 244, 255, 0.82);
    color: #8d2430;
}

.wishlist-view-card__actions--compact .wishlist-view-card__action--primary {
    box-shadow: 0 8px 18px rgba(36, 49, 72, 0.14);
}

.wishlist-view-card__media {
    width: 72px;
    height: 72px;
    align-self: start;
    border-radius: 16px;
    overflow: hidden;
    background: linear-gradient(180deg, rgba(248, 250, 255, 0.9) 0%, rgba(236, 242, 250, 0.94) 100%);
}

.wishlist-view-card__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.wishlist-view-page .item-menu-action-reserved {
    color: #8d2430;
}

.wishlist-view-archive {
    display: grid;
    gap: 12px;
    padding: 16px;
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(247, 249, 253, 0.96) 100%);
}

.wishlist-view-archive summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    cursor: pointer;
    list-style: none;
}

.wishlist-view-archive summary::-webkit-details-marker {
    display: none;
}

.wishlist-view-archive summary > span:first-child {
    color: var(--color-link);
    font-size: 20px;
    font-weight: 700;
    line-height: 1.1;
}

.wishlist-view-archive__content {
    overflow: hidden;
}

.wishlist-view-archive--menu-open .wishlist-view-archive__content {
    overflow: visible;
}

.wishlist-view-archive.js-ready .wishlist-view-archive__content {
    height: 0;
    opacity: 0;
    transition: height 0.34s ease, opacity 0.24s ease;
}

.wishlist-view-archive__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 34px;
    height: 34px;
    padding: 0 10px;
    border-radius: 999px;
    background: rgba(51, 51, 51, 0.08);
    color: var(--color-link);
    font-size: 12px;
    font-weight: 700;
}

.wishlist-view-archive .wishlist-view-list {
    padding-top: 2px;
}

.wishlist-view-page .status-overlay {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 3;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    padding: 0 18px;
    border-radius: 999px;
    background: rgba(36, 49, 72, 0.92);
    color: #fff;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    white-space: nowrap;
    box-shadow: 0 12px 24px rgba(20, 28, 43, 0.14);
    border: 1px solid rgba(255, 255, 255, 0.28);
    pointer-events: none;
}

.wishlist-view-empty {
    display: grid;
    gap: 10px;
    justify-items: start;
    padding: 22px;
    border-radius: 22px;
}

.wishlist-view-empty__label {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(124, 79, 34, 0.1);
    color: #7c4f22;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.wishlist-view-empty h3 {
    margin: 0;
    font-size: 24px;
    line-height: 1.12;
}

.wishlist-view-empty p {
    margin: 0;
    max-width: 620px;
    color: #6c7484;
    font-size: 14px;
    line-height: 1.6;
}

.wishlist-public-empty {
    margin: 0;
}

.wishlist-public-promo {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 24px;
    align-items: center;
    padding: 24px 26px;
    border-radius: 26px;
}

.wishlist-public-promo__copy h2 {
    margin: 0;
    font-size: clamp(28px, 3vw, 40px);
    line-height: 1.04;
    letter-spacing: -0.04em;
}

.wishlist-public-promo__copy p {
    margin: 12px 0 0;
    max-width: 620px;
    color: #675f55;
    font-size: 15px;
    line-height: 1.65;
}

.wishlist-public-promo__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-end;
}

.wishlist-view-page .confirm-modal {
    width: min(520px, calc(100vw - 32px));
    max-width: 100%;
    padding: 24px;
    border-radius: 28px;
    border: 1px solid rgba(42, 57, 87, 0.08);
    background:
        radial-gradient(circle at top right, rgba(216, 151, 58, 0.18), transparent 34%),
        linear-gradient(180deg, rgba(247, 240, 232, 0.98) 0%, rgba(232, 238, 247, 0.98) 100%);
    box-shadow: 0 34px 90px rgba(20, 28, 43, 0.22);
}

.wishlist-view-page .confirm-backdrop {
    position: fixed;
    inset: 0;
    z-index: 9998;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: rgba(20, 28, 43, 0.34);
    backdrop-filter: blur(8px);
}

.wishlist-view-page .confirm-backdrop.is-open {
    display: flex;
}

body.confirm-lock {
    overflow: hidden;
}

.wishlist-view-page .copy-item-modal .confirm-title {
    margin: 0;
    font-size: 28px;
    line-height: 1.05;
    letter-spacing: -0.03em;
    color: #1f2937;
}

.wishlist-view-page .copy-item-subtitle {
    margin-top: 10px;
    color: #667085;
    font-size: 15px;
    line-height: 1.7;
}

.wishlist-view-page .copy-item-modal .confirm-message,
.wishlist-view-page .copy-item-name {
    margin-top: 18px;
    padding: 16px 18px;
    border-radius: 18px;
    background: rgba(240, 234, 225, 0.82);
    border: 1px solid rgba(42, 57, 87, 0.08);
    color: #2f3b4e;
    font-size: 14px;
    line-height: 1.6;
}

.wishlist-view-page .copy-item-form {
    display: grid;
    gap: 18px;
    margin-top: 18px;
}

.wishlist-view-page .copy-item-modal .field-group {
    display: grid;
    gap: 10px;
    margin: 0;
}

.wishlist-view-page .copy-item-modal .field-label {
    color: #5f6b80;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.wishlist-view-page .copy-item-modal .select-wrap {
    position: relative;
}

.wishlist-view-page .copy-item-modal .select-wrap::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 16px;
    width: 10px;
    height: 10px;
    border-right: 2px solid #5d6a7f;
    border-bottom: 2px solid #5d6a7f;
    transform: translateY(-60%) rotate(45deg);
    pointer-events: none;
}

.wishlist-view-page .copy-item-select {
    width: 100%;
    min-height: 54px;
    padding: 0 44px 0 16px;
    border-radius: 16px;
    border: 1px solid rgba(42, 57, 87, 0.12);
    background: rgba(241, 236, 229, 0.92);
    color: #243148;
    font-size: 15px;
    font-weight: 600;
    appearance: none;
}

.wishlist-view-page .copy-item-select:focus {
    outline: none;
    border-color: rgba(36, 49, 72, 0.28);
    box-shadow: 0 0 0 4px rgba(49, 71, 103, 0.08);
}

.wishlist-view-page .copy-item-modal .confirm-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-top: 4px;
}

.wishlist-view-page .copy-item-modal .confirm-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    border-radius: 14px;
    border: 1px solid rgba(42, 57, 87, 0.1);
    font-size: 14px;
    font-weight: 700;
    text-decoration: none;
    cursor: pointer;
}

.wishlist-view-page .copy-item-modal .confirm-btn-cancel {
    background: rgba(236, 241, 248, 0.88);
    color: #40526d;
}

.wishlist-view-page .copy-item-modal .confirm-btn-ok {
    background: #243148;
    color: #fff;
    box-shadow: 0 12px 28px rgba(36, 49, 72, 0.2);
}

.wishlist-view-page .copy-item-modal .confirm-btn:hover,
.wishlist-view-page .copy-item-modal .confirm-btn:focus-visible {
    transform: translateY(-1px);
}

.wishlist-view-page .copy-create-link {
    text-decoration: none;
}

.wishlist-view-page .toast {
    position: fixed;
    left: 50%;
    top: 24px;
    bottom: auto;
    width: max-content;
    max-width: min(560px, calc(100vw - 32px));
    min-height: 48px;
    transform: translateX(-50%) translateY(-20px);
    padding: 14px 18px;
    border-radius: 14px;
    background: rgba(27, 39, 59, 0.94);
    color: #fff;
    box-shadow: 0 20px 50px rgba(20, 28, 43, 0.2);
    white-space: normal;
    line-height: 1.45;
    z-index: 9999;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
}

.wishlist-view-page .toast a,
.wishlist-view-page .toast strong,
.wishlist-view-page .toast span {
    color: inherit;
}

.wishlist-view-page .toast.show {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
    visibility: visible;
}

.profile-page .toast {
    position: fixed;
    left: 50%;
    top: 24px;
    bottom: auto;
    width: max-content;
    max-width: min(560px, calc(100vw - 32px));
    min-height: 48px;
    transform: translateX(-50%) translateY(-20px);
    padding: 14px 18px;
    border-radius: 14px;
    background: rgba(27, 39, 59, 0.94);
    color: #fff;
    box-shadow: 0 20px 50px rgba(20, 28, 43, 0.2);
    white-space: normal;
    line-height: 1.45;
    z-index: 9999;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
}

.profile-page .toast.show {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
    visibility: visible;
}

@media (max-width: 900px) {
    .wishlist-view-stage__header,
    .wishlist-view-collection__header,
    .wishlist-view-stage__eyebrow {
        grid-template-columns: 1fr;
        flex-direction: column;
        align-items: flex-start;
    }

    .wishlist-view-stage__actions {
        justify-content: flex-start;
    }

    .reports-layout {
        grid-template-columns: minmax(0, 1fr);
    }

    .reports-sidebar {
        position: static;
    }

    .privacy-layout {
        grid-template-columns: minmax(0, 1fr);
    }

    .privacy-aside {
        position: static;
    }
}

@media (max-width: 640px) {
    .wishlist-view-stage__main,
    .wishlist-view-collection,
    .wishlist-view-empty,
    .wishlist-view-archive {
        padding: 16px;
        border-radius: 18px;
    }

    .wishlist-view-stage__title {
        font-size: 32px;
    }

    .wishlist-view-card__body {
        grid-template-columns: 1fr;
    }

    .wishlist-view-card__body--with-actions,
    .wishlist-view-card__body--no-image.wishlist-view-card__body--with-actions {
        grid-template-columns: 1fr;
    }

    .wishlist-view-card__media {
        width: 64px;
        height: 64px;
    }

    .wishlist-view-card__actions {
        grid-template-columns: 1fr;
    }

    .wishlist-view-card__actions--compact {
        grid-template-columns: 1fr;
    }

    .wishlist-view-list {
        grid-template-columns: 1fr;
    }

    .wishlist-view-event-pill {
        grid-template-columns: 1fr;
        align-items: start;
    }

    .wishlist-view-event-pill__timer {
        justify-self: start;
    }

    .wishlist-view-page .toast {
        top: 16px;
        max-width: calc(100vw - 24px);
    }

    .profile-page .toast {
        top: 16px;
        max-width: calc(100vw - 24px);
    }

}

.support-card h2,
.support-section-heading h2 {
    margin: 0 0 14px;
    font-size: 28px;
    line-height: 1.15;
}

.support-card > * + *,
.support-platform > * + * {
    margin-top: 14px;
}

.support-link-list {
    display: grid;
    gap: 14px;
    margin-top: 18px;
}

.support-link-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 18px 20px;
    border-radius: 20px;
    background: var(--color-chip-soft);
    border: 1px solid rgba(79, 96, 129, 0.22);
    transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.support-link-card:hover,
.support-link-card:focus-visible {
    transform: translateY(-2px);
    background: var(--color-chip-strong);
    box-shadow: var(--shadow-soft);
}

.support-link-card__content {
    display: grid;
    gap: 4px;
}

.support-link-card__label {
    font-size: 17px;
    font-weight: 700;
    color: #243148;
}

.support-link-card__meta {
    color: var(--color-text-muted);
    font-size: 14px;
    line-height: 1.5;
}

.support-link-card__arrow {
    flex: 0 0 auto;
    font-size: 28px;
    line-height: 1;
    color: #3b537a;
}

.support-contact-list {
    display: grid;
    gap: 12px;
    margin-top: 18px;
}

.support-contact-link {
    display: inline-flex;
    align-items: center;
    min-height: 52px;
    padding: 0 18px;
    border-radius: 16px;
    background: var(--color-surface-raised);
    border: 1px solid rgba(79, 96, 129, 0.22);
    font-weight: 700;
}

.support-section-heading {
    display: grid;
    gap: 10px;
}

.support-faq-list {
    display: grid;
    gap: 14px;
}

.support-faq-item {
    padding: 20px 22px;
    border-radius: 22px;
}

.support-faq-item summary {
    cursor: pointer;
    list-style: none;
    font-size: 18px;
    font-weight: 700;
    color: #243148;
}

.support-faq-item summary::-webkit-details-marker {
    display: none;
}

.support-faq-item p {
    margin-top: 14px;
}

.support-platforms {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.support-platform {
    padding: 20px;
    border-radius: 22px;
    background: var(--color-surface-raised);
    border: 1px solid rgba(79, 96, 129, 0.18);
    box-shadow: inset 0 1px 0 rgba(255, 248, 240, 0.48);
}

.support-platform__title {
    font-size: 20px;
    font-weight: 700;
    color: #243148;
}

.privacy-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(280px, 360px);
    gap: 24px;
    align-items: start;
}

.privacy-main-card,
.privacy-aside-card {
    border-radius: var(--radius-lg);
}

.privacy-main-card {
    padding: 30px;
}

.privacy-main-card > * + * {
    margin-top: 28px;
}

.privacy-section h2,
.privacy-aside-card h2 {
    margin: 0 0 14px;
    font-size: 28px;
    line-height: 1.15;
}

.privacy-section p,
.privacy-fact p {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 16px;
    line-height: 1.7;
}

.privacy-list {
    margin: 0;
    padding-left: 22px;
    color: var(--color-text-muted);
    font-size: 16px;
    line-height: 1.7;
}

.privacy-list li + li {
    margin-top: 8px;
}

.privacy-aside {
    position: sticky;
    top: 24px;
}

.privacy-aside-card {
    padding: 26px;
}

.privacy-facts {
    display: grid;
    gap: 18px;
}

.privacy-fact {
    padding: 18px 20px;
    border-radius: 20px;
    background: var(--color-surface-raised);
    border: 1px solid rgba(79, 96, 129, 0.18);
    box-shadow: inset 0 1px 0 rgba(255, 248, 240, 0.48);
}

.privacy-fact strong {
    display: block;
    margin-bottom: 8px;
    font-size: 16px;
    color: #243148;
}

.privacy-inline-link {
    color: var(--color-link);
    font-weight: 700;
}

.reset-page {
    display: flex;
    justify-content: center;
}

.reset-card {
    width: 100%;
    padding: 32px;
    border-radius: var(--radius-xl);
    border: 1px solid var(--color-surface-border);
    background: var(--color-bg-surface);
    box-shadow: var(--shadow-card);
}

.reset-title {
    margin: 16px 0 12px;
    font-size: clamp(34px, 5vw, 52px);
    line-height: 1.02;
}

.reset-text {
    margin: 0 0 22px;
    color: var(--color-text-muted);
    font-size: 16px;
    line-height: 1.65;
}

.status-box {
    margin-bottom: 16px;
    padding: 14px 16px;
    border-radius: 14px;
    border: 1px solid transparent;
    font-size: 14px;
    line-height: 1.5;
}

.status-box--success {
    background: rgba(95, 174, 83, 0.12);
    border-color: rgba(47, 138, 70, 0.18);
    color: var(--color-success);
}

.status-box--error {
    background: rgba(217, 54, 62, 0.1);
    border-color: rgba(199, 59, 74, 0.18);
    color: var(--color-danger);
}

.status-page__main {
    display: flex;
    justify-content: center;
}

.status-card {
    width: 100%;
    padding: 32px;
    border-radius: var(--radius-xl);
    border: 1px solid var(--color-surface-border);
    background: var(--color-bg-surface);
    box-shadow: var(--shadow-card);
    text-align: center;
}

.status-card--left {
    text-align: left;
}

.status-card__code {
    margin: 18px 0 12px;
    font-size: clamp(64px, 9vw, 120px);
    line-height: 0.9;
    color: #243148;
}

.status-card__title {
    margin: 0;
    font-size: clamp(32px, 5vw, 48px);
    line-height: 1.05;
}

.status-card__text {
    margin: 14px 0 0;
    color: var(--color-text-muted);
    font-size: 16px;
    line-height: 1.7;
}

.status-card__actions {
    display: flex;
    justify-content: center;
    gap: 14px;
    margin-top: 24px;
}

.status-card__actions--stack {
    align-items: flex-start;
    flex-direction: column;
}

.status-card__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 56px;
    padding: 0 24px;
    border-radius: 16px;
    font-size: 15px;
    font-weight: 700;
}

.status-card__support-link {
    color: var(--color-link);
    font-weight: 700;
}

.auth-form--standalone {
    display: flex;
}

.reservations-page-main,
.reservations-book-page-main {
    gap: 18px;
}

.reservations-overview {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(240px, 0.36fr) minmax(240px, 0.36fr);
    gap: 16px;
}

.reservations-hero-card {
    min-height: 100%;
    grid-template-columns: minmax(0, 1fr);
}

.reservations-hero-card__spotlight {
    min-height: 100%;
}

.reservations-spotlight-card {
    min-height: 100%;
}

.reservations-spotlight-card__value {
    font-size: clamp(34px, 4vw, 52px);
    line-height: 0.95;
}

.reservations-overview-card {
    align-content: center;
    justify-items: center;
    text-align: center;
    position: relative;
    padding-top: 64px;
}

.reservations-overview-card strong {
    font-size: clamp(42px, 4.4vw, 64px);
    line-height: 0.92;
}

.reservations-overview-card p {
    max-width: 26ch;
}

.reservations-overview-card .profile-summary-card__label {
    position: absolute;
    top: 20px;
    left: 20px;
}

.reservations-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.reservations-card {
    gap: 16px;
}

.reservations-card--high {
    background:
        radial-gradient(circle at top left, rgba(207, 92, 76, 0.14), transparent 38%),
        linear-gradient(180deg, rgba(255, 252, 250, 0.98) 0%, rgba(244, 248, 253, 0.98) 100%);
}

.reservations-card--medium {
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.12), transparent 38%),
        linear-gradient(180deg, rgba(255, 253, 249, 0.98) 0%, rgba(241, 246, 253, 0.98) 100%);
}

.reservations-card--low {
    background:
        radial-gradient(circle at top left, rgba(74, 150, 110, 0.12), transparent 38%),
        linear-gradient(180deg, rgba(252, 255, 252, 0.98) 0%, rgba(241, 246, 253, 0.98) 100%);
}

.reservations-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.04em;
    white-space: nowrap;
}

.reservations-status--active {
    background: rgba(74, 150, 110, 0.14);
    color: #1f7a47;
}

.reservations-status--gifted {
    background: rgba(65, 100, 154, 0.14);
    color: #284873;
}

.reservations-status--archived {
    background: rgba(107, 116, 132, 0.14);
    color: #5b6676;
}

.reservations-card__meta,
.reservations-card__details,
.reservations-card__actions,
.reservations-book-form,
.reservations-book-layout {
    display: grid;
    gap: 14px;
}

.reservations-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 18px;
}

.reservations-card__meta-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0 13px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.76);
    border: 1px solid rgba(79, 96, 129, 0.18);
    color: var(--color-link);
    font-size: 13px;
    font-weight: 700;
}

.reservations-card__meta-pill--priority {
    color: var(--color-text-main);
}

.reservations-card__meta-pill--link:hover {
    color: #243148;
}

.reservations-card__details {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    padding: 14px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.62);
    border: 1px solid rgba(79, 96, 129, 0.16);
    margin-top: 14px;
}

.reservations-card__details > div {
    display: grid;
    gap: 4px;
}

.reservations-card__label {
    color: var(--color-text-muted);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.reservations-card__wishlist-link {
    color: var(--color-link);
    font-weight: 700;
}

.reservations-card__actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 16px;
}

.reservations-card__actions form {
    min-width: 0;
}

.reservations-action-button,
.reservations-action-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 50px;
    padding: 0 18px;
    border-radius: 16px;
    border: 1px solid transparent;
    font-size: 15px;
    font-weight: 700;
    line-height: 1.2;
    text-align: center;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.reservations-action-button {
    cursor: pointer;
    font-family: inherit;
}

.reservations-action-button:hover,
.reservations-action-link:hover {
    transform: translateY(-1px);
}

.reservations-action-button--primary {
    background: var(--color-action-primary-gradient);
    color: #fff;
    border-color: rgba(74, 103, 159, 0.44);
    box-shadow: 0 10px 22px rgba(45, 67, 106, 0.14);
}

.reservations-action-button--danger {
    background: linear-gradient(180deg, rgba(255, 247, 244, 0.98) 0%, rgba(255, 236, 231, 0.98) 100%);
    color: #a03b30;
    border-color: rgba(173, 71, 61, 0.22);
}

.reservations-action-link {
    background: rgba(255, 255, 255, 0.78);
    color: var(--color-link);
    border-color: rgba(79, 96, 129, 0.2);
}

.reservations-empty-card {
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.12), transparent 42%),
        linear-gradient(180deg, rgba(255, 253, 249, 0.98) 0%, rgba(241, 246, 253, 0.98) 100%);
}

.reservations-book-layout {
    grid-template-columns: minmax(0, 1.35fr) minmax(280px, 0.78fr);
    align-items: start;
    gap: 18px;
}

.reservations-book-hero,
.reservations-book-form-card,
.reservations-book-item-card {
    min-height: 100%;
}

.reservations-book-stage,
.reservations-book-main,
.reservations-book-sidebar {
    display: grid;
    gap: 18px;
}

.reservations-book-main {
    align-content: start;
}

.reservations-book-sidebar {
    position: sticky;
    top: 24px;
}

.reservations-book-hero {
    grid-template-columns: minmax(0, 1fr);
}

.reservations-book-form-card {
    gap: 18px;
}

.reservations-book-form-card__head {
    display: grid;
    gap: 10px;
}

.reservations-book-form-card__intro {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 15px;
    line-height: 1.65;
}

.reservations-book-field {
    display: grid;
    gap: 10px;
}

.reservations-book-field span {
    font-size: 14px;
    font-weight: 700;
    color: var(--color-text-main);
}

.reservations-book-field input[type="date"] {
    width: 100%;
    min-height: 54px;
    padding: 0 16px;
    border-radius: 16px;
    border: 1px solid rgba(79, 96, 129, 0.22);
    background: rgba(255, 255, 255, 0.84);
    color: var(--color-text-main);
    font: inherit;
}

.reservations-book-toggle {
    background: rgba(255, 255, 255, 0.62);
}

.reservations-book-toggle input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.reservations-book-date-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 14px;
}

.reservations-book-hint {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 14px;
    line-height: 1.6;
}

.reservations-book-side-card {
    gap: 12px;
}

.reservations-book-side-card--accent {
    background:
        radial-gradient(circle at top right, rgba(198, 132, 55, 0.18), transparent 38%),
        linear-gradient(180deg, rgba(255, 252, 247, 0.98) 0%, rgba(241, 246, 253, 0.98) 100%);
}

.reservations-book-form__actions {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 180px;
    gap: 12px;
    margin-top: 4px;
}

.reports-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(280px, 0.78fr);
    align-items: start;
    gap: 18px;
}

.reports-main,
.reports-sidebar,
.reports-stage {
    display: grid;
    gap: 18px;
}

.reports-sidebar {
    position: sticky;
    top: 24px;
}

.reports-hero-card,
.reports-form-card,
.reports-side-card {
    min-height: 100%;
}

.reports-form-card {
    gap: 20px;
}

.reports-form {
    display: grid;
    gap: 22px;
}

.reports-form__grid {
    display: grid;
    gap: 18px;
}

.reports-select-wrap {
    position: relative;
    display: block;
}

.reports-select-wrap::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 18px;
    width: 10px;
    height: 10px;
    border-right: 2px solid #5d6a7f;
    border-bottom: 2px solid #5d6a7f;
    transform: translateY(-60%) rotate(45deg);
    pointer-events: none;
}

.reports-select {
    width: 100%;
    min-height: 50px;
    padding: 14px 44px 14px 16px;
    border-radius: 16px;
    border: 1px solid var(--color-border-soft);
    background: var(--color-bg-surface-input);
    box-shadow: inset 0 1px 0 rgba(255, 248, 240, 0.36);
    color: var(--color-text-main);
    font-size: 15px;
    appearance: none;
}

.reports-select:focus {
    outline: none;
    border-color: rgba(61, 93, 165, 0.55);
    box-shadow: 0 0 0 3px rgba(51, 75, 136, 0.14);
}

.reports-form__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 16px;
    align-items: center;
}

.reports-side-card {
    gap: 12px;
}

.reports-side-card--accent {
    background:
        radial-gradient(circle at top left, rgba(198, 132, 55, 0.14), transparent 38%),
        linear-gradient(180deg, rgba(255, 253, 249, 0.98) 0%, rgba(241, 246, 253, 0.98) 100%);
}

@media (max-width: 1180px) {
    .reservations-overview,
    .reservations-book-layout {
        grid-template-columns: 1fr;
    }

    .reservations-book-sidebar {
        position: static;
    }
}

@media (max-width: 960px) {
    .reservations-grid,
    .reservations-card__details,
    .reservations-card__actions,
    .reservations-book-date-grid,
    .reservations-book-hero {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .reservations-book-form__actions {
        grid-template-columns: 1fr;
    }
}

.link-like--anchor {
    display: inline-flex;
    align-items: center;
}

@keyframes auth-card-pulse {
    0% {
        transform: scale(1);
        box-shadow: var(--shadow-card);
    }

    35% {
        transform: scale(1.018);
        box-shadow:
            0 0 0 10px rgba(74, 99, 141, 0.08),
            0 0 0 22px rgba(255, 204, 0, 0.10),
            0 20px 48px rgba(45, 67, 106, 0.18);
    }

    100% {
        transform: scale(1);
        box-shadow: var(--shadow-card);
    }
}

.landing-footnote {
    margin: 0;
    text-align: center;
    color: var(--color-text-muted);
    font-size: 14px;
    font-weight: 700;
}

@media (min-width: 761px) {
    .page-shell {
        width: min(1440px, calc(100% - 72px));
        padding: 16px 0 32px;
    }

    .page-shell--narrow {
        width: min(700px, calc(100% - 40px));
    }

    .site-header {
        gap: 18px;
        margin-bottom: 18px;
    }

    .brand {
        font-size: clamp(40px, 4.2vw, 62px);
    }

    .header-nav,
    .hero-actions,
    .final-cta-actions,
    .wishlists-empty-card__tips,
    .wishlists-empty-card__actions,
    .wishlists-alert__actions {
        gap: 10px;
    }

    .header-link,
    .header-button,
    .app-nav__link,
    .profile-pill {
        min-height: 40px;
        padding: 0 14px;
        font-size: 13px;
    }

    .hero-layout {
        grid-template-columns: minmax(0, 1.2fr) minmax(360px, 420px);
        gap: 24px;
    }

    .hero-copy,
    .auth-card,
    .step-card,
    .wishlist-card,
    .feature-card,
    .final-cta-section,
    .support-hero,
    .support-card,
    .support-faq-item,
    .reset-card,
    .status-card,
    .desktop-wishlist-card,
    .wishlists-alert,
    .wishlists-empty-card,
    .wishlist-view-stage__main,
    .wishlist-view-collection,
    .wishlist-view-empty,
    .wishlist-view-archive {
        border-radius: 24px;
    }

    .hero-copy {
        padding: 34px;
    }

    .hero-badge,
    .section-kicker,
    .feature-card__label {
        min-height: 30px;
        padding: 0 12px;
        font-size: 11px;
    }

    .hero-title {
        margin: 18px 0 14px;
        font-size: clamp(44px, 5.2vw, 70px);
    }

    .hero-subtitle,
    .step-card p,
    .final-cta-section p,
    .support-hero__text,
    .support-card p,
    .support-platform p,
    .support-faq-item p,
    .wishlists-alert p,
    .wishlists-empty-card p,
    .desktop-wishlist-card__description,
    .wishlist-view-stage__description {
        font-size: 15px;
        line-height: 1.6;
    }

    .hero-cta,
    .action-btn,
    .oauth-btn {
        min-height: 48px;
        padding: 0 20px;
        font-size: 14px;
    }

    .hero-proof,
    .auth-form__intro,
    .remember-me,
    .consent-field,
    .item-link,
    .item-price,
    .wishlist-desc,
    .link-like {
        font-size: 13px;
    }

    .auth-card {
        padding: 24px;
    }

    .auth-card h2,
    .wishlists-alert strong,
    .wishlists-empty-card h3,
    .desktop-wishlist-card__title {
        font-size: 22px;
    }

    .auth-card__lead,
    .trust-label,
    .desktop-wishlist-owner__name,
    .desktop-wishlist-occasion__copy span:last-child,
    .wishlists-empty-tip strong {
        font-size: 14px;
    }

    .wishlists-empty-card__tips-header strong {
        font-size: 18px;
    }

    .auth-switcher,
    .wishlists-overview-panel {
        padding: 5px;
    }

    .auth-switcher__tab {
        min-height: 40px;
        font-size: 14px;
    }

    .field {
        gap: 6px;
    }

    .field span {
        font-size: 13px;
    }

    .field input {
        min-height: 46px;
        padding: 0 14px;
        font-size: 15px;
    }

    .section-heading h2,
    .final-cta-section h2,
    .wishlists-section__heading h1,
    .wishlists-section__heading h2,
    .support-section-heading h2 {
        font-size: clamp(28px, 3.2vw, 38px);
    }

    .support-hero {
        gap: 18px;
        padding: 28px;
    }

    .support-hero__title {
        font-size: clamp(32px, 4.2vw, 52px);
    }

    .support-highlight,
    .desktop-wishlist-occasion {
        padding: 14px 16px;
    }

    .support-highlight strong,
    .desktop-wishlist-occasion__copy strong,
    .wishlist-view-event-pill strong {
        font-size: 15px;
    }

    .support-card {
        padding: 22px;
    }

    .wishlists-page-main,
    .wishlists-section,
    .wishlist-view-main,
    .wishlist-view-items {
        gap: 12px;
    }

    .wishlists-top-row {
        grid-template-columns: minmax(0, 1fr) 248px;
    }

    .wishlists-alert,
    .wishlists-empty-card {
        padding: 10px 12px;
    }

    .wishlists-alert.wishlists-alert--accent {
        padding-left: 30px;
    }

    .wishlists-empty-tip {
        padding: 14px;
        border-radius: 18px;
    }

    .wishlists-empty-card__primary,
    .wishlists-empty-card__secondary {
        padding: 14px;
        border-radius: 18px;
    }

    .wishlists-stat-card {
        min-height: 72px;
        padding: 8px 6px;
    }

    .wishlists-stat-card strong {
        font-size: 21px;
    }

    .wishlists-section__count {
        min-height: 28px;
        padding: 0 11px;
        margin-left: 6px;
        font-size: 14px;
    }

    .desktop-wishlist-grid {
        gap: 14px;
    }

    .desktop-wishlist-card {
        gap: 12px;
        padding: 16px;
    }

    .desktop-wishlist-card__meta,
    .desktop-wishlist-card__description {
        margin-top: 8px;
    }

    .profile-page-main {
        gap: 12px;
    }

    .profile-hero-card {
        gap: 14px;
        padding: 16px;
    }

    .profile-hero-card__main {
        grid-template-columns: auto minmax(0, 1fr);
        gap: 18px;
        padding: 16px;
    }

    .profile-hero-card__avatar-wrap {
        width: auto;
        max-width: 240px;
    }

    .profile-hero-card__avatar {
        width: 100%;
        height: auto;
        max-height: 240px;
        border-radius: 28px;
    }

    .profile-hero-card__avatar--placeholder {
        font-size: 160px;
    }

    .profile-hero-card__title,
    .profile-summary-card strong,
    .profile-link-card strong {
        font-size: 22px;
    }

    .profile-hero-card__eyebrow,
    .profile-hero-card__handle,
    .profile-hero-card__login-label,
    .profile-link-card__cta,
    .profile-summary-card p,
    .profile-link-card p,
    .profile-summary-stat span {
        font-size: 14px;
    }

    .profile-hero-card__bio {
        font-size: 15px;
        line-height: 1.6;
    }

    .profile-hero-card__bio-box {
        padding: 14px 16px;
        border-radius: 18px;
    }

    .profile-summary-card,
    .profile-summary-stat,
    .profile-link-card {
        padding: 16px;
        border-radius: 20px;
    }

    .profile-summary-stats,
    .profile-link-grid {
        gap: 12px;
    }

    .profile-summary-stat strong {
        font-size: 30px;
    }

    .profile-wishlists-empty-card {
        padding: 18px;
        gap: 14px;
        border-radius: 20px;
        min-height: 200px;
    }

    .profile-wishlists-empty-card__intro {
        gap: 14px;
    }

    .profile-wishlists-empty-card__copy h3 {
        font-size: 22px;
    }

    .profile-wishlists-empty-card__copy p {
        font-size: 14px;
    }

    .profile-wishlists-empty-card__icon {
        width: 56px;
        height: 56px;
        border-radius: 18px;
        font-size: 28px;
    }

    .desktop-wishlist-chip,
    .desktop-wishlist-card__meta span,
    .wishlist-view-summary__meta span,
    .wishlist-view-filter-chip,
    .wishlist-view-card__priority,
    .wishlist-view-card__price,
    .wishlist-view-badge {
        min-height: 32px;
        padding: 0 12px;
        font-size: 12px;
    }

    .wishlist-view-stage__main {
        gap: 16px;
        padding: 26px;
    }

    .wishlist-view-stage__header {
        gap: 20px;
    }

    .wishlist-view-stage__title {
        font-size: clamp(32px, 4vw, 50px);
    }

    .wishlist-view-stage__owner {
        min-height: 36px;
        padding: 0 12px 0 9px;
        font-size: 13px;
    }

    .wishlist-view-stage__owner--self {
        padding: 0 12px;
    }

    .wishlist-view-stage__owner-avatar,
    .wishlist-view-stage__owner-fallback {
        width: 24px;
        height: 24px;
    }

    .wishlist-public-stage__note {
        padding: 18px 20px;
    }

    .wishlist-view-event-pill {
        gap: 12px;
        padding: 14px 16px;
        border-radius: 18px;
    }

    .wishlist-view-event-pill__timer,
    .desktop-wishlist-occasion__timer {
        min-height: 34px;
        padding: 0 12px;
        font-size: 12px;
    }

    .wishlist-view-collection {
        gap: 18px;
        padding: 22px;
    }

    .wishlist-view-collection__header h2 {
        font-size: clamp(26px, 3vw, 36px);
    }

    .wishlist-view-filter-chip {
        min-height: 38px;
        padding: 0 14px;
        font-size: 13px;
    }

    .wishlist-view-list,
    .wishlist-view-card,
    .support-page-main {
        gap: 16px;
    }

    .wishlist-public-promo {
        gap: 28px;
        padding: 26px 28px;
    }

    .reset-card,
    .status-card {
        padding: 26px;
    }

    .status-card__code {
        font-size: clamp(42px, 5vw, 64px);
    }

    .status-card__title {
        font-size: 28px;
    }

    .status-card__text {
        font-size: 15px;
    }
}

@media (max-width: 1180px) {
    .hero-layout,
    .demo-layout,
    .final-cta-section,
    .support-hero,
    .support-grid {
        grid-template-columns: 1fr;
    }

    .auth-shell {
        position: static;
    }

    .demo-items,
    .steps-grid,
    .features-grid,
    .support-platforms {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .wishlists-empty-card {
        grid-template-columns: 1fr;
    }

}

@media (max-width: 1100px) {
    .profile-hero-card {
        grid-template-columns: minmax(0, 1fr) repeat(2, minmax(240px, 280px));
    }

    .profile-hero-card__main {
        grid-column: 1 / -1;
    }
}

@media (max-width: 760px) {
    .page-shell {
        width: min(100% - 24px, 1320px);
        padding-top: 18px;
    }

    .site-header,
    .header-nav,
    .hero-actions,
    .final-cta-actions,
    .links-row,
    .trust-section,
    .demo-items,
    .steps-grid,
    .features-grid {
        grid-template-columns: 1fr;
        flex-direction: column;
    }

    .site-header,
    .header-nav,
    .hero-actions,
    .final-cta-actions {
        align-items: stretch;
    }

    .hero-copy,
    .auth-card,
    .step-card,
    .wishlist-card,
    .feature-card,
    .final-cta-section,
    .support-hero,
    .support-card,
    .support-faq-item,
    .reset-card,
    .status-card {
        padding: 22px;
        border-radius: 22px;
    }

    .brand {
        font-size: 58px;
    }

    .hero-title {
        max-width: none;
        font-size: 48px;
    }

    .section-heading h2,
    .final-cta-section h2,
    .support-card h2,
    .support-section-heading h2 {
        font-size: 32px;
    }

    .links-row {
        justify-content: flex-start;
        align-items: flex-start;
    }

    .status-card__actions {
        flex-direction: column;
        align-items: stretch;
    }

    .status-card__actions--stack {
        align-items: stretch;
    }

    .support-platforms {
        grid-template-columns: 1fr;
    }

    .profile-hero-card,
    .profile-hero-card__main,
    .profile-summary-stats,
    .profile-link-grid {
        grid-template-columns: 1fr;
    }

    .profile-hero-card__avatar-wrap {
        justify-content: flex-start;
        width: 140px;
        max-width: none;
        height: 140px;
    }

    .landing-demo-shell {
        padding: 12px;
        border-radius: 24px;
    }
}

@media (max-width: 900px) {
    .wishlist-public-promo {
        grid-template-columns: minmax(0, 1fr);
    }

    .wishlist-public-promo__actions {
        justify-content: flex-start;
    }
}

@media (max-width: 720px) {
    .wishlist-public-card__actions {
        min-width: 0;
    }
}

.profile-preferences-page-main {
    gap: 18px;
}

.profile-preferences-hero {
    grid-template-columns: minmax(0, 1.2fr) minmax(260px, 320px) minmax(260px, 320px);
}

.profile-preferences-hero__main {
    min-height: 100%;
}

.profile-preferences-hero__main--no-avatar,
.friend-preferences-hero__main--no-avatar {
    grid-template-columns: minmax(0, 1fr);
}

.profile-preferences-hero__avatar-wrap {
    width: 160px;
    max-width: 160px;
    height: 160px;
}

.profile-preferences-legend,
.profile-preferences-links {
    display: grid;
    gap: 10px;
}

.profile-preferences-legend__item {
    display: inline-flex;
    align-items: center;
    min-height: 40px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1px solid rgba(79, 96, 129, 0.18);
    background: rgba(255, 255, 255, 0.74);
    font-size: 14px;
    font-weight: 700;
}

.profile-preferences-legend__item--like {
    color: #1f7a47;
}

.profile-preferences-legend__item--dislike {
    color: #a03b30;
}

.profile-preferences-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(260px, 320px);
    gap: 18px;
    align-items: start;
}

.profile-preferences-card,
.profile-preferences-aside {
    min-width: 0;
}

.profile-preferences-aside {
    display: grid;
    gap: 18px;
    position: sticky;
    top: 24px;
}

.profile-preferences-card {
    padding: 24px;
}

.profile-preferences-toolbar {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 20px;
    position: sticky;
    top: 16px;
    z-index: 8;
    padding: 16px;
    border-radius: 20px;
    background: rgba(247, 250, 254, 0.94);
    border: 1px solid rgba(79, 96, 129, 0.12);
    box-shadow: 0 12px 28px rgba(20, 28, 43, 0.08);
    backdrop-filter: blur(14px);
}

.profile-preferences-search {
    display: grid;
    gap: 10px;
    flex: 1 1 420px;
}

.profile-preferences-search__label {
    color: var(--color-text-muted);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.profile-preferences-search__input {
    width: 100%;
    min-height: 56px;
    padding: 0 18px;
    border-radius: 18px;
    border: 1px solid rgba(79, 96, 129, 0.18);
    background: rgba(255, 255, 255, 0.9);
    color: var(--color-text-main);
    font-size: 16px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.profile-preferences-search__input:focus {
    outline: none;
    border-color: rgba(65, 100, 154, 0.42);
    box-shadow: 0 0 0 4px rgba(65, 100, 154, 0.12);
}

.profile-preferences-save {
    align-self: end;
    min-width: 240px;
    position: sticky;
    top: 32px;
}

.profile-preferences-list {
    display: grid;
    gap: 12px;
}

.profile-preferences-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 16px 18px;
    border-radius: 20px;
    border: 1px solid rgba(79, 96, 129, 0.16);
    background: rgba(255, 255, 255, 0.72);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

.profile-preferences-row__main {
    display: grid;
    gap: 4px;
    min-width: 0;
}

.profile-preferences-row__title {
    font-size: 18px;
    line-height: 1.35;
    color: #243148;
}

.profile-preferences-row__hint {
    color: var(--color-text-muted);
    font-size: 14px;
    line-height: 1.5;
}

.profile-preferences-row__actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 0 0 auto;
}

.profile-preferences-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    border: 1px solid rgba(79, 96, 129, 0.18);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.92);
    font-size: 24px;
    cursor: pointer;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.profile-preferences-toggle:hover,
.profile-preferences-toggle:focus-visible {
    transform: translateY(-1px);
    outline: none;
    box-shadow: var(--shadow-soft);
}

.profile-preferences-toggle--like.active {
    background: rgba(95, 174, 83, 0.14);
    border-color: rgba(47, 138, 70, 0.26);
}

.profile-preferences-toggle--dislike.active {
    background: rgba(217, 54, 62, 0.12);
    border-color: rgba(199, 59, 74, 0.24);
}

.profile-preferences-row .likes-checkbox,
.profile-preferences-row .dislikes-checkbox {
    display: none;
}

.profile-preferences-empty {
    margin-top: 16px;
    padding: 16px 18px;
    border-radius: 18px;
    border: 1px dashed rgba(79, 96, 129, 0.24);
    color: var(--color-text-muted);
    background: rgba(255, 255, 255, 0.62);
}

.friend-preferences-hero {
    grid-template-columns: minmax(0, 1.2fr) minmax(260px, 320px) minmax(260px, 320px);
}

.friend-preferences-layout {
    grid-template-columns: minmax(0, 1fr) minmax(260px, 320px);
}

.friend-preferences-card {
    min-width: 0;
}

.friend-preferences-toolbar {
    align-items: end;
}

.friend-preferences-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-self: end;
}

.friend-preferences-filter {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 0 18px;
    border: 1px solid rgba(79, 96, 129, 0.18);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.92);
    color: var(--color-link);
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.friend-preferences-filter:hover,
.friend-preferences-filter:focus-visible {
    transform: translateY(-1px);
    outline: none;
    box-shadow: var(--shadow-soft);
}

.friend-preferences-filter.is-active {
    border-color: rgba(65, 100, 154, 0.28);
    background: rgba(65, 100, 154, 0.12);
}

.friend-preferences-sections {
    display: grid;
    gap: 18px;
}

.friend-preferences-section {
    display: grid;
    gap: 14px;
}

.friend-preferences-section__heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.friend-preferences-section__heading h3 {
    margin: 0;
    font-size: 22px;
    line-height: 1.2;
    color: #243148;
}

.friend-preferences-section__heading span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    min-height: 40px;
    padding: 0 14px;
    border-radius: 999px;
    background: rgba(47, 63, 93, 0.1);
    color: var(--color-link);
    font-size: 14px;
    font-weight: 700;
}

.friend-preferences-row {
    align-items: flex-start;
}

.friend-preferences-row__meta {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 0 0 auto;
}

.friend-preferences-row__badge {
    display: inline-flex;
    align-items: center;
    min-height: 36px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1px solid rgba(79, 96, 129, 0.16);
    background: rgba(255, 255, 255, 0.88);
    color: var(--color-link);
    font-size: 13px;
    font-weight: 700;
    white-space: nowrap;
}

.friend-preferences-row__badge--common,
.friend-preferences-legend__item--common {
    background: rgba(255, 188, 99, 0.16);
    border-color: rgba(198, 132, 55, 0.22);
    color: #8a5418;
}

.friend-preferences-row__emoji {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    border-radius: 18px;
    font-size: 24px;
    border: 1px solid rgba(79, 96, 129, 0.18);
    background: rgba(255, 255, 255, 0.92);
}

.friend-preferences-row__emoji--like {
    background: rgba(95, 174, 83, 0.14);
    border-color: rgba(47, 138, 70, 0.26);
}

.friend-preferences-row__emoji--dislike {
    background: rgba(217, 54, 62, 0.12);
    border-color: rgba(199, 59, 74, 0.24);
}

@media (max-width: 1100px) {
    .profile-preferences-hero,
    .profile-preferences-layout,
    .friend-preferences-hero,
    .friend-preferences-layout {
        grid-template-columns: 1fr;
    }

    .profile-preferences-aside {
        position: static;
        top: auto;
    }

    .notification-settings-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .profile-preferences-card {
        padding: 18px;
    }

    .profile-preferences-toolbar {
        top: 12px;
        padding: 14px;
    }

    .profile-preferences-save {
        width: 100%;
        min-width: 0;
        top: 0;
    }

    .profile-preferences-row {
        flex-direction: column;
        align-items: flex-start;
    }

    .notification-settings-toolbar {
        align-items: stretch;
        flex-direction: column;
    }

    .notification-settings-toolbar__actions {
        justify-content: stretch;
    }

    .notification-settings-toolbar__button {
        width: 100%;
        justify-content: center;
    }

    .notification-setting-card {
        padding: 18px;
    }

    .notification-channel-toggle {
        min-height: 64px;
    }

    .friend-preferences-row__meta {
        width: 100%;
        justify-content: space-between;
    }

    .friend-preferences-filter {
        flex: 1 1 140px;
    }

    .profile-preferences-row__actions {
        width: 100%;
        justify-content: flex-start;
    }
}

/* Palette normalization: keep the desktop-specific layouts, but reuse the main picklist.ru color language. */
.landing-demo-shell,
.wishlist-card--cover,
.events-hero-card,
.events-summary-card--accent,
.events-my-alert,
.events-my-card--create,
.profile-hero-card__main,
.profile-summary-card,
.profile-summary-card--stats,
.profile-edit-form-card,
.friend-action-panel--hero,
.profile-page .wishitem-image-crop-card,
.profile-modal__dialog {
    background:
        radial-gradient(120% 120% at 0% 0%, rgba(255, 188, 99, 0.08) 0%, rgba(255, 188, 99, 0) 55%),
        radial-gradient(110% 120% at 100% 0%, rgba(79, 110, 183, 0.08) 0%, rgba(79, 110, 183, 0) 60%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(247, 249, 253, 0.96) 100%);
}

.events-spotlight-card,
.events-empty-panel,
.events-spotlight-card__avatar,
.events-upcoming-card__avatar,
.events-upcoming-card__avatar--placeholder,
.events-spotlight-card__avatar--placeholder,
.events-calendar-day,
.profile-hero-card__avatar,
.profile-hero-card__avatar--placeholder,
.profile-hero-card__bio-box,
.profile-public-link,
.profile-summary-stat,
.profile-page .wishitem-image-crop-close,
.avatar-crop-page .avatar-crop-overlay-card,
.profile-page .avatar-crop-overlay-card,
.profile-settings-modal__section,
.profile-friends-search,
.profile-friends-modal-section,
.profile-friends-blocked-link,
.profile-notifications-section,
.profile-notifications-mark-all,
.profile-notification-card,
.friend-profile-status-pill {
    border-color: rgba(208, 217, 233, 0.82);
    background: rgba(255, 255, 255, 0.82);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.events-calendar-item,
.events-calendar-item--birthday,
.profile-summary-stat--alert,
.friend-profile-status-pill--success,
.friend-profile-status-pill--accent {
    border-color: rgba(208, 217, 233, 0.82);
}

.events-calendar-item {
    background: rgba(240, 244, 255, 0.82);
}

.events-calendar-item--birthday,
.friend-profile-status-pill--accent {
    background: linear-gradient(180deg, rgba(255, 244, 218, 0.96) 0%, rgba(255, 250, 236, 0.92) 100%);
}

.profile-summary-stat--alert {
    background: rgba(240, 244, 255, 0.82);
}

.friend-profile-status-pill--success {
    background: rgba(220, 255, 220, 0.75);
    color: #1e7e34;
}

.landing-demo-owner,
.events-spotlight-card__timer,
.events-upcoming-card__timer,
.events-calendar-day__count,
.profile-hero-card__eyebrow,
.friend-action-panel__label {
    background: rgba(51, 51, 51, 0.08);
    color: var(--color-link);
}

.landing-demo-owner__avatar,
.events-calendar-day--today,
.event-access-card.is-selected,
.event-friend-card.is-selected {
    border-color: rgba(89, 105, 139, 0.45);
    box-shadow: 0 0 0 3px rgba(87, 117, 184, 0.12), 0 8px 16px rgba(53, 81, 141, 0.08);
}

.landing-demo-owner__avatar,
.event-access-card.is-selected,
.event-friend-card.is-selected,
.events-upcoming-card__avatar--placeholder,
.events-spotlight-card__avatar--placeholder,
.profile-hero-card__avatar--placeholder,
.profile-edit-avatar-trigger__image--placeholder {
    background:
        radial-gradient(120% 120% at 0% 0%, rgba(255, 199, 93, 0.12) 0%, rgba(255, 199, 93, 0) 58%),
        radial-gradient(95% 120% at 100% 0%, rgba(71, 122, 255, 0.1) 0%, rgba(71, 122, 255, 0) 60%),
        linear-gradient(170deg, rgba(255, 255, 255, 0.9) 0%, rgba(248, 250, 255, 0.8) 100%);
}

.event-access-card::before,
.event-friend-card::before {
    background: var(--color-action-primary-gradient);
}

.event-access-card::after,
.event-friend-card::after,
.profile-notifications-mark-all,
.profile-page .wishitem-image-crop-close,
.profile-modal__close {
    background: rgba(255, 255, 255, 0.82);
    color: var(--color-link);
}

.landing-demo-menu-item {
    cursor: default;
}

.landing-demo-menu-item:hover,
.landing-demo-menu-item:focus-visible {
    background: transparent;
    box-shadow: none;
}

.event-danger-zone,
.friend-action-panel__danger,
.profile-hero-card__logout,
.profile-friends-search-note--warning {
    border-color: rgba(205, 86, 99, 0.36);
}

.event-danger-zone,
.friend-action-panel__danger,
.profile-hero-card__logout {
    background: linear-gradient(180deg, rgba(255, 244, 246, 0.98) 0%, rgba(255, 233, 236, 0.96) 100%);
}

.event-danger-zone__copy strong,
.event-danger-zone__button,
.friend-action-panel__danger,
.profile-hero-card__logout,
.profile-friends-search-note--warning {
    color: #8f262c;
}

.event-danger-zone__copy p {
    color: #6b5058;
}

.profile-form-notice--success {
    background: #d3f9d8;
    color: #1e7e34;
}

.profile-form-notice--error {
    background: #ffe3e3;
    color: #c92a2a;
}

.profile-friends-modal-card__avatar--placeholder,
.profile-wishlists-empty-card__icon,
.profile-friend-card__avatar--placeholder {
    background:
        radial-gradient(120% 120% at 0% 0%, rgba(255, 199, 93, 0.12) 0%, rgba(255, 199, 93, 0) 58%),
        radial-gradient(95% 120% at 100% 0%, rgba(71, 122, 255, 0.1) 0%, rgba(71, 122, 255, 0) 60%),
        linear-gradient(170deg, rgba(255, 255, 255, 0.9) 0%, rgba(248, 250, 255, 0.8) 100%);
}

.profile-wishlists-empty-card,
.profile-friend-card,
.profile-friend-card--cta,
.reservations-empty-card,
.reservations-book-side-card--accent {
    background:
        radial-gradient(120% 120% at 0% 0%, rgba(255, 188, 99, 0.08) 0%, rgba(255, 188, 99, 0) 55%),
        radial-gradient(110% 120% at 100% 0%, rgba(79, 110, 183, 0.08) 0%, rgba(79, 110, 183, 0) 60%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(247, 249, 253, 0.96) 100%);
}

.profile-friend-card__alert-badge {
    background: var(--color-danger);
    box-shadow: 0 10px 18px rgba(217, 54, 62, 0.2);
}

.wishlists-alert--accent,
.reservations-action-button--danger,
.profile-friends-modal-action--danger {
    border-color: rgba(205, 86, 99, 0.36);
    background: linear-gradient(180deg, rgba(255, 244, 246, 0.98) 0%, rgba(255, 233, 236, 0.96) 100%);
    color: #8f262c;
}

.reservations-card--high,
.reservations-card--medium,
.reservations-card--low {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(247, 249, 253, 0.96) 100%);
}

.reservations-status--active {
    background: rgba(220, 255, 220, 0.75);
    color: #1e7e34;
}

.reservations-status--gifted {
    background: rgba(240, 244, 255, 0.82);
    color: #3f557d;
}

.reservations-status--archived {
    background: rgba(241, 243, 245, 0.9);
    color: #5c667a;
}

.reservations-card__meta-pill,
.reservations-card__details,
.reservations-action-link,
.reservations-book-field input[type="date"],
.reservations-book-toggle {
    border-color: rgba(208, 217, 233, 0.82);
    background: rgba(255, 255, 255, 0.82);
}

.profile-preferences-search__input:focus {
    border-color: rgba(87, 117, 184, 0.45);
    box-shadow: 0 0 0 3px rgba(87, 117, 184, 0.12);
}

@media (max-width: 900px) {
    .feedback-overview {
        grid-template-columns: minmax(0, 1fr);
    }
}

.yandex-metrika-noscript {
    position: absolute;
    left: -9999px;
}

.onboarding-main {
    display: grid;
    gap: 28px;
    padding: 36px 0 72px;
}

.onboarding-hero-card,
.onboarding-steps-card,
.onboarding-side-card,
.onboarding-inline-panel {
    border: 1px solid rgba(208, 217, 233, 0.82);
    border-radius: 28px;
    background:
        radial-gradient(120% 120% at 0% 0%, rgba(255, 188, 99, 0.08) 0%, rgba(255, 188, 99, 0) 55%),
        radial-gradient(110% 120% at 100% 0%, rgba(79, 110, 183, 0.08) 0%, rgba(79, 110, 183, 0) 60%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(247, 249, 253, 0.96) 100%);
    box-shadow: 0 24px 60px rgba(28, 41, 69, 0.12);
}

.onboarding-hero-card {
    padding: 36px;
}

.onboarding-hero-card__title {
    margin: 10px 0 12px;
    font-size: clamp(2rem, 3vw, 3.2rem);
    line-height: 1.05;
}

.onboarding-hero-card__text {
    max-width: 760px;
    margin: 0;
    color: var(--color-text-secondary);
    font-size: 1.05rem;
    line-height: 1.65;
}

.onboarding-hero-card__status {
    margin-top: 18px;
}

.onboarding-progress-panel {
    margin-top: 28px;
    display: grid;
    gap: 14px;
}

.onboarding-progress-panel__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.onboarding-progress-panel__head strong,
.onboarding-progress-panel__head span,
.onboarding-inline-panel__progress,
.onboarding-step-card__status {
    font-weight: 700;
}

.onboarding-progress-panel__head strong {
    display: block;
    color: var(--color-text-primary);
}

.onboarding-progress-panel__head span {
    color: var(--color-text-secondary);
}

.onboarding-progress-bar {
    width: 100%;
    height: 10px;
    border-radius: 999px;
    background: rgba(217, 226, 240, 0.9);
    overflow: hidden;
}

.onboarding-progress-bar span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, rgba(78, 104, 170, 1) 0%, rgba(116, 142, 206, 1) 100%);
}

.onboarding-progress-panel__cta {
    justify-self: start;
}

.onboarding-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.9fr) minmax(300px, 0.95fr);
    gap: 24px;
    align-items: start;
}

.onboarding-steps-card,
.onboarding-side-card {
    padding: 28px;
}

.onboarding-step-list {
    display: grid;
    gap: 14px;
}

.onboarding-step-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 16px;
    align-items: start;
    padding: 18px 20px;
    border-radius: 22px;
    border: 1px solid rgba(208, 217, 233, 0.82);
    background: rgba(255, 255, 255, 0.74);
    text-decoration: none;
    color: inherit;
}

.onboarding-step-card:hover,
.onboarding-step-card:focus-visible {
    border-color: rgba(103, 128, 192, 0.42);
    box-shadow: 0 18px 34px rgba(30, 41, 59, 0.1);
}

.onboarding-step-card.is-current,
.onboarding-inline-panel--highlighted {
    border-color: rgba(103, 128, 192, 0.42);
    box-shadow: 0 18px 34px rgba(30, 41, 59, 0.1);
}

.onboarding-step-card.is-done .onboarding-step-card__status {
    color: #20744d;
}

.onboarding-step-card__index {
    width: 42px;
    height: 42px;
    border-radius: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(78, 104, 170, 0.12);
    color: #304e89;
    font-weight: 800;
}

.onboarding-step-card__copy {
    display: grid;
    gap: 4px;
}

.onboarding-step-card__copy strong {
    font-size: 1.05rem;
}

.onboarding-step-card__copy span,
.onboarding-side-card p,
.onboarding-inline-panel__copy p {
    color: var(--color-text-secondary);
    line-height: 1.6;
}

.onboarding-side-card {
    display: grid;
    gap: 16px;
}

.onboarding-side-card__note {
    padding: 14px 16px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.82);
    color: var(--color-text-primary);
    border: 1px solid rgba(208, 217, 233, 0.82);
}

.onboarding-inline-status {
    margin-bottom: 18px;
}

.onboarding-inline-panel {
    display: grid;
    grid-template-columns: minmax(0, 1.7fr) minmax(220px, 0.9fr);
    gap: 18px;
    align-items: center;
    padding: 24px 28px;
    margin-bottom: 24px;
}

.onboarding-inline-panel__copy h2 {
    margin: 6px 0 8px;
    font-size: 1.75rem;
    line-height: 1.15;
}

.onboarding-inline-panel__copy p {
    margin: 0;
}

.onboarding-inline-panel__meta {
    display: grid;
    gap: 12px;
}

.onboarding-inline-panel__progress {
    color: var(--color-text-secondary);
}

.onboarding-inline-panel--wishlist {
    margin-top: 22px;
    margin-bottom: 0;
}

@media (max-width: 980px) {
    .onboarding-layout,
    .onboarding-inline-panel {
        grid-template-columns: minmax(0, 1fr);
    }

    .onboarding-main {
        padding-top: 20px;
    }

    .onboarding-progress-panel__cta {
        justify-self: stretch;
    }
}
