/**
 * Dynamic app shells (favorites, notifications, shop JS output)
 */
.site-ui .favorites-state-card,
.site-ui .notifications-state-card {
    border-radius: 18px;
    border: 1px solid #dfeee4;
    background: #fff;
    box-shadow: 0 16px 42px rgba(23, 32, 51, 0.07);
    padding: 2.5rem 1.5rem;
    text-align: center;
}

.site-ui .favorites-state-card--loading .animate-pulse,
.site-ui .favorites-loading-dot,
.site-ui .notifications-loading-dot {
    background: #e8f4eb !important;
}

.site-ui .favorites-state-card--error {
    border-color: #fecaca;
    background: #fef2f2;
    color: #991b1b;
    text-align: left;
    padding: 1.5rem;
}

.site-ui .favorites-state-card--error h2 {
    margin: 0 0 0.5rem;
    font-size: 1.35rem;
}

.site-ui .favorites-state-card .mb-btn,
.site-ui .notifications-state-card .mb-btn {
    min-height: 44px;
    margin-top: 0.75rem;
}

.site-ui #favorites-app .rounded-2xl.border.border-gray-100 {
    border-radius: 18px !important;
    border-color: #dfeee4 !important;
    box-shadow: 0 16px 42px rgba(23, 32, 51, 0.07) !important;
}

.site-ui.shop-page #product-grid > .shop-empty-state,
.site-ui.shop-page #product-grid > div.sm\:col-span-2 {
    grid-column: 1 / -1;
    border-radius: var(--mb-radius-lg, 16px);
    border: 1px dashed #cbd5e1;
    background: #f8fafc;
    padding: 2rem 1.5rem;
    text-align: center;
}

.site-ui.shop-page #category-filters button {
    border-radius: 10px;
    transition: background 0.15s ease, color 0.15s ease;
}

.site-ui.shop-page #category-filters button.text-blue-600,
.site-ui.shop-page #category-filters button.font-semibold {
    background: #eff6ff;
    color: #1d4ed8 !important;
}

.site-ui.shop-page aside .bg-white.p-5 {
    border-radius: var(--mb-radius-lg, 16px) !important;
    border-color: var(--mb-line, #d8e6f7) !important;
    box-shadow: var(--mb-shadow-sm) !important;
}

.site-ui.shop-page main > section.rounded-xl {
    border-radius: var(--mb-radius-lg, 16px) !important;
    border-color: #bbf7d0 !important;
    background: #f0fdf4 !important;
}

.site-ui.notifications-page #reminders-app .reminder-form-grid {
    gap: 0.85rem;
}

.site-ui.notifications-page #reminders-app .reminder-card {
    border-radius: 14px;
    border: 1px solid #dfeee4;
    transition: box-shadow 0.15s ease, border-color 0.15s ease;
}

.site-ui.notifications-page #reminders-app .reminder-card:hover {
    box-shadow: var(--mb-shadow-sm);
    border-color: #bbf7d0;
}

.site-ui.notifications-page .notifications-hero {
    margin-bottom: 1.25rem;
    background: linear-gradient(180deg, #eff6ff 0%, #f8fafc 45%, #ffffff 100%);
    border-bottom: 1px solid #e2e8f0;
}

.site-ui.notifications-page .notifications-hero h1 {
    letter-spacing: -0.02em;
    color: var(--mb-navy, #172033);
}

.site-ui.notifications-page .notifications-hero .notification-count-chip {
    display: inline-flex;
    align-items: center;
    margin: 0;
    padding: 0.45rem 0.95rem;
    border-radius: 999px;
    background: #ffffff;
    border: 1px solid rgba(255, 255, 255, 0.95);
    color: #166534;
    font-size: 0.875rem;
    font-weight: 800;
    box-shadow: 0 4px 16px rgba(15, 23, 42, 0.14);
}

.site-ui.notifications-page .notifications-hero .notification-soon-chip {
    display: inline-flex;
    align-items: center;
    padding: 0.45rem 0.95rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.14);
    border: 1px solid rgba(255, 255, 255, 0.32);
    color: #e0f2fe;
    font-size: 0.8125rem;
    font-weight: 600;
    text-transform: none;
    letter-spacing: normal;
}

.site-ui.notifications-page .notifications-back-link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.45rem 0.85rem;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.38);
    background: rgba(255, 255, 255, 0.14);
    color: #ffffff;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.site-ui.notifications-page .notifications-back-link:hover {
    background: rgba(255, 255, 255, 0.22);
    border-color: rgba(255, 255, 255, 0.55);
    color: #ffffff;
    text-decoration: none;
}

.site-ui.notifications-page .notifications-badge {
    background: #eff6ff !important;
    color: #1d4ed8 !important;
    border: 1px solid #bfdbfe;
}

.site-ui.notifications-page #reminders-app .reminder-field input,
.site-ui.notifications-page #reminders-app .reminder-field select,
.site-ui.notifications-page #reminders-app .reminder-field textarea {
    min-height: 44px;
    border-radius: 10px;
    border-color: #cbd5e1;
}

.site-ui.notifications-page #reminders-app .reminder-field input:focus,
.site-ui.notifications-page #reminders-app .reminder-field select:focus,
.site-ui.notifications-page #reminders-app .reminder-field textarea:focus {
    outline: none;
    border-color: #93c5fd;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
}

.site-ui.notifications-page #reminders-app .reminder-card {
    border-radius: 14px;
    transition: box-shadow 0.15s ease, border-color 0.15s ease;
}

.site-ui.notifications-page #reminders-app .reminder-card:hover {
    box-shadow: 0 8px 24px rgba(23, 32, 51, 0.08);
}

.site-ui.favorites-page .favorite-list {
    display: grid;
    gap: 1rem;
}

.site-ui.favorites-page .favorite-list > article,
.site-ui.favorites-page .favorite-list > .rounded-xl {
    border-radius: var(--mb-radius-lg, 16px) !important;
    border-color: var(--mb-line, #d8e6f7) !important;
    box-shadow: var(--mb-shadow-sm) !important;
    transition: box-shadow 0.15s ease, border-color 0.15s ease, transform 0.15s ease;
}

.site-ui.favorites-page .favorite-list > article:hover,
.site-ui.favorites-page .favorite-list > .rounded-xl:hover {
    box-shadow: var(--mb-shadow-md) !important;
    border-color: #bfdbfe !important;
    transform: translateY(-1px);
}

.site-ui.favorites-page .favorite-list h3 {
    color: var(--mb-navy, #172033);
    font-size: 1.05rem;
    line-height: 1.3;
}

.site-ui.favorites-page .favorites-empty-state {
    border-radius: var(--mb-radius-lg, 16px) !important;
    border-style: dashed !important;
    border-color: #cfe5d5 !important;
    background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%) !important;
    padding: 2rem 1.5rem !important;
}

.site-ui.favorites-page .favorites-empty-state .mb-btn,
.site-ui.favorites-page .favorites-empty-state a.inline-flex {
    min-height: 44px;
    border-radius: 12px;
    font-weight: 700;
}

.site-ui.favorites-page .favorites-empty-tip {
    border-radius: 12px !important;
    line-height: 1.55;
}

.site-ui.favorites-page .favorites-empty-state .guide-cta-row {
    justify-content: flex-start;
}

.site-ui.favorites-page .favorite-feature-actions .mb-btn {
    min-height: 44px;
}

.site-ui.notifications-page .reminder-actions .mb-btn,
.site-ui.notifications-page .reminder-form-grid .mb-btn,
.site-ui.notifications-page .reminder-card-actions .mb-btn,
.site-ui.notifications-page .reminder-empty-card .mb-btn {
    min-height: 44px;
}

.site-ui.notifications-page .reminder-action-button-delete {
    background: #fef2f2 !important;
    border-color: #fecaca !important;
    color: #b91c1c !important;
}

.site-ui.notifications-page .reminder-action-button-delete:hover {
    background: #fee2e2 !important;
    border-color: #fca5a5 !important;
}

.site-ui.notifications-page .reminder-login-card {
    border-radius: var(--mb-radius-lg, 16px) !important;
}

.site-ui.notifications-page #reminder-message {
    border-radius: 12px;
}

@media (max-width: 900px) {
    .site-ui.favorites-page .favorite-feature-strip {
        grid-template-columns: 1fr !important;
    }

    .site-ui.favorites-page .favorite-feature-actions {
        justify-content: flex-start;
    }
}

.site-ui.favorites-page #favorites-app > .rounded-xl.border.border-green-200,
.site-ui.favorites-page #favorites-app > .rounded-xl.border.border-amber-200,
.site-ui.favorites-page .favorites-account-banner {
    border-radius: 12px !important;
    line-height: 1.55;
}

.site-ui.favorites-page .favorites-account-banner a {
    color: var(--mb-blue, #2563eb);
}

.site-ui.favorites-page .favorites-back-link,
.site-ui.notifications-page .notifications-back-link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.45rem 0.85rem;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.38);
    background: rgba(255, 255, 255, 0.14);
    color: #ffffff;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.site-ui.favorites-page .favorites-back-link:hover,
.site-ui.notifications-page .notifications-back-link:hover {
    background: rgba(255, 255, 255, 0.22);
    border-color: rgba(255, 255, 255, 0.55);
    color: #ffffff;
    text-decoration: none;
}

.site-ui.notifications-page .notifications-hero .notification-count-chip {
    box-shadow: 0 4px 16px rgba(15, 23, 42, 0.14);
}

.site-ui.notifications-page #reminders-app .notification-soon-chip {
    border-radius: 999px;
    padding: 0.35rem 0.75rem;
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    background: #eff6ff;
    color: #1d4ed8;
    border: 1px solid #bfdbfe;
}

.site-ui.notifications-page .notifications-loading-card {
    border-radius: 18px;
    border: 1px solid #dfeee4;
    background: #fff;
    padding: 2.5rem 1.5rem;
    text-align: center;
    box-shadow: 0 16px 42px rgba(23, 32, 51, 0.07);
}

/* Favoritter — beslutningscenter (firebase-decision-center.js) */
.site-ui.favorites-page .favorites-shell {
    overflow-x: hidden;
}

.site-ui.favorites-page .favorite-card {
    border-radius: var(--mb-radius-lg, 16px) !important;
    border-color: var(--mb-line, #d8e6f7) !important;
    box-shadow: var(--mb-shadow-sm) !important;
    transition: box-shadow 0.15s ease, border-color 0.15s ease;
}

.site-ui.favorites-page .favorite-card:hover {
    box-shadow: var(--mb-shadow-md) !important;
    border-color: #bfdbfe !important;
}

.site-ui.favorites-page .favorite-card {
    display: grid;
    gap: 1.25rem;
}

@media (min-width: 960px) {
    .site-ui.favorites-page .favorite-card {
        grid-template-columns: 1fr minmax(260px, 320px);
        align-items: start;
    }
}

.site-ui.favorites-page .favorite-card-top {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 0.65rem;
}

.site-ui.favorites-page .favorite-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}

.site-ui.favorites-page .favorite-title {
    margin: 0 0 0.35rem;
    font-size: 1.2rem;
    color: var(--mb-navy, #172033);
    letter-spacing: -0.02em;
    line-height: 1.3;
}

.site-ui.favorites-page .favorite-address,
.site-ui.favorites-page .favorite-next,
.site-ui.favorites-page .favorite-disclaimer {
    margin: 0.35rem 0 0;
    color: #64748b;
    line-height: 1.55;
    font-size: 0.9rem;
}

.site-ui.favorites-page .favorite-next strong {
    color: #334155;
}

.site-ui.favorites-page .favorite-next a {
    font-weight: 700;
    color: var(--mb-blue, #2563eb);
}

.site-ui.favorites-page .favorite-disclaimer {
    font-size: 0.82rem;
    padding: 0.65rem 0.75rem;
    border-radius: 10px;
    background: #fffbeb;
    border: 1px solid #fde68a;
    color: #92400e;
}

.site-ui.favorites-page .favorite-form-grid {
    display: grid;
    gap: 0.65rem;
}

.site-ui.favorites-page .favorite-field-wide {
    grid-column: 1 / -1;
}

.site-ui.favorites-page .favorite-pill-type {
    background: #eff6ff !important;
    color: #1d4ed8 !important;
    border: 1px solid #bfdbfe;
}

.site-ui.favorites-page .favorite-pill-data {
    background: #f0fdf4 !important;
    color: #166534 !important;
    border: 1px solid #bbf7d0;
}

.site-ui.favorites-page .favorite-remove-button {
    min-height: 40px;
    border-radius: 10px;
    font-weight: 600;
    transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.site-ui.favorites-page .favorite-remove-button:hover {
    background: #fef2f2;
    border-color: #fecaca;
    color: #b91c1c;
}

.site-ui.favorites-page .favorite-pill-data {
    font-size: 0.72rem;
}

.site-ui.favorites-page .favorite-controls {
    border-radius: 12px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    padding: 1rem;
}

.site-ui.favorites-page .favorite-controls-title {
    font-size: 0.82rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: #64748b;
    margin: 0 0 0.65rem;
}

.site-ui.favorites-page .favorite-field input,
.site-ui.favorites-page .favorite-field select,
.site-ui.favorites-page .favorite-field textarea {
    min-height: 42px;
    border-radius: 10px;
    border: 1px solid #cbd5e1;
    width: 100%;
}

.site-ui.favorites-page .favorite-field input:focus,
.site-ui.favorites-page .favorite-field select:focus,
.site-ui.favorites-page .favorite-field textarea:focus {
    outline: none;
    border-color: #93c5fd;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
}

.site-ui.favorites-page .favorite-compare,
.site-ui.favorites-page #favorite-compare {
    margin-top: 1.75rem;
    padding: 1.35rem 1.4rem;
    border-radius: var(--mb-radius-lg, 16px);
    border: 1px solid var(--mb-line, #d8e6f7);
    background: #fff;
    box-shadow: var(--mb-shadow-sm);
}

.site-ui.favorites-page .favorite-compare-header {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: space-between;
    align-items: flex-start;
}

.site-ui.favorites-page .favorite-compare-badge {
    display: inline-flex;
    padding: 0.25rem 0.65rem;
    border-radius: 999px;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    color: #166534;
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.site-ui.favorites-page .favorite-compare-title {
    margin: 0.5rem 0 0;
    font-size: 1.35rem;
    color: var(--mb-navy, #172033);
    letter-spacing: -0.02em;
}

.site-ui.favorites-page .favorite-compare-copy {
    margin: 0.35rem 0 0;
    color: #64748b;
    line-height: 1.55;
    font-size: 0.92rem;
}

.site-ui.favorites-page .favorite-compare-note {
    flex: 1 1 200px;
    max-width: 280px;
    padding: 0.75rem 0.9rem;
    border-radius: 10px;
    background: #fffbeb;
    border: 1px solid #fde68a;
    color: #92400e;
    font-size: 0.82rem;
    line-height: 1.5;
    font-weight: 600;
}

.site-ui.favorites-page .favorite-compare-table-wrap {
    position: relative;
    margin-top: 1rem;
    overflow-x: auto;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    -webkit-overflow-scrolling: touch;
}

@media (max-width: 767px) {
    .site-ui.favorites-page .favorite-compare-table-wrap {
        box-shadow: inset -14px 0 12px -10px rgba(15, 23, 42, 0.08);
    }

    .site-ui.favorites-page .favorite-compare-note {
        font-size: 0.82rem;
    }
}

.site-ui.favorites-page .favorite-compare-table {
    width: 100%;
    min-width: 720px;
    border-collapse: collapse;
    font-size: 0.85rem;
}

.site-ui.favorites-page .favorite-compare-table th {
    background: #f8fafc;
    font-weight: 800;
    color: var(--mb-navy, #172033);
    text-transform: uppercase;
    letter-spacing: 0.03em;
    font-size: 0.72rem;
}

.site-ui.favorites-page .favorite-compare-table td,
.site-ui.favorites-page .favorite-compare-table th {
    padding: 0.65rem 0.75rem;
    border-bottom: 1px solid #f1f5f9;
    vertical-align: top;
    text-align: left;
}

.site-ui.favorites-page .favorite-compare-table td:first-child {
    font-weight: 700;
    color: var(--mb-navy, #172033);
    background: #fafbfc;
}

.site-ui.favorites-page .favorite-compare-table tr:hover td {
    background: #f8fafc;
}

.site-ui.favorites-page .favorites-badge,
.site-ui.notifications-page .notifications-badge {
    border-radius: 999px;
    font-weight: 800;
    letter-spacing: 0.04em;
}

.site-ui.favorites-page #favorites-count {
    border-radius: 999px;
    font-weight: 800;
    display: inline-flex;
    padding: 0.35rem 0.85rem;
    background: #fff;
    border: 1px solid #bbf7d0;
    color: #166534;
    font-size: 0.85rem;
}

.site-ui.favorites-page .favorites-hero {
    background: linear-gradient(180deg, #fdf2f8 0%, #f8fafc 40%, #ffffff 100%);
    border-bottom: 1px solid #fce7f3;
}

.site-ui.favorites-page .favorites-hero h1 {
    color: var(--mb-navy, #172033);
    letter-spacing: -0.02em;
}

.site-ui.favorites-page .favorites-badge {
    background: #fff !important;
    border: 1px solid #fbcfe8;
    color: #9d174d !important;
}

.site-ui.favorites-page .favorite-feature-strip {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 1.25rem;
    align-items: center;
    padding: 1.35rem 1.4rem;
    border-radius: var(--mb-radius-lg, 16px);
    border: 1px solid #bbf7d0;
    background: linear-gradient(135deg, #f0fdf4 0%, #ffffff 60%);
    box-shadow: var(--mb-shadow-sm);
}

.site-ui.favorites-page .favorite-feature-eyebrow {
    display: inline-block;
    margin-bottom: 0.35rem;
    padding: 0.2rem 0.6rem;
    border-radius: 999px;
    background: #dcfce7;
    color: #166534;
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.site-ui.favorites-page .favorite-feature-title {
    margin: 0 0 0.4rem;
    font-size: 1.2rem;
    color: var(--mb-navy, #172033);
    letter-spacing: -0.02em;
}

.site-ui.favorites-page .favorite-feature-text {
    margin: 0;
    color: #64748b;
    line-height: 1.6;
    max-width: 36rem;
}

.site-ui.favorites-page .favorite-feature-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    justify-content: flex-end;
}

.site-ui.favorites-page .favorites-empty-state {
    padding: 2.5rem 1.5rem;
    text-align: center;
    border-radius: var(--mb-radius-lg, 16px);
    border: 1px dashed #cbd5e1;
    background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
}

.site-ui.favorites-page .favorites-empty-state h2 {
    margin: 0 0 0.5rem;
    color: var(--mb-navy, #172033);
}

.site-ui.favorites-page .favorite-controls {
    padding: 1.15rem 1.2rem;
    border-radius: 14px;
    border: 1px solid #e2e8f0;
    background: #f8fafc;
}

.site-ui.favorites-page .favorite-field label {
    font-weight: 600;
    font-size: 0.85rem;
    color: #334155;
}

.site-ui.favorites-page .favorites-hero-copy {
    color: #64748b;
    line-height: 1.65;
}

.site-ui.favorites-page .favorite-controls {
    display: grid;
    gap: 0.75rem;
}

.site-ui.favorites-page .favorite-controls .favorite-field {
    margin: 0;
}

.site-ui.favorites-page .favorite-controls .mb-btn {
    min-height: 44px;
    justify-self: start;
}

.site-ui .favorites-state-card--loading .favorites-loading-dot {
    border: 3px solid #e2e8f0;
    border-top-color: var(--mb-green, #79ad87);
    animation: mb-spin 0.8s linear infinite;
    background: transparent !important;
}

@media (max-width: 900px) {
    .site-ui.favorites-page .favorite-card {
        grid-template-columns: 1fr !important;
    }

    .site-ui.favorites-page .favorite-feature-strip {
        grid-template-columns: 1fr !important;
    }

    .site-ui.favorites-page .favorite-feature-actions {
        justify-content: flex-start;
    }
}

/* Påmindelser */
.site-ui.notifications-page .reminder-card {
    padding: 1rem 1.1rem;
    border-radius: 14px;
    border: 1px solid var(--mb-line, #d8e6f7);
    background: #fff;
    box-shadow: var(--mb-shadow-sm);
    transition: box-shadow 0.15s ease, border-color 0.15s ease, opacity 0.15s ease;
}

.site-ui.notifications-page .reminder-card:hover {
    box-shadow: var(--mb-shadow-md);
    border-color: #bfdbfe;
}

.site-ui.favorites-page .favorite-compare-header {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.5rem;
}

.site-ui.favorites-page .favorite-compare-badge {
    flex-shrink: 0;
}

.site-ui.notifications-page .reminder-card.reminder-card-completed {
    opacity: 0.82;
    background: #f8fafc;
    border-color: #e2e8f0;
}

.site-ui.notifications-page .reminder-card h3,
.site-ui.notifications-page .reminder-card strong {
    color: var(--mb-navy, #172033);
}

.site-ui.notifications-page .reminder-empty-card {
    border-radius: var(--mb-radius-lg, 16px);
    border: 1px dashed #cbd5e1;
    background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
    padding: 2rem 1.5rem;
    text-align: center;
}

.site-ui.notifications-page .reminder-login-card {
    border-radius: var(--mb-radius-lg, 16px);
    border: 1px solid #fde68a;
    background: #fffbeb;
    padding: 1.5rem;
    text-align: center;
}

.site-ui.notifications-page .reminder-login-card .mb-btn {
    margin-top: 0.75rem;
    min-height: 44px;
}

.site-ui.notifications-page .reminder-empty-card p {
    color: #64748b;
    line-height: 1.6;
    max-width: 32rem;
    margin-left: auto;
    margin-right: auto;
}

.site-ui.notifications-page .reminder-login-card {
    border-color: #fde68a !important;
    background: #fffbeb !important;
}

.site-ui.notifications-page .reminder-form-grid .mb-btn-primary {
    min-height: 48px;
}

.site-ui.notifications-page .notifications-hero-copy {
    color: #64748b;
    line-height: 1.65;
}

.site-ui.notifications-page .reminder-empty-card h2 {
    color: var(--mb-navy, #172033);
    letter-spacing: -0.01em;
}

.site-ui.notifications-page .reminder-card {
    border-radius: var(--mb-radius-lg, 16px) !important;
    border-color: #e2e8f0 !important;
    box-shadow: var(--mb-shadow-sm);
    padding: 1.15rem 1.2rem !important;
}

.site-ui.notifications-page .reminder-card h3 {
    color: var(--mb-navy, #172033);
    letter-spacing: -0.01em;
}

.site-ui.notifications-page .reminder-form-grid {
    gap: 0.85rem;
}

.site-ui.notifications-page .reminder-form-grid label {
    font-weight: 600;
    font-size: 0.85rem;
    color: #334155;
}

.site-ui.notifications-page .reminder-form-grid input,
.site-ui.notifications-page .reminder-form-grid select,
.site-ui.notifications-page .reminder-form-grid textarea {
    border-radius: 10px;
    border: 1px solid #cbd5e1;
    min-height: 44px;
}

.site-ui.favorites-page .favorite-match-score {
    font-weight: 800;
    color: #166534;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-radius: 999px;
    padding: 0.2rem 0.55rem;
    font-size: 0.78rem;
}

.site-ui.favorites-page .favorite-notes textarea,
.site-ui.favorites-page .favorite-field textarea {
    min-height: 88px;
    border-radius: 10px;
    border: 1px solid #cbd5e1;
    resize: vertical;
}

.site-ui.favorites-page .favorite-notes textarea:focus,
.site-ui.favorites-page .favorite-field textarea:focus {
    outline: none;
    border-color: #93c5fd;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

.site-ui.favorites-page .favorites-loading-card,
.site-ui.notifications-page .notifications-loading-card {
    border-radius: var(--mb-radius-lg, 16px);
    border: 1px dashed #cbd5e1;
    background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
    padding: 2.5rem 1.5rem;
    text-align: center;
}

.site-ui.favorites-page .favorites-loading-dot,
.site-ui.notifications-page .notifications-loading-dot {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    border: 3px solid #e2e8f0;
    border-top-color: var(--mb-green, #79ad87);
    animation: mb-spin 0.8s linear infinite;
    margin: 0 auto;
}

@keyframes mb-spin {
    to {
        transform: rotate(360deg);
    }
}

.site-ui.favorites-page .favorite-compare-table tbody tr:nth-child(even) td {
    background: #fafbfc;
}

.site-ui.favorites-page .favorite-compare-table tbody tr:nth-child(even) td:first-child {
    background: #f1f5f9;
}

.site-ui.favorites-page .favorite-list {
    display: grid;
    gap: 1rem;
}

.site-ui.notifications-page .reminder-form-card {
    padding: 1.35rem 1.4rem;
    border-radius: var(--mb-radius-lg, 16px);
    border: 1px solid var(--mb-line, #d8e6f7);
    background: #fff;
    box-shadow: var(--mb-shadow-sm);
    margin-bottom: 1.5rem;
}

.site-ui.notifications-page .reminder-form-header {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 0.5rem;
}

.site-ui.notifications-page .reminder-form-badge {
    display: inline-flex;
    padding: 0.2rem 0.6rem;
    border-radius: 999px;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    color: #166534;
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.site-ui.notifications-page .reminder-form-header h2 {
    margin: 0.5rem 0 0;
    color: var(--mb-navy, #172033);
    letter-spacing: -0.01em;
}

.site-ui.notifications-page .reminder-section-heading {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}

.site-ui.notifications-page .reminder-section-heading h2 {
    margin: 0;
    color: var(--mb-navy, #172033);
    letter-spacing: -0.01em;
}

.site-ui.notifications-page .reminder-list {
    display: grid;
    gap: 0.85rem;
}

.site-ui.notifications-page .reminder-card {
    display: grid;
    gap: 1rem;
}

@media (min-width: 720px) {
    .site-ui.notifications-page .reminder-card {
        grid-template-columns: 1fr auto;
        align-items: start;
    }
}

.site-ui.notifications-page .reminder-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-bottom: 0.5rem;
}

.site-ui.notifications-page .reminder-pill {
    display: inline-flex;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 800;
}

.site-ui.notifications-page .reminder-pill-type {
    background: #eff6ff;
    color: #1d4ed8;
    border: 1px solid #bfdbfe;
}

.site-ui.notifications-page .reminder-pill-done {
    background: #f0fdf4;
    color: #166534;
    border: 1px solid #bbf7d0;
}

.site-ui.notifications-page .reminder-pill-email {
    background: #fffbeb;
    color: #92400e;
    border: 1px solid #fde68a;
}

.site-ui.notifications-page .reminder-title {
    margin: 0 0 0.35rem;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--mb-navy, #172033);
}

.site-ui.notifications-page .reminder-date,
.site-ui.notifications-page .reminder-institution,
.site-ui.notifications-page .reminder-next {
    margin: 0.25rem 0 0;
    color: #64748b;
    font-size: 0.88rem;
    line-height: 1.5;
}

.site-ui.notifications-page .reminder-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.site-ui.notifications-page .reminder-field-wide {
    grid-column: 1 / -1;
}

.site-ui.notifications-page .reminder-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.site-ui.notifications-page #reminder-message[data-state="success"] {
    padding: 0.75rem 0.9rem;
    border-radius: 10px;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    color: #166534;
    font-weight: 600;
}

.site-ui.notifications-page #reminder-message[data-state="error"] {
    padding: 0.75rem 0.9rem;
    border-radius: 10px;
    background: #fef2f2;
    border: 1px solid #fecaca;
    color: #b91c1c;
    font-weight: 600;
}
