﻿:root {
    --dnre-bg: #050505;
    --dnre-bg-soft: #080808;
    --dnre-surface: #101010;
    --dnre-surface-soft: #151515;
    --dnre-surface-light: #1a1a1a;
    --dnre-text: #f5f5f5;
    --dnre-text-soft: #d8d8d8;
    --dnre-muted: #969696;
    --dnre-muted-dark: #6f6f6f;
    --dnre-border: rgba(255, 255, 255, 0.10);
    --dnre-border-strong: rgba(255, 255, 255, 0.22);
    --dnre-white: #ffffff;
    --dnre-black: #000000;
    --dnre-error: #ff6b6b;
    --dnre-radius-lg: 28px;
    --dnre-radius-md: 16px;
    --dnre-shadow: 0 32px 90px rgba(0, 0, 0, 0.55);
}

html,
body {
    min-height: 100%;
    margin: 0;
    background: var(--dnre-bg);
    color: var(--dnre-text);
    font-family: var(--font-body, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
}

body {
    overflow-x: hidden;
}

/* Shared page shell */

.prelaunch-page {
    min-height: 100vh;
    background: radial-gradient(circle at 12% 12%, rgba(255, 255, 255, 0.045), transparent 28rem), radial-gradient(circle at 88% 78%, rgba(255, 255, 255, 0.035), transparent 30rem), linear-gradient(180deg, #050505 0%, #030303 100%);
    padding: 32px 28px 48px;
    box-sizing: border-box;
}

.prelaunch-shell {
    width: min(1120px, 100%);
    margin: 0 auto;
}

.prelaunch-header {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 58px;
    padding-bottom: 22px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.prelaunch-logo {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
}

    .prelaunch-logo img {
        display: block;
        height: 44px;
        width: auto;
        object-fit: contain;
    }

/* Typography */

.prelaunch-eyebrow {
    margin: 0 0 18px;
    color: var(--dnre-muted);
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.32em;
    text-transform: uppercase;
}

.prelaunch-copy h1,
.claim-copy h1 {
    margin: 0;
    max-width: 780px;
    color: var(--dnre-white);
    font-family: var(--font-heading, var(--font-body, Inter, system-ui, sans-serif));
    font-size: clamp(3.4rem, 7.5vw, 7rem);
    font-weight: 850;
    line-height: 0.92;
    letter-spacing: -0.055em;
    text-transform: uppercase;
}

.prelaunch-copy p,
.claim-copy p {
    max-width: 570px;
    margin: 26px 0 0;
    color: var(--dnre-text-soft);
    font-size: 1.02rem;
    line-height: 1.75;
}

/* Home page */

.prelaunch-main {
    min-height: auto;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 390px;
    align-items: center;
    gap: 72px;
    padding-top: 120px;
}

.prelaunch-copy {
    max-width: 760px;
}

.prelaunch-card {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.025));
    border: 1px solid var(--dnre-border);
    border-radius: var(--dnre-radius-lg);
    padding: 28px;
    box-shadow: var(--dnre-shadow);
}

.artist-name-form {
    display: grid;
    gap: 20px;
}

/* Claim page */

.claim-main {
    display: grid;
    grid-template-columns: 0.72fr 1fr;
    align-items: start;
    gap: 62px;
    padding-top: 58px;
}

.claim-copy {
    position: sticky;
    top: 44px;
    padding-top: 8px;
}

    .claim-copy h1 {
        font-size: clamp(3rem, 5.2vw, 5.8rem);
    }

.claim-card {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.025));
    border: 1px solid var(--dnre-border);
    border-radius: var(--dnre-radius-lg);
    padding: 30px;
    box-shadow: var(--dnre-shadow);
}

.claim-form {
    display: grid;
    gap: 22px;
}

.form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
}

.full-width {
    grid-column: 1 / -1;
}

/* Form fields */

.form-field {
    display: grid;
    gap: 8px;
}

    .form-field label {
        color: #e7e7e7;
        font-size: 0.88rem;
        font-weight: 750;
    }

    .form-field input,
    .form-field textarea {
        width: 100%;
        box-sizing: border-box;
        border: 1px solid var(--dnre-border);
        background: rgba(255, 255, 255, 0.045);
        color: var(--dnre-white);
        border-radius: var(--dnre-radius-md);
        padding: 14px 15px;
        font: inherit;
        font-size: 0.95rem;
        outline: none;
        transition: border-color 140ms ease, background-color 140ms ease, box-shadow 140ms ease;
    }

        .form-field input::placeholder,
        .form-field textarea::placeholder {
            color: var(--dnre-muted-dark);
        }

        .form-field input:focus,
        .form-field textarea:focus {
            border-color: var(--dnre-border-strong);
            background: rgba(255, 255, 255, 0.065);
            box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.055);
        }

        .form-field input[readonly] {
            color: var(--dnre-white);
            background: rgba(255, 255, 255, 0.075);
            border-color: rgba(255, 255, 255, 0.18);
            cursor: default;
        }

    .form-field textarea {
        min-height: 128px;
        resize: vertical;
    }

.checkbox-row {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    color: var(--dnre-text-soft);
    font-size: 0.92rem;
    line-height: 1.55;
}

    .checkbox-row input {
        width: 18px;
        height: 18px;
        margin-top: 2px;
        accent-color: var(--dnre-white);
    }

/* Buttons */

.artist-name-form button,
.claim-form button {
    width: 100%;
    border: 0;
    border-radius: 999px;
    background: var(--dnre-white);
    color: var(--dnre-black);
    padding: 15px 22px;
    font: inherit;
    font-size: 0.96rem;
    font-weight: 850;
    cursor: pointer;
    transition: transform 140ms ease, opacity 140ms ease, box-shadow 140ms ease;
}

    .artist-name-form button:hover,
    .claim-form button:hover {
        transform: translateY(-1px);
        box-shadow: 0 18px 34px rgba(255, 255, 255, 0.12);
    }

    .artist-name-form button:active,
    .claim-form button:active {
        transform: translateY(0);
        opacity: 0.9;
    }

/* Validation */

.validation-summary {
    color: var(--dnre-error);
    background: rgba(255, 107, 107, 0.08);
    border: 1px solid rgba(255, 107, 107, 0.25);
    border-radius: 14px;
    padding: 12px 14px;
    line-height: 1.5;
}

.field-validation-error,
.form-field > span,
.claim-form > span {
    color: var(--dnre-error);
    font-size: 0.82rem;
}

/* Success page support */

.account-created-actions {
    margin-top: 32px;
}

.button-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: var(--dnre-white);
    color: var(--dnre-black);
    padding: 14px 20px;
    font-weight: 850;
    text-decoration: none;
}

/* Responsive */

@media (max-width: 1000px) {
    .prelaunch-main,
    .claim-main {
        grid-template-columns: 1fr;
        gap: 36px;
        padding-top: 48px;
    }

    .prelaunch-main {
        align-items: start;
        min-height: auto;
    }

    .claim-copy {
        position: static;
    }

    .prelaunch-card {
        max-width: 460px;
    }

    .claim-card {
        max-width: 760px;
    }

    .prelaunch-copy h1,
    .claim-copy h1 {
        font-size: clamp(3.1rem, 12vw, 5.8rem);
    }
}

@media (max-width: 680px) {
    .prelaunch-page {
        padding: 28px 28px 54px;
    }

    .prelaunch-header {
        padding-bottom: 22px;
    }

    .prelaunch-logo img {
        height: 42px;
    }

    .prelaunch-copy h1,
    .claim-copy h1 {
        font-size: clamp(2.7rem, 15vw, 4.8rem);
        letter-spacing: -0.06em;
    }

    .prelaunch-copy p,
    .claim-copy p {
        font-size: 0.98rem;
        line-height: 1.65;
    }

    .prelaunch-card,
    .claim-card {
        padding: 22px;
        border-radius: 22px;
    }

    .form-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 380px) {
    .prelaunch-page {
        padding-left: 22px;
        padding-right: 22px;
    }
}

.search-select {
    position: relative;
}

.search-select-button {
    width: 100%;
    min-height: 48px;
    border: 1px solid var(--dnre-border);
    background: rgba(255, 255, 255, 0.045);
    color: var(--dnre-white);
    border-radius: 999px;
    padding: 14px 18px;
    font: inherit;
    font-size: 0.95rem;
    font-weight: 650;
    text-align: left;
    cursor: pointer;
    transition: border-color 140ms ease, background-color 140ms ease, box-shadow 140ms ease;
}

    .search-select-button:hover {
        border-color: var(--dnre-border-strong);
        background: rgba(255, 255, 255, 0.06);
    }

    .search-select-button:focus {
        outline: none;
        border-color: var(--dnre-border-strong);
        box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.055);
    }

    .search-select-button span {
        display: block;
        color: var(--dnre-white);
        overflow: hidden;
        white-space: nowrap;
        text-overflow: ellipsis;
    }

.search-select:not(.has-value) .search-select-button span {
    color: var(--dnre-muted-dark);
    font-weight: 500;
}

/* selected value */
.search-select.has-value .search-select-button {
    background: rgba(255, 255, 255, 0.92);
    border-color: rgba(255, 255, 255, 0.92);
}

    .search-select.has-value .search-select-button span {
        color: #111111;
        font-weight: 750;
    }

/* dropdown menu */
.search-select-menu {
    position: absolute;
    z-index: 80;
    top: calc(100% + 10px);
    left: 0;
    right: 0;
    display: none;
    background: #0d0d0d;
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 24px;
    box-shadow: 0 26px 80px rgba(0, 0, 0, 0.72);
    padding: 12px;
}

.search-select.is-open .search-select-menu {
    display: block;
}

.search-select-search {
    width: 100%;
    box-sizing: border-box;
    margin-bottom: 12px;
    border: 1px solid rgba(255, 255, 255, 0.13);
    background: rgba(255, 255, 255, 0.055);
    color: var(--dnre-white);
    border-radius: 16px;
    padding: 13px 15px;
    font: inherit;
    font-size: 0.95rem;
    outline: none;
}

    .search-select-search::placeholder {
        color: var(--dnre-muted-dark);
    }

    .search-select-search:focus {
        border-color: var(--dnre-border-strong);
        box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.05);
    }

.search-select-options {
    max-height: 260px;
    overflow-y: auto;
    display: grid;
    gap: 8px;
    padding-right: 5px;
    scrollbar-width: thin;
    scrollbar-color: rgba(255, 255, 255, 0.26) transparent;
}

    .search-select-options::-webkit-scrollbar {
        width: 10px;
    }

    .search-select-options::-webkit-scrollbar-track {
        background: transparent;
        border-radius: 999px;
    }

    .search-select-options::-webkit-scrollbar-thumb {
        background: rgba(255, 255, 255, 0.22);
        border-radius: 999px;
        border: 2px solid #0d0d0d;
    }

        .search-select-options::-webkit-scrollbar-thumb:hover {
            background: rgba(255, 255, 255, 0.34);
        }

.search-select-option {
    width: 100%;
    border: 0;
    background: rgba(255, 255, 255, 0.055);
    color: var(--dnre-text-soft);
    border-radius: 999px;
    padding: 13px 16px;
    font: inherit;
    font-size: 0.94rem;
    font-weight: 700;
    text-align: left;
    cursor: pointer;
    transition: background-color 120ms ease, color 120ms ease, transform 120ms ease;
}

    .search-select-option:hover,
    .search-select-option.is-active {
        background: rgba(255, 255, 255, 0.92);
        color: #111111;
        transform: translateY(-1px);
    }

.search-select-empty {
    color: var(--dnre-muted);
    padding: 12px 10px;
    font-size: 0.9rem;
}
