/* ==========================================================
   Rintin Starter — My Account
   Auth, dashboard, addresses, pago a plazo, orders
   ========================================================== */

/* ==========================================================
   My Account — Auth (login / register)
   ========================================================== */

.rintin-auth {
    padding: 2rem 0 3rem;
}

.rintin-auth__card {
    background: #fff;
    border: 1px solid var(--rintin-border);
    border-radius: 16px;
    padding: 2rem;
    height: 100%;
}

.rintin-auth__title {
    font-size: 1.375rem;
    font-weight: 700;
    color: var(--rintin-text);
    margin-bottom: 1.5rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.rintin-auth__desc {
    font-size: 0.9375rem;
    color: #666;
    line-height: 1.6;
    margin-bottom: 1.5rem;
}

.rintin-auth__note {
    font-size: 0.875rem;
    color: #888;
    margin-bottom: 1rem;
}

.rintin-auth__actions {
    margin-bottom: 1rem;
}

/* Hide OTP plugin's own tabs on my-account page (we provide our own) */
.woocommerce-account .rintin-otp-tabs {
    display: none !important;
}

/* ==========================================================
   Rintin OTP Plugin — Login/Register Form Styling
   Classes: rintin-login-tabs__btn, rintin-login-form__input,
   rintin-login-form__submit, rintin-login-form__field
   ========================================================== */

/* Tabs (Usuario/WhatsApp) */
.rintin-login-tabs {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 1.25rem;
}

.rintin-login-tabs__btn {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.5rem 1rem;
    border: 1px solid var(--rintin-border, #E5E5E5);
    border-radius: 8px;
    background: #fff;
    color: var(--rintin-text, #1A1A1A);
    font-size: 0.8125rem;
    font-weight: 500;
    cursor: pointer;
    transition: border-color 0.15s, background 0.15s, color 0.15s;
    font-family: inherit;
}

.rintin-login-tabs__btn:hover {
    border-color: #cbd5e1;
    background: #f8fafc;
}

.rintin-login-tabs__btn.is-active {
    border-color: var(--rintin-green, #39B54A);
    background: rgba(57, 181, 74, 0.06);
    color: var(--rintin-green, #39B54A);
    font-weight: 600;
}

.rintin-login-tabs__btn .bi {
    font-size: 1rem;
}

/* Form fields */
.rintin-login-form__field {
    margin-bottom: 1rem;
}

.rintin-login-form__field > span:first-child {
    display: block;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--rintin-text, #1A1A1A);
    margin-bottom: 0.375rem;
}

/* Inputs */
.rintin-login-form__input,
.rintin-auth__card input[type="text"],
.rintin-auth__card input[type="email"],
.rintin-auth__card input[type="password"],
.rintin-auth__card input[type="tel"] {
    width: 100%;
    padding: 0.75rem 1rem;
    border: 1px solid var(--rintin-border, #E5E5E5);
    border-radius: 8px;
    font-size: 0.9375rem;
    color: var(--rintin-text, #1A1A1A);
    background: #f8f8f8;
    transition: border-color 0.2s, box-shadow 0.2s;
    box-sizing: border-box;
    font-family: inherit;
}

.rintin-login-form__input:focus,
.rintin-auth__card input[type="text"]:focus,
.rintin-auth__card input[type="email"]:focus,
.rintin-auth__card input[type="password"]:focus,
.rintin-auth__card input[type="tel"]:focus {
    outline: none;
    border-color: var(--rintin-green, #39B54A);
    box-shadow: 0 0 0 3px rgba(57, 181, 74, 0.1);
    background: #fff;
}

/* Submit buttons */
.rintin-login-form__submit,
.rintin-auth__card button[type="submit"],
.rintin-auth__card input[type="submit"] {
    display: block;
    width: 100%;
    padding: 0.75rem 1.5rem;
    background: var(--rintin-green, #39B54A);
    color: #fff;
    border: none;
    border-radius: 8px;
    font-size: 0.9375rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    font-family: inherit;
}

.rintin-login-form__submit:hover,
.rintin-auth__card button[type="submit"]:hover,
.rintin-auth__card input[type="submit"]:hover {
    background: var(--rintin-green-dark, #2D9A3C);
}

/* Remember me + lost password row */
.rintin-auth__actions {
    margin-top: 1rem;
}

.rintin-auth__actions label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
    color: #666;
    cursor: pointer;
}

.rintin-auth__actions input[type="checkbox"] {
    accent-color: var(--rintin-green, #39B54A);
}

.rintin-auth__actions a {
    font-size: 0.875rem;
    color: var(--rintin-green, #39B54A);
    text-decoration: none;
}

.rintin-auth__actions a:hover {
    text-decoration: underline;
}

/* Register card: radio buttons + privacy text */
.rintin-auth__card input[type="radio"] {
    accent-color: var(--rintin-green, #39B54A);
    margin-right: 0.375rem;
}

.rintin-auth__card .woocommerce-privacy-policy-text,
.rintin-auth__card p:has(a[href*="privacidad"]) {
    font-size: 0.8125rem;
    color: #888;
    line-height: 1.5;
    margin-bottom: 1rem;
}

.rintin-auth__card .woocommerce-privacy-policy-text a,
.rintin-auth__card p a[href*="privacidad"] {
    color: var(--rintin-green, #39B54A);
}

/* Mobile */
@media (max-width: 767.98px) {
    .rintin-auth {
        padding: 1rem 0 2rem;
    }

    .rintin-auth__card {
        padding: 1.5rem;
    }

    .rintin-login-form__input,
    .rintin-auth__card input[type="text"],
    .rintin-auth__card input[type="email"],
    .rintin-auth__card input[type="password"],
    .rintin-auth__card input[type="tel"] {
        font-size: 1rem; /* Prevent iOS zoom */
    }
}

/* ==========================================================
   My Account — Dashboard (logged-in)
   ========================================================== */

.rintin-myaccount {
    padding: 2rem 0 3rem;
}

/* Sidebar navigation */
.rintin-myaccount__nav {
    background: #fff;
    border: 1px solid var(--rintin-border);
    border-radius: 16px;
    overflow: hidden;
}

.rintin-myaccount__user {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid var(--rintin-border);
    background: var(--rintin-gray-bg);
}

.rintin-myaccount__avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    flex-shrink: 0;
}

.rintin-myaccount__user-greeting {
    font-size: 0.8125rem;
    color: #888;
    display: block;
}

.rintin-myaccount__user-name {
    font-size: 0.9375rem;
    color: var(--rintin-text);
    display: block;
}

.rintin-myaccount__menu {
    list-style: none;
    margin: 0;
    padding: 0.5rem 0;
}

.rintin-myaccount__menu-item a {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 1.5rem;
    color: var(--rintin-text);
    text-decoration: none;
    font-size: 0.9375rem;
    font-weight: 500;
    transition: background 0.15s, color 0.15s;
}

.rintin-myaccount__menu-item a:hover {
    background: var(--rintin-gray-bg);
    color: var(--rintin-green);
}

.rintin-myaccount__menu-item.is-active a,
.rintin-myaccount__menu-item a[aria-current="page"] {
    color: var(--rintin-green);
    background: rgba(58, 135, 80, 0.06);
    border-right: 3px solid var(--rintin-green);
    font-weight: 600;
}

.rintin-myaccount__menu-item a .bi {
    font-size: 1.125rem;
    width: 1.5rem;
    text-align: center;
}

/* Sidebar extras section (Propaga + Beneficio) */
.rintin-myaccount__extras {
    border-top: 1px solid var(--rintin-border);
    padding-top: 0.25rem;
    margin-top: 0.25rem;
}

.rintin-myaccount__extras-title {
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #94a3b8;
    padding: 0.5rem 1.5rem;
}

.rintin-myaccount__extras .rintin-myaccount__menu {
    padding-top: 0;
}

.rintin-myaccount__menu-item--logout {
    border-top: 1px solid var(--rintin-border);
    margin-top: 0.5rem;
    padding-top: 0.5rem;
}

.rintin-myaccount__menu-item--logout a {
    color: #dc3545;
}

.rintin-myaccount__menu-item--logout a:hover {
    color: #b02a37;
    background: #fef2f2;
}

/* Main content area */
.rintin-myaccount__content {
    background: #fff;
    border: 1px solid var(--rintin-border);
    border-radius: 16px;
    padding: 2rem;
    min-height: 400px;
}

/* Dashboard */
.rintin-dashboard__welcome {
    margin-bottom: 2rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid var(--rintin-border);
}

.rintin-dashboard__greeting {
    font-size: 1.375rem;
    font-weight: 600;
    color: var(--rintin-text);
    margin-bottom: 0.25rem;
}

.rintin-dashboard__subtitle {
    font-size: 0.875rem;
    color: #888;
}

.rintin-dashboard__subtitle a {
    color: var(--rintin-green);
    text-decoration: none;
}

.rintin-dashboard__subtitle a:hover {
    text-decoration: underline;
}

.rintin-dashboard__cards {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.rintin-dashboard__card {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.25rem 1.5rem;
    border: 1px solid var(--rintin-border);
    border-radius: 12px;
    text-decoration: none;
    color: var(--rintin-text);
    transition: border-color 0.2s, box-shadow 0.2s;
}

.rintin-dashboard__card:hover {
    border-color: var(--rintin-green);
    box-shadow: 0 2px 8px rgba(58, 135, 80, 0.1);
    color: var(--rintin-text);
}

.rintin-dashboard__card-icon {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(58, 135, 80, 0.08);
    border-radius: 12px;
    flex-shrink: 0;
}

.rintin-dashboard__card-icon .bi {
    font-size: 1.375rem;
    color: var(--rintin-green);
}

.rintin-dashboard__card-body {
    flex: 1;
}

.rintin-dashboard__card-title {
    font-size: 0.9375rem;
    font-weight: 600;
    margin: 0 0 0.125rem;
}

.rintin-dashboard__card-desc {
    font-size: 0.8125rem;
    color: #888;
    margin: 0;
}

.rintin-dashboard__card-arrow {
    color: #ccc;
    font-size: 1rem;
}

.rintin-dashboard__card:hover .rintin-dashboard__card-arrow {
    color: var(--rintin-green);
}

/* ==========================================================
   Addresses — shadcn cards
   ========================================================== */

.rintin-addresses__intro {
    font-size: 0.875rem;
    color: #64748b;
    margin-bottom: 1.5rem;
}

.rintin-addresses {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1rem;
}

.rintin-addresses__card {
    border: 1px solid var(--rintin-border);
    border-radius: 12px;
    overflow: hidden;
    transition: border-color 0.15s;
}

.rintin-addresses__card:hover {
    border-color: #cbd5e1;
}

.rintin-addresses__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--rintin-border);
    background: #f8fafc;
}

.rintin-addresses__title-wrap {
    display: flex;
    align-items: center;
    gap: 0.625rem;
}

.rintin-addresses__icon {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(58, 135, 80, 0.08);
    border-radius: 8px;
    flex-shrink: 0;
}

.rintin-addresses__icon .bi {
    font-size: 1.125rem;
    color: var(--rintin-green);
}

.rintin-addresses__title {
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--rintin-text);
    margin: 0;
}

.rintin-addresses__edit-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.375rem 0.875rem;
    border: 1px solid var(--rintin-green);
    border-radius: 8px;
    color: var(--rintin-green);
    font-size: 0.8125rem;
    font-weight: 500;
    text-decoration: none;
    transition: background 0.15s, color 0.15s;
    white-space: nowrap;
}

.rintin-addresses__edit-btn:hover {
    background: var(--rintin-green);
    color: #fff;
}

.rintin-addresses__body {
    padding: 1.25rem;
}

.rintin-addresses__text {
    font-style: normal;
    font-size: 0.9375rem;
    line-height: 1.7;
    color: var(--rintin-text);
}

.rintin-addresses__empty {
    font-size: 0.875rem;
    color: #94a3b8;
    margin: 0;
}

@media (max-width: 767.98px) {
    .rintin-addresses {
        grid-template-columns: 1fr;
    }

    .rintin-addresses__header {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.75rem;
    }

    .rintin-addresses__edit-btn {
        width: 100%;
        justify-content: center;
    }
}

/* ==========================================================
   Pago a Plazo — Propaga credit tiers
   ========================================================== */

.rintin-credito {
    width: 100%;
}

/* Header */
.rintin-credito__header {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 2rem;
}

.rintin-credito__header-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    background: rgba(58, 135, 80, 0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.rintin-credito__header-icon .bi {
    font-size: 1.375rem;
    color: var(--rintin-green);
}

.rintin-credito__title {
    font-size: 1.375rem;
    font-weight: 600;
    color: var(--rintin-text);
    margin: 0 0 0.25rem;
}

.rintin-credito__subtitle {
    font-size: 0.875rem;
    color: #64748b;
    margin: 0;
}

/* Progress bar (horizontal steps) */
.rintin-credito__progress {
    display: flex;
    align-items: center;
    margin-bottom: 1.5rem;
    padding: 0 0.5rem;
}

.rintin-credito__step {
    display: flex;
    align-items: center;
    flex: 1;
}

.rintin-credito__step:last-child {
    flex: 0;
}

.rintin-credito__step-dot {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--rintin-gray-bg);
    border: 2px solid var(--rintin-border);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    font-weight: 600;
    color: #94a3b8;
    flex-shrink: 0;
    transition: all 0.2s;
}

.rintin-credito__step--done .rintin-credito__step-dot {
    background: var(--rintin-green);
    border-color: var(--rintin-green);
    color: #fff;
}

.rintin-credito__step--done .rintin-credito__step-dot .bi {
    font-size: 0.875rem;
}

.rintin-credito__step--active .rintin-credito__step-dot {
    background: #fff;
    border-color: var(--rintin-green);
    color: var(--rintin-green);
    box-shadow: 0 0 0 3px rgba(58, 135, 80, 0.15);
}

.rintin-credito__step-line {
    flex: 1;
    height: 2px;
    background: var(--rintin-border);
    margin: 0 0.25rem;
}

.rintin-credito__step-line--done {
    background: var(--rintin-green);
}

/* Level cards */
.rintin-credito__levels {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-bottom: 2rem;
}

.rintin-credito__card {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1rem 1.25rem;
    border: 1px solid var(--rintin-border);
    border-radius: 12px;
    background: #fff;
    transition: border-color 0.15s, box-shadow 0.15s;
}

.rintin-credito__card--active {
    border-color: var(--rintin-green);
    box-shadow: 0 0 0 3px rgba(58, 135, 80, 0.08);
    background: rgba(58, 135, 80, 0.02);
}

.rintin-credito__card--done {
    opacity: 0.65;
}

.rintin-credito__card-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: var(--rintin-gray-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.rintin-credito__card--active .rintin-credito__card-icon {
    background: rgba(58, 135, 80, 0.1);
}

.rintin-credito__card-icon .bi {
    font-size: 1.125rem;
    color: #64748b;
}

.rintin-credito__card--active .rintin-credito__card-icon .bi {
    color: var(--rintin-green);
}

.rintin-credito__card-body {
    flex: 1;
    min-width: 0;
}

.rintin-credito__card-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.375rem;
}

.rintin-credito__card-title {
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--rintin-text);
    margin: 0;
}

.rintin-credito__card-badge {
    font-size: 0.6875rem;
    font-weight: 600;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    white-space: nowrap;
}

.rintin-credito__card-badge--active {
    color: var(--rintin-green);
    background: rgba(58, 135, 80, 0.08);
    padding: 0.2rem 0.625rem;
    border-radius: 9999px;
    font-size: 0.6875rem;
}

.rintin-credito__card-desc {
    font-size: 0.8125rem;
    color: #64748b;
    margin: 0;
    line-height: 1.5;
}

.rintin-credito__card-check {
    flex-shrink: 0;
    color: var(--rintin-green);
    font-size: 1.25rem;
    line-height: 1;
}

/* CTA */
.rintin-credito__cta {
    text-align: center;
    padding: 1.5rem 0 0;
    border-top: 1px solid var(--rintin-border);
}

.rintin-credito__cta-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.625rem 1.5rem;
    background: var(--rintin-green);
    color: #fff;
    border: none;
    border-radius: 8px;
    font-size: 0.875rem;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.15s;
}

.rintin-credito__cta-btn:hover {
    background: var(--rintin-green-dark);
    color: #fff;
    text-decoration: none;
}

.rintin-credito__cta-note {
    font-size: 0.8125rem;
    color: #94a3b8;
    margin: 0.75rem 0 0;
}

/* Mobile */
@media (max-width: 767.98px) {
    .rintin-credito__header {
        flex-direction: column;
        gap: 0.75rem;
    }

    .rintin-credito__progress {
        padding: 0;
    }

    .rintin-credito__step-dot {
        width: 28px;
        height: 28px;
        font-size: 0.6875rem;
    }

    .rintin-credito__card {
        padding: 0.875rem 1rem;
    }

    .rintin-credito__card-top {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.25rem;
    }

    .rintin-credito__cta-btn {
        width: 100%;
        justify-content: center;
    }
}

/* ==========================================================
   Orders — shadcn card-based table
   ========================================================== */

/* Container */
.rintin-orders {
    width: 100%;
}

/* Desktop header row */
.rintin-orders__header {
    display: flex;
    align-items: center;
    padding: 0 1rem;
    margin-bottom: 0.25rem;
}

.rintin-orders__col {
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #94a3b8;
    padding: 0.5rem 0.5rem;
}

.rintin-orders__col--number  { flex: 0 0 100px; }
.rintin-orders__col--date    { flex: 0 0 140px; }
.rintin-orders__col--status  { flex: 0 0 130px; }
.rintin-orders__col--total   { flex: 1; }
.rintin-orders__col--actions { flex: 0 0 220px; text-align: right; }

/* Order row (desktop: horizontal flex; mobile: stacked card) */
.rintin-orders__row {
    display: flex;
    align-items: center;
    padding: 1rem;
    border-bottom: 1px solid var(--rintin-border);
    transition: background 0.15s;
}

.rintin-orders__row:last-child {
    border-bottom: none;
}

.rintin-orders__row:hover {
    background: #f8fafc;
}

/* Cells match header widths */
.rintin-orders__cell--number  { flex: 0 0 100px; }
.rintin-orders__cell--date    { flex: 0 0 140px; font-size: 0.875rem; color: #64748b; }
.rintin-orders__cell--status  { flex: 0 0 130px; }
.rintin-orders__cell--total   { flex: 1; }
.rintin-orders__cell--actions { flex: 0 0 220px; text-align: right; display: flex; flex-wrap: wrap; gap: 0.375rem; justify-content: flex-end; }

/* Order number link */
.rintin-orders__order-link {
    font-weight: 600;
    color: var(--rintin-green);
    text-decoration: none;
    font-size: 0.9375rem;
}
.rintin-orders__order-link:hover {
    text-decoration: underline;
}

/* Total: amount + item count */
.rintin-orders__total-amount {
    display: block;
    font-weight: 600;
    font-size: 0.9375rem;
    color: var(--rintin-text);
}
.rintin-orders__total-items {
    display: block;
    font-size: 0.75rem;
    color: #94a3b8;
}

/* ── Status badges ── */
.rintin-orders__badge {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.75rem;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 600;
    line-height: 1.4;
    white-space: nowrap;
}

.rintin-orders__badge--warning {
    background: #fef3c7;
    color: #92400e;
}
.rintin-orders__badge--info {
    background: #dbeafe;
    color: #1e40af;
}
.rintin-orders__badge--success {
    background: #dcfce7;
    color: #166534;
}
.rintin-orders__badge--danger {
    background: #fee2e2;
    color: #991b1b;
}
.rintin-orders__badge--default {
    background: #f1f5f9;
    color: #475569;
}

/* ── Action buttons ── */
.rintin-orders__btn {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.375rem 0.875rem;
    border-radius: 8px;
    font-size: 0.8125rem;
    font-weight: 500;
    text-decoration: none;
    white-space: nowrap;
    transition: background 0.15s, color 0.15s, border-color 0.15s;
    cursor: pointer;
    border: 1px solid transparent;
    line-height: 1.5;
}

/* Pay — primary green */
.rintin-orders__btn--pay {
    background: var(--rintin-green);
    color: #fff;
    border-color: var(--rintin-green);
}
.rintin-orders__btn--pay:hover {
    background: var(--rintin-green-dark);
    border-color: var(--rintin-green-dark);
    color: #fff;
}

/* Outline — green border */
.rintin-orders__btn--outline {
    background: transparent;
    color: var(--rintin-green);
    border-color: var(--rintin-green);
}
.rintin-orders__btn--outline:hover {
    background: var(--rintin-green);
    color: #fff;
}

/* Cancel — red text, no border */
.rintin-orders__btn--cancel {
    background: transparent;
    color: #ef4444;
    border-color: transparent;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}
.rintin-orders__btn--cancel:hover {
    background: #fef2f2;
    color: #dc2626;
}

/* ── Pagination ── */
.rintin-orders__pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    margin-top: 1.5rem;
    padding-top: 1rem;
    border-top: 1px solid var(--rintin-border);
}

.rintin-orders__page-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.5rem 1rem;
    border: 1px solid var(--rintin-border);
    border-radius: 8px;
    background: #fff;
    color: var(--rintin-text);
    font-size: 0.875rem;
    font-weight: 500;
    text-decoration: none;
    transition: border-color 0.15s, background 0.15s;
}

.rintin-orders__page-btn:hover {
    border-color: var(--rintin-green);
    background: rgba(58, 135, 80, 0.04);
    color: var(--rintin-green);
}

.rintin-orders__page-info {
    font-size: 0.8125rem;
    color: #94a3b8;
}

/* ── Empty state ── */
.rintin-orders__empty {
    text-align: center;
    padding: 3rem 1rem;
}

.rintin-orders__empty-icon {
    font-size: 2.5rem;
    color: #cbd5e1;
    margin-bottom: 1rem;
}

.rintin-orders__empty-text {
    font-size: 1rem;
    color: #64748b;
    margin-bottom: 1.5rem;
}

/* ── Mobile orders ── */
@media (max-width: 767.98px) {
    .rintin-orders__row {
        flex-direction: column;
        align-items: stretch;
        border: 1px solid var(--rintin-border);
        border-radius: 12px;
        padding: 1rem;
        margin-bottom: 0.75rem;
        gap: 0.5rem;
    }

    .rintin-orders__row:last-child {
        border-bottom: 1px solid var(--rintin-border);
    }

    .rintin-orders__row:hover {
        background: #fff;
    }

    .rintin-orders__cell {
        display: flex;
        align-items: center;
        justify-content: space-between;
    }

    .rintin-orders__cell::before {
        content: attr(data-label);
        font-size: 0.75rem;
        font-weight: 600;
        color: #94a3b8;
        text-transform: uppercase;
        letter-spacing: 0.04em;
        flex-shrink: 0;
        margin-right: 0.75rem;
    }

    .rintin-orders__cell--number,
    .rintin-orders__cell--date,
    .rintin-orders__cell--status,
    .rintin-orders__cell--total,
    .rintin-orders__cell--actions {
        flex: none;
        width: 100%;
        text-align: right;
    }

    .rintin-orders__cell--number {
        padding-bottom: 0.5rem;
        border-bottom: 1px solid var(--rintin-border);
        margin-bottom: 0.25rem;
    }

    .rintin-orders__cell--actions {
        flex-direction: column;
        align-items: stretch;
        gap: 0.5rem;
        margin-top: 0.5rem;
        padding-top: 0.75rem;
        border-top: 1px solid var(--rintin-border);
    }

    .rintin-orders__cell--actions::before {
        display: none;
    }

    .rintin-orders__btn {
        width: 100%;
        justify-content: center;
        padding: 0.625rem 1rem;
    }

    .rintin-orders__pagination {
        flex-direction: column;
        gap: 0.75rem;
    }

    .rintin-orders__page-btn {
        width: 100%;
        justify-content: center;
    }
}

/* WooCommerce buttons */
.rintin-myaccount__content .woocommerce-button,
.rintin-myaccount__content .button {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.625rem 1.25rem;
    border: none;
    border-radius: 8px;
    background: var(--rintin-green);
    color: #fff;
    font-size: 0.875rem;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    transition: background 0.2s;
}

.rintin-myaccount__content .woocommerce-button:hover,
.rintin-myaccount__content .button:hover {
    background: var(--rintin-green-dark);
    color: #fff;
}

/* Form fields in my-account */
.rintin-myaccount__content .woocommerce-form-row label,
.rintin-myaccount__content .form-row label {
    display: block;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--rintin-text);
    margin-bottom: 0.5rem;
}

.rintin-myaccount__content .woocommerce-Input,
.rintin-myaccount__content .input-text,
.rintin-myaccount__content select {
    width: 100%;
    padding: 0.75rem 1rem;
    border: 1px solid var(--rintin-border);
    border-radius: 8px;
    font-size: 0.9375rem;
    color: var(--rintin-text);
    background: var(--rintin-gray-bg);
    transition: border-color 0.2s;
}

.rintin-myaccount__content .woocommerce-Input:focus,
.rintin-myaccount__content .input-text:focus,
.rintin-myaccount__content select:focus {
    outline: none;
    border-color: var(--rintin-green);
    box-shadow: 0 0 0 3px rgba(58, 135, 80, 0.1);
}

/* WooCommerce notices — shadcn-inspired alert cards */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
    position: relative;
    display: flex;
    align-items: flex-start;
    gap: 12px;
    border-radius: 12px;
    padding: 16px;
    margin-bottom: 12px;
    font-size: 0.8125rem;
    font-weight: 500;
    line-height: 1.5;
    list-style: none;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

/* Reset WooCommerce default icon */
.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before,
.woocommerce-error li::before {
    font-family: 'bootstrap-icons' !important;
    position: static !important;
    float: none !important;
    flex-shrink: 0;
    font-size: 1.25rem;
    line-height: 1;
    margin: 1px 0 0 !important;
    top: auto !important;
    left: auto !important;
}

/* Success message — green (matches SHADCN --success) */
.woocommerce-message {
    border: 1px solid #bbf7d0;
    background: #dcfce7;
    color: #166534;
}

.woocommerce-message::before {
    content: '\F26A' !important; /* bi-check-circle-fill */
    color: #16a34a;
}

/* Info/Notice — blue (matches SHADCN --info) */
.woocommerce-info {
    border: 1px solid #bfdbfe;
    background: #dbeafe;
    color: #1e40af;
}

.woocommerce-info::before {
    content: '\F431' !important; /* bi-info-circle-fill */
    color: #2563eb;
}

/* Error notice — red (matches SHADCN --danger) */
.woocommerce-error {
    border: 1px solid #fecaca;
    background: #fee2e2;
    color: #991b1b;
    flex-direction: column;
    gap: 4px;
}

.woocommerce-error li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
}

.woocommerce-error li::before {
    content: '\F336' !important; /* bi-exclamation-circle-fill */
    color: #dc2626;
    font-family: 'bootstrap-icons' !important;
    flex-shrink: 0;
    font-size: 1.25rem;
    line-height: 1.5;
}

.woocommerce-error::before {
    display: none !important;
}

/* Action button inside notices (e.g. "Ver carrito") */
.woocommerce-message .button,
.woocommerce-message .wc-forward {
    margin-left: auto;
    flex-shrink: 0;
    background: var(--rintin-green);
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 0.375rem 1rem;
    font-size: 0.8125rem;
    font-weight: 600;
    text-decoration: none;
    white-space: nowrap;
    transition: background 0.15s;
}

.woocommerce-message .button:hover,
.woocommerce-message .wc-forward:hover {
    background: var(--rintin-green-dark, #2d6e47);
    color: #fff;
}

/* Notice wrapper */
.woocommerce-notices-wrapper {
    max-height: 200px;
    overflow-y: auto;
    margin-bottom: 1rem;
}

/* Coupon inline messages (SHADCN status badges) */
.rintin-cart__coupon-error,
.rintin-cart__coupon-success {
    margin-top: 8px;
    padding: 10px 14px;
    border-radius: 12px;
    font-size: 0.8125rem;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 8px;
    line-height: 1.4;
}

.rintin-cart__coupon-error {
    background: #fee2e2;
    border: 1px solid #fecaca;
    color: #991b1b;
}

.rintin-cart__coupon-success {
    background: #dcfce7;
    border: 1px solid #bbf7d0;
    color: #166534;
}

/* Hide the default WC page title on cart/checkout (our template has its own) */
.woocommerce-cart .entry-title,
.woocommerce-cart article > h1,
.woocommerce-checkout .entry-title {
    display: none;
}

/* ==========================================================
   WooCommerce Default Login/Register Form (non-logged-in)
   Styles the default #customer_login two-column form
   ========================================================== */
.woocommerce-account .woocommerce #customer_login {
    display: flex;
    gap: 1.5rem;
    max-width: 900px;
    margin: 0 auto;
    padding: 1.5rem 1rem 3rem;
}

.woocommerce-account .woocommerce #customer_login > div {
    flex: 1;
    background: #fff;
    border: 1px solid var(--rintin-border, #E5E5E5);
    border-radius: 16px;
    padding: 2rem;
}

.woocommerce-account .woocommerce #customer_login h2 {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--rintin-text, #1A1A1A);
    margin-bottom: 1.25rem;
}

.woocommerce-account .woocommerce #customer_login label {
    display: block;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--rintin-text, #1A1A1A);
    margin-bottom: 0.375rem;
}

.woocommerce-account .woocommerce #customer_login input[type="text"],
.woocommerce-account .woocommerce #customer_login input[type="email"],
.woocommerce-account .woocommerce #customer_login input[type="password"] {
    width: 100%;
    padding: 0.75rem 1rem;
    border: 1px solid var(--rintin-border, #E5E5E5);
    border-radius: 8px;
    font-size: 0.9375rem;
    color: var(--rintin-text, #1A1A1A);
    background: #f8f8f8;
    transition: border-color 0.2s, box-shadow 0.2s;
    box-sizing: border-box;
}

.woocommerce-account .woocommerce #customer_login input[type="text"]:focus,
.woocommerce-account .woocommerce #customer_login input[type="email"]:focus,
.woocommerce-account .woocommerce #customer_login input[type="password"]:focus {
    outline: none;
    border-color: var(--rintin-green, #39B54A);
    box-shadow: 0 0 0 3px rgba(57, 181, 74, 0.1);
    background: #fff;
}

.woocommerce-account .woocommerce #customer_login .form-row {
    margin-bottom: 1rem;
}

.woocommerce-account .woocommerce #customer_login button[type="submit"],
.woocommerce-account .woocommerce #customer_login input[type="submit"],
.woocommerce-account .woocommerce #customer_login .woocommerce-button {
    display: block;
    width: 100%;
    padding: 0.75rem 1.5rem;
    background: var(--rintin-green, #39B54A);
    color: #fff;
    border: none;
    border-radius: 8px;
    font-size: 0.9375rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.woocommerce-account .woocommerce #customer_login button[type="submit"]:hover,
.woocommerce-account .woocommerce #customer_login input[type="submit"]:hover,
.woocommerce-account .woocommerce #customer_login .woocommerce-button:hover {
    background: var(--rintin-green-dark, #2D9A3C);
}

.woocommerce-account .woocommerce #customer_login .woocommerce-form-login__rememberme {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
    color: #666;
    margin-bottom: 1rem;
}

.woocommerce-account .woocommerce #customer_login .lost_password {
    margin-top: 0.75rem;
}

.woocommerce-account .woocommerce #customer_login .lost_password a {
    font-size: 0.875rem;
    color: var(--rintin-green, #39B54A);
    text-decoration: none;
}

.woocommerce-account .woocommerce #customer_login .lost_password a:hover {
    text-decoration: underline;
}

/* Registration description */
.woocommerce-account .woocommerce #customer_login .u-column2 p:first-of-type {
    font-size: 0.875rem;
    color: #666;
    line-height: 1.6;
    margin-bottom: 1.25rem;
}

/* Dokan vendor/customer radio */
.woocommerce-account .woocommerce #customer_login .show_if_seller,
.woocommerce-account .woocommerce #customer_login p:has(input[type="radio"]) {
    font-size: 0.875rem;
    color: var(--rintin-text, #1A1A1A);
    margin-bottom: 1rem;
}

.woocommerce-account .woocommerce #customer_login input[type="radio"] {
    accent-color: var(--rintin-green, #39B54A);
    margin-right: 0.375rem;
}

/* Privacy policy text */
.woocommerce-account .woocommerce #customer_login .woocommerce-privacy-policy-text {
    font-size: 0.8125rem;
    color: #888;
    line-height: 1.5;
    margin-bottom: 1rem;
}

.woocommerce-account .woocommerce #customer_login .woocommerce-privacy-policy-text a {
    color: var(--rintin-green, #39B54A);
}

/* Hide default page title on my-account (login view) */
.woocommerce-account:not(.logged-in) article > h1:first-child,
.woocommerce-account:not(.logged-in) .entry-title {
    text-align: center;
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
    padding-top: 1.5rem;
}

/* Mobile: stack login/register */
@media (max-width: 767.98px) {
    .woocommerce-account .woocommerce #customer_login {
        flex-direction: column;
        gap: 1rem;
        padding: 1rem 0.75rem 2rem;
    }

    .woocommerce-account .woocommerce #customer_login > div {
        padding: 1.5rem;
    }

    .woocommerce-account .woocommerce #customer_login h2 {
        font-size: 1.125rem;
    }

    .woocommerce-account .woocommerce #customer_login input[type="text"],
    .woocommerce-account .woocommerce #customer_login input[type="email"],
    .woocommerce-account .woocommerce #customer_login input[type="password"] {
        font-size: 1rem; /* Prevent iOS zoom */
    }
}

/* Responsive */
@media (max-width: 991.98px) {
    .rintin-myaccount__nav {
        margin-bottom: 1rem;
    }

    .rintin-myaccount__menu-item.is-active a {
        border-right: none;
        border-left: 3px solid var(--rintin-green);
    }

    .rintin-myaccount__content {
        padding: 1.5rem;
    }

    .rintin-auth__card {
        padding: 1.5rem;
    }
}
