@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@500;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800&display=swap');
@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Instrument+Sans:wght@400;500;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:wght,FILL@100..700,0..1&display=swap');

:root {
    --nova-body-font: 'Plus Jakarta Sans', sans-serif;
    --nova-display-font: 'Cormorant Garamond', serif;
    --nova-primary: #8b3d5a;
    --nova-primary-rgb: 139, 61, 90;
}

body,
button,
input,
textarea,
select {
    font-family: var(--nova-body-font);
}

h1,
h2,
h3,
h4,
h5,
h6,
.font-display {
    font-family: var(--nova-display-font) !important;
}

.material-symbols-outlined {
    font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
}

.text-primary {
    color: var(--nova-primary) !important;
}

.bg-primary {
    background-color: var(--nova-primary) !important;
}

.border-primary {
    border-color: var(--nova-primary) !important;
}

.ring-primary {
    --tw-ring-color: var(--nova-primary) !important;
}

.ring-primary\/50 {
    --tw-ring-color: rgba(var(--nova-primary-rgb), 0.5) !important;
}

.bg-primary\/5 {
    background-color: rgba(var(--nova-primary-rgb), 0.05) !important;
}

.bg-primary\/10 {
    background-color: rgba(var(--nova-primary-rgb), 0.10) !important;
}

.bg-primary\/20 {
    background-color: rgba(var(--nova-primary-rgb), 0.20) !important;
}

.bg-primary\/30 {
    background-color: rgba(var(--nova-primary-rgb), 0.30) !important;
}

.border-primary\/10 {
    border-color: rgba(var(--nova-primary-rgb), 0.10) !important;
}

.border-primary\/20 {
    border-color: rgba(var(--nova-primary-rgb), 0.20) !important;
}

.border-primary\/30 {
    border-color: rgba(var(--nova-primary-rgb), 0.30) !important;
}

.hover\:text-primary:hover {
    color: var(--nova-primary) !important;
}

.hover\:bg-primary:hover {
    background-color: var(--nova-primary) !important;
}

.hover\:border-primary:hover {
    border-color: var(--nova-primary) !important;
}

.focus\:ring-primary:focus {
    --tw-ring-color: var(--nova-primary) !important;
}

.accent-primary {
    accent-color: var(--nova-primary);
}

.nova-customizer {
    position: fixed;
    top: 50%;
    right: 0;
    z-index: 80;
    transform: translateY(-50%) translateX(100%);
    transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

.nova-customizer.is-open {
    transform: translateY(-50%) translateX(0);
}

.nova-customizer__tabs {
    position: absolute;
    left: -4.5rem;
    top: 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.nova-customizer__tab {
    width: 4.5rem;
    min-height: 4.5rem;
    border: 0;
    border-radius: 1.25rem 0 0 1.25rem;
    background: #20161a;
    color: #fdf8f4;
    box-shadow: -12px 18px 34px rgba(32, 22, 26, 0.28);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.2rem;
    padding: 0.75rem 0.5rem;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    transition: transform 0.2s ease, background-color 0.2s ease;
}

.nova-customizer__tab:hover {
    transform: none;
}

.nova-customizer__tab--buy {
    background: #20161a;
    color: #fdf8f4;
}

.nova-customizer__tab-label {
    font-size: 0.68rem;
    font-weight: 800;
    line-height: 1.05;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.nova-customizer__panel {
    width: min(22rem, calc(100vw - 2rem));
    padding: 1.5rem;
    border-radius: 1.75rem 0 0 1.75rem;
    background: rgba(253, 248, 244, 0.96);
    backdrop-filter: blur(18px);
    box-shadow: -18px 24px 54px rgba(15, 23, 42, 0.24);
    border: 1px solid rgba(148, 163, 184, 0.22);
}

.dark .nova-customizer__panel {
    background: rgba(24, 18, 22, 0.94);
    border-color: rgba(91, 71, 78, 0.9);
    color: #f5e9e2;
}

.nova-customizer__eyebrow {
    margin: 0 0 0.35rem;
    color: var(--nova-primary);
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.22em;
}

.nova-customizer__title {
    margin: 0;
    font-size: 1.45rem;
    font-weight: 800;
    line-height: 1.1;
}

.nova-customizer__copy {
    margin: 0.75rem 0 1.5rem;
    color: #6f5a62;
    font-size: 0.95rem;
    line-height: 1.6;
}

.dark .nova-customizer__copy {
    color: #c9b2ba;
}

.nova-customizer__section + .nova-customizer__section {
    margin-top: 1.5rem;
}

.nova-customizer__section-title {
    margin: 0 0 0.75rem;
    font-size: 0.86rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: #8a7078;
}

.nova-customizer__swatches {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.75rem;
}

.nova-customizer__swatch {
    border: 1px solid rgba(148, 163, 184, 0.35);
    border-radius: 1rem;
    background: #fff;
    color: #0f172a;
    padding: 0.65rem;
    cursor: pointer;
    transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.nova-customizer__swatch-name {
    display: block;
    margin-top: 0.45rem;
    font-size: 0.7rem;
    font-weight: 700;
    color: inherit;
}

.dark .nova-customizer__swatch,
.dark .nova-customizer__font-option {
    background: rgba(15, 23, 42, 0.55);
    color: #e2e8f0;
}

.nova-customizer__swatch:hover,
.nova-customizer__font-option:hover {
    transform: translateY(-2px);
    border-color: rgba(var(--nova-primary-rgb), 0.45);
}

.nova-customizer__swatch.is-active,
.nova-customizer__font-option.is-active {
    border-color: var(--nova-primary);
    box-shadow: 0 0 0 3px rgba(var(--nova-primary-rgb), 0.14);
}

.nova-customizer__swatch-dot {
    width: 100%;
    aspect-ratio: 1 / 1;
    display: block;
    border-radius: 0.85rem;
    border: 2px solid rgba(255, 255, 255, 0.85);
    box-shadow: 0 0 0 1px rgba(148, 163, 184, 0.3);
}

.nova-customizer__font-name {
    display: block;
    font-size: 0.74rem;
    font-weight: 700;
}

.nova-customizer__fonts {
    display: flex;
    flex-direction: column;
    gap: 0.7rem;
}

.nova-customizer__font-option {
    width: 100%;
    border: 1px solid rgba(148, 163, 184, 0.35);
    border-radius: 1rem;
    background: #fff;
    color: #0f172a;
    padding: 0.85rem 0.95rem;
    text-align: left;
    cursor: pointer;
    transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.nova-customizer__font-preview {
    display: block;
    margin-top: 0.28rem;
    color: #8a7078;
    font-size: 0.85rem;
}

.dark .nova-customizer__font-preview {
    color: #c9b2ba;
}

@media (max-width: 640px) {
    .nova-customizer {
        top: auto;
        bottom: 1rem;
        transform: translateX(100%);
    }

    .nova-customizer.is-open {
        transform: translateX(0);
    }

    .nova-customizer__tabs {
        top: 1rem;
    }

    .nova-customizer__panel {
        width: min(22rem, calc(100vw - 1rem));
    }
}
