/* Auth pages */
.auth-page { min-height: 100vh; display: flex; align-items: center; justify-content: center; background: var(--dark); padding: 2rem 1rem; }
.auth-wrap { width: 100%; max-width: 480px; }
.auth-card { background: var(--card-bg); border: 1px solid var(--border); border-radius: 20px; padding: 2.5rem; backdrop-filter: blur(20px); }
.auth-card-wide { max-width: 560px; margin: 0 auto; }
.auth-logo { text-align: center; margin-bottom: 1.75rem; }
.auth-logo .logo-icon { font-size: 2.5rem; display: block; margin-bottom: 0.5rem; }
.auth-logo h1 { font-family: 'Playfair Display', serif; color: var(--gold); font-size: 1.6rem; }
.auth-logo p { color: var(--text-muted); font-size: 0.85rem; margin-top: 0.25rem; }
.auth-submit { width: 100%; justify-content: center; margin-top: 0.5rem; }
.auth-alt, .auth-back { text-align: center; margin-top: 1.25rem; font-size: 0.875rem; color: var(--text-muted); }
.auth-alt a, .auth-back a { color: var(--gold); }
.form-group { margin-bottom: 1rem; }
.form-group label { display: block; color: var(--text-light); font-size: 0.8rem; font-weight: 500; margin-bottom: 0.4rem; text-transform: uppercase; letter-spacing: 0.05em; }
.form-group input, .form-group textarea {
    width: 100%; padding: 0.8rem 1rem; background: rgba(255,255,255,0.05);
    border: 1px solid var(--border); border-radius: 10px; color: var(--text);
    font-family: 'DM Sans', sans-serif; font-size: 0.95rem; outline: none; box-sizing: border-box;
}
.form-group input:focus, .form-group textarea:focus { border-color: var(--gold); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.field-error { color: #ff6b6b; font-size: 0.78rem; margin-top: 0.35rem; display: block; }
.msg { padding: 0.75rem 1rem; border-radius: 8px; font-size: 0.875rem; margin-bottom: 1rem; text-align: center; }
.msg-error { background: rgba(220,53,69,0.15); border: 1px solid rgba(220,53,69,0.3); color: #ff6b6b; }
.msg-success { background: rgba(40,167,69,0.15); border: 1px solid rgba(40,167,69,0.3); color: #75d4a0; }

/* Navbar cart & user */
.nav-cart { position: relative; color: var(--text-light); padding: 0.5rem; display: flex; align-items: center; }
.nav-cart:hover { color: var(--gold); }
.cart-badge {
    position: absolute; top: 0; right: 0; background: var(--gold); color: var(--dark);
    font-size: 0.65rem; font-weight: 700; min-width: 18px; height: 18px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
}
.nav-link-btn { background: none; border: none; color: var(--text-light); font-size: 0.85rem; cursor: pointer; padding: 0.5rem; }
.nav-link-btn:hover { color: var(--gold); }
.nav-user { display: flex; align-items: center; gap: 0.5rem; }
.nav-user-email { font-size: 0.75rem; color: var(--text-muted); max-width: 120px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.nav-logout-form { display: inline; }
.mobile-logout-btn { width: 100%; border: none; cursor: pointer; font-family: inherit; }

/* Shop pages */
.shop-page { padding: 6.5rem 2rem 4rem; min-height: 70vh; }
.shop-container { max-width: 1000px; margin: 0 auto; }
.shop-header { margin-bottom: 2rem; }
.shop-header h1 { font-family: 'Playfair Display', serif; font-size: 2rem; color: var(--cream); }
.shop-header p { color: var(--text-muted); margin-top: 0.35rem; }

.cart-table { width: 100%; border-collapse: collapse; }
.cart-table th, .cart-table td { padding: 1rem; text-align: left; border-bottom: 1px solid var(--border-light); }
.cart-table th { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-muted); }
.cart-product { display: flex; align-items: center; gap: 1rem; }
.cart-emoji { font-size: 2rem; }
.cart-qty-form { display: flex; align-items: center; gap: 0.5rem; }
.cart-qty-form input { width: 60px; padding: 0.4rem; text-align: center; background: rgba(255,255,255,0.05); border: 1px solid var(--border); border-radius: 6px; color: var(--text); }
.btn-remove { background: none; border: none; color: #ff6b6b; cursor: pointer; font-size: 0.85rem; }
.cart-summary {
    margin-top: 2rem; padding: 1.5rem; background: var(--card-bg);
    border: 1px solid var(--border); border-radius: 16px; max-width: 360px; margin-left: auto;
}
.cart-summary-row { display: flex; justify-content: space-between; margin-bottom: 0.75rem; color: var(--text-light); }
.cart-summary-total { font-size: 1.25rem; font-weight: 700; color: var(--gold); border-top: 1px solid var(--border-light); padding-top: 0.75rem; margin-top: 0.75rem; }
.cart-actions { display: flex; gap: 0.75rem; margin-top: 1.25rem; flex-wrap: wrap; }

.empty-cart { text-align: center; padding: 4rem 2rem; color: var(--text-muted); }
.empty-cart span { font-size: 3rem; display: block; margin-bottom: 1rem; }

.add-cart-form { display: flex; gap: 0.75rem; align-items: center; flex-wrap: wrap; margin-top: 0.5rem; }
.add-cart-form label { font-size: 0.85rem; color: var(--text-muted); }
.add-cart-form input[type=number] {
    width: 70px; padding: 0.6rem; border-radius: 8px; border: 1px solid var(--border);
    background: rgba(255,255,255,0.05); color: var(--text);
}

.orders-list { display: flex; flex-direction: column; gap: 1rem; }
.order-card {
    background: var(--card-bg); border: 1px solid var(--border); border-radius: 14px;
    padding: 1.25rem 1.5rem; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem;
}
.order-card:hover { border-color: var(--gold); }
.order-id { font-family: monospace; font-size: 0.8rem; color: var(--text-muted); }
.order-status {
    font-size: 0.7rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em;
    padding: 0.3rem 0.75rem; border-radius: 50px; background: rgba(201,147,58,0.15); color: var(--gold);
}
.order-status.CONFIRMED { background: rgba(74,222,128,0.15); color: #4ade80; }
.order-status.DELIVERED { background: rgba(96,165,250,0.15); color: #60a5fa; }
.order-status.CANCELLED { background: rgba(255,107,107,0.15); color: #ff6b6b; }

.order-detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; margin-top: 1.5rem; }
.order-items-table { width: 100%; border-collapse: collapse; margin-top: 1rem; }
.order-items-table td, .order-items-table th { padding: 0.75rem; border-bottom: 1px solid var(--border-light); text-align: left; }

.checkout-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2.5rem; align-items: start; }
.checkout-form-card { background: var(--card-bg); border: 1px solid var(--border); border-radius: 16px; padding: 1.5rem; }

.flash-banner {
    background: rgba(40,167,69,0.15); border: 1px solid rgba(40,167,69,0.3);
    color: #75d4a0; padding: 0.85rem 1rem; border-radius: 10px; margin-bottom: 1.5rem;
}

.card-footer { flex-wrap: wrap; gap: 0.5rem; }
.card-cart-form { display: inline; }
.card-footer .card-btn-secondary { background: transparent; border: 1px solid var(--border); }
.card-footer .card-btn { flex: 1; min-width: 70px; text-align: center; }

/* Mobile cart/checkout: see mobile.css */
