/* ===========================================
   DSV - Custom Styles
   DSV-specific overrides and page styles
   =========================================== */

/* ===========================================
   OAUTH MODAL (u-oauth-modal uses native <dialog>)
   Tailwind's display utilities override dialog:not([open]) { display:none },
   so we let native dialog handle visibility and style via ::backdrop instead.
   =========================================== */
dialog.oauth-modal-dialog {
    margin: auto; /* Tailwind resets strip UA margin:auto — restore for centering */
    padding: 0;
    border: none;
    border-radius: 0.75rem;
    max-width: 28rem;
    width: calc(100% - 2rem);
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
}

dialog.oauth-modal-dialog::backdrop {
    background: rgba(0, 0, 0, 0.5);
}

/* ===========================================
   LOGIN MODAL
   =========================================== */

/* Overlay open state (toggled via JS .active) */
#loginModalOverlay.active {
    opacity: 1;
    visibility: visible;
}

/* ===========================================
   HERO SECTION
   Background image only — layout via Tailwind
   =========================================== */
.hero {
    background: url('/assets/images/hero-bg.webp') center/cover;
}

/* ===========================================
   WALLET EXPORT BUTTON
   =========================================== */
.btn-wallet {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-4);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    font-family: var(--font-family);
    color: var(--color-white);
    background: linear-gradient(135deg, #1a1a1a 0%, #333 100%);
    border: none;
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition-normal);
}

.btn-wallet:hover {
    background: linear-gradient(135deg, #333 0%, #444 100%);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.btn-wallet:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
}

.btn-wallet svg {
    flex-shrink: 0;
}

/* ===========================================
   UNIDY SDK COMPONENT OVERRIDES
   =========================================== */
u-field::part(field-error-message) {
    color: var(--color-primary);
    font-size: var(--font-size-sm);
    margin-top: var(--space-2);
    display: block;
}

u-newsletter::part(form) {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

u-newsletter::part(input) {
    width: 100%;
    padding: var(--space-3) var(--space-4);
    font-size: var(--font-size-base);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    transition: border-color var(--transition-normal);
}

u-newsletter::part(input):focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(228, 5, 33, 0.15);
}

u-newsletter::part(submit-button) {
    padding: var(--space-3) var(--space-6);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    background-color: var(--color-primary);
    color: var(--color-white);
    border: none;
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: background-color var(--transition-normal);
}

u-newsletter::part(submit-button):hover {
    background-color: var(--color-primary-dark);
}

/* Multi-select / Checkbox Group (Customer Group) */
u-field::part(checkbox-group_field) {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3);
}

u-field::part(checkbox-group-item_label) {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-4);
    background-color: var(--color-white);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition-normal);
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--color-text);
}

u-field::part(checkbox-group-item_label):hover {
    border-color: var(--color-primary);
    background-color: rgba(228, 5, 33, 0.03);
}

u-field::part(checkbox-group-item_checkbox) {
    width: 18px;
    height: 18px;
    border: 2px solid var(--color-border);
    border-radius: var(--radius-sm);
    appearance: none;
    cursor: pointer;
    transition: all var(--transition-normal);
    position: relative;
    flex-shrink: 0;
}

u-field::part(checkbox-group-item_checkbox):checked {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
}

u-field::part(checkbox-group-item_checkbox):checked::after {
    content: "";
    position: absolute;
    left: 5px;
    top: 2px;
    width: 5px;
    height: 9px;
    border: solid white;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

u-field::part(checkbox_checked) {
    background-color: rgba(228, 5, 33, 0.08);
    border-color: var(--color-primary);
    color: var(--color-primary);
}

u-field[field="custom_attributes.customer_group"]::part(field-container) {
    padding: var(--space-4);
    background-color: var(--color-background-light);
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);
}

u-field[field="custom_attributes.customer_group"]::part(field_label) {
    margin-bottom: var(--space-3);
    font-size: 0.8125rem;
}

u-field::part(multi-select-readonly-container) {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    list-style: none;
    padding: 0;
    margin: 0;
}

u-field::part(multi-select-readonly-field) {
    display: inline-flex;
    align-items: center;
    padding: var(--space-2) var(--space-4);
    background-color: var(--color-primary);
    color: var(--color-white);
    font-size: 0.875rem;
    font-weight: 600;
    border-radius: var(--radius-full);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
