/* ═══════════════════════════════════════════════════════════
   MILORA BEAUTY — buttons.css  v2
═══════════════════════════════════════════════════════════ */

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--sp-2);
    padding: 0.78em 2em;
    border-radius: var(--radius-sm);
    font-family: var(--font-body);
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-align: center;
    cursor: pointer;
    border: 2px solid transparent;
    transition: background var(--transition-normal),
                color var(--transition-normal),
                border-color var(--transition-normal),
                box-shadow var(--transition-normal),
                transform var(--transition-fast);
    position: relative;
    white-space: nowrap;
    text-decoration: none;
}

.btn:active { transform: translateY(1px); }

.btn:disabled,
.btn[disabled] {
    opacity: 0.45;
    cursor: not-allowed;
    pointer-events: none;
}

/* ── Primary — gold fill ─────────────────────────────────── */
.btn--primary {
    background: var(--gold);
    color: var(--white);
    border-color: var(--gold);
}
.btn--primary:hover {
    background: var(--gold-deep);
    border-color: var(--gold-deep);
    box-shadow: var(--shadow-gold);
}

/* ── Dark — black fill (main CTA, matches hero mockup) ───── */
.btn--dark {
    background: var(--black);
    color: var(--white);
    border-color: var(--black);
}
.btn--dark:hover {
    background: var(--black-soft);
    box-shadow: var(--shadow-md);
}

/* ── Secondary — gold outline ────────────────────────────── */
.btn--secondary {
    background: transparent;
    color: var(--gold-deep);
    border-color: var(--gold);
}
.btn--secondary:hover {
    background: var(--gold-light);
    border-color: var(--gold-deep);
}

/* ── Ghost ───────────────────────────────────────────────── */
.btn--ghost {
    background: transparent;
    color: var(--black-soft);
    border-color: transparent;
}
.btn--ghost:hover {
    color: var(--gold-deep);
    background: var(--nude-beige);
}

/* ── Sizes ───────────────────────────────────────────────── */
.btn--sm  { padding: 0.55em 1.3em; font-size: 0.75rem; }
.btn--lg  { padding: 0.88em 2.5em; font-size: 0.875rem; }
.btn--full { width: 100%; }

/* ── Icon only ───────────────────────────────────────────── */
.btn--icon {
    padding: 0;
    width: 42px;
    height: 42px;
    border-radius: var(--radius-full);
}
.btn--icon.btn--sm { width: 34px; height: 34px; font-size: 0.8rem; }

/* ── Add to Cart ─────────────────────────────────────────── */
.btn--add-to-cart {
    background: var(--black);
    color: var(--white);
    border-color: var(--black);
    gap: var(--sp-2);
    font-size: 0.78rem;
    font-weight: 700;
}
.btn--add-to-cart:hover {
    background: var(--gold);
    border-color: var(--gold);
    color: var(--white);
    box-shadow: var(--shadow-gold);
}
.btn--add-to-cart.added {
    background: var(--color-success);
    border-color: var(--color-success);
    color: #fff;
}

/* ── Loading spinner ─────────────────────────────────────── */
.btn--loading { pointer-events: none; opacity: 0.75; }
.btn--loading::after {
    content: '';
    width: 14px;
    height: 14px;
    border: 2px solid currentColor;
    border-top-color: transparent;
    border-radius: 50%;
    animation: btnSpin 0.7s linear infinite;
    margin-left: var(--sp-2);
}
@keyframes btnSpin { to { transform: rotate(360deg); } }

/* ── Quantity stepper ────────────────────────────────────── */
.qty-stepper {
    display: inline-flex;
    align-items: center;
    border: 2px solid var(--grey-border);
    border-radius: var(--radius-sm);
    overflow: hidden;
}
.qty-stepper__btn {
    width: 38px;
    height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.9rem;
    color: var(--gold-deep);
    transition: background var(--transition-fast);
}
.qty-stepper__btn:hover { background: var(--nude-beige); }
.qty-stepper__input {
    width: 48px;
    height: 38px;
    text-align: center;
    border: none;
    border-left: 1px solid var(--grey-border);
    border-right: 1px solid var(--grey-border);
    font-family: var(--font-body);
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--black);
    background: transparent;
    outline: none;
    -moz-appearance: textfield;
}
.qty-stepper__input::-webkit-outer-spin-button,
.qty-stepper__input::-webkit-inner-spin-button { -webkit-appearance: none; }