/* ── Flash messages ───────────────────────────────────────────────────── */
.messages-container { position:fixed; top:80px; right:20px; z-index:9999; display:flex; flex-direction:column; gap:8px; max-width:360px; pointer-events:none; }
.alert { padding:12px 18px; border-radius:10px; font-size:.875rem; font-weight:500; display:flex; align-items:center; gap:10px; box-shadow:0 4px 20px rgba(0,0,0,.12); animation:slideIn .3s ease; pointer-events:all; }
@keyframes slideIn { from{opacity:0;transform:translateX(40px)} to{opacity:1;transform:translateX(0)} }
.alert-success { background:#f0fdf4; color:#166534; border:1px solid #bbf7d0; }
.alert-error   { background:#fef2f2; color:#991b1b; border:1px solid #fecaca; }

/* ── Client type bar ──────────────────────────────────────────────────── */
.client-type-bar { display:flex; align-items:center; gap:12px; padding:6px 20px; font-size:.8rem; background:#0f2233; color:rgba(255,255,255,.8); flex-wrap:wrap; }
.ct-normal    { color:#43dde6; }
.ct-revendeur { color:#fb923c; }
.ct-grossiste { color:#a78bfa; }

/* ── Auth pages ───────────────────────────────────────────────────────── */
.auth-page  { min-height:70vh; display:flex; align-items:center; justify-content:center; padding:40px 16px; background:#f7f9fc; }
.auth-box   { background:#fff; border-radius:20px; padding:36px; width:100%; max-width:440px; box-shadow:0 4px 32px rgba(0,0,0,.09); }
.auth-box h2 { font-size:1.5rem; font-weight:800; color:#17344c; margin-bottom:24px; text-align:center; }
.auth-box h2 i { color:#f02443; margin-right:8px; }
.auth-box .form-group { margin-bottom:16px; }
.auth-box .form-group label { display:block; font-size:.8rem; font-weight:700; color:#17344c; margin-bottom:5px; text-transform:uppercase; letter-spacing:.04em; }
.auth-box .form-group input { width:100%; padding:10px 14px; border:1.5px solid #e5e7eb; border-radius:8px; font-size:.9rem; color:#17344C; outline:none; transition:border .2s; box-sizing:border-box; }
.auth-box .form-group input:focus { border-color:#43dde6; box-shadow:0 0 0 3px rgba(67,221,230,.12); }
.btn-auth { width:100%; padding:13px; background:#17344c; color:#fff; border:none; border-radius:10px; font-size:.95rem; font-weight:700; cursor:pointer; transition:background .2s; font-family: 'urbane', sans-serif; }
.btn-auth:hover { background:#43dde6; }
.auth-link { text-align:center; margin-top:16px; font-size:.85rem; color:#888; }
.auth-link a { color:#17344c; font-weight:700; text-decoration:none; }
.auth-link a:hover { color:#43dde6; }
.field-error { color:#f02443; font-size:.75rem; margin-top:3px; display:block; }
.auth-input { box-sizing:border-box; }

/* ── Cart ─────────────────────────────────────────────────────────────── */
.cart-layout { display:grid; grid-template-columns:1fr 340px; gap:24px; }
.cart-items  { background:#fff; border-radius:16px; box-shadow:0 2px 16px rgba(0,0,0,.06); overflow:hidden; }
.cart-item   { display:grid; grid-template-columns:90px 1fr auto auto auto; align-items:center; gap:14px; padding:16px 20px; border-bottom:1px solid #f5f5f5; }
.cart-item:last-child { border:none; }
.cart-item img { width:80px; height:80px; object-fit:contain; background:#f8f8f8; border-radius:8px; padding:6px; }
.cart-item-info h3 { font-size:.88rem; font-weight:700; color:#17344C; margin-bottom:4px; }
.cart-item-info h3:hover { color:#f02443; }
.cart-item-info a { text-decoration:none; }
.cart-item-price { color:#888; font-size:.82rem; }
.cart-item-qty span { font-weight:700; color:#17344C; padding:0 6px; }
.cart-item-subtotal { font-weight:800; color:#f02443; white-space:nowrap; }
.cart-remove { color:#ccc; font-size:1rem; transition:color .2s; }
.cart-remove:hover { color:#f02443; }
.cart-summary { background:#fff; border-radius:16px; box-shadow:0 2px 16px rgba(0,0,0,.06); padding:24px; height:fit-content; position:sticky; top:90px; }
.cart-summary h3 { font-size:1.05rem; font-weight:800; color:#17344C; margin-bottom:18px; }
.summary-row { display:flex; justify-content:space-between; font-size:.9rem; color:#555; margin-bottom:10px; }
.total-row   { font-size:1.05rem; font-weight:800; color:#17344C; border-top:1px solid #f0f0f0; padding-top:12px; margin-top:4px; }
hr { border:none; border-top:1px solid #f0f0f0; margin:10px 0; }
.btn-checkout { display:block; width:100%; padding:13px; background:#43dde6; color:#fff; border:none; border-radius:10px; font-size:.95rem; font-weight:800; text-align:center; text-decoration:none; cursor:pointer; margin-top:16px; transition:background .2s; }
.btn-checkout:hover { background:#fff;border: 2px solid #17344c; }
.btn-continue { display:inline-block; margin-top:10px; font-size:.82rem; color:#17344c; font-weight:600; text-decoration:none; text-align:center; width:100%; }
.btn-continue:hover { color:#f02443; }
.empty-cart { text-align:center; padding:80px 20px; }
.empty-cart i { font-size:3.5rem; color:#f0d0d8; display:block; margin-bottom:14px; }
.empty-cart p { font-size:1.05rem; font-weight:600; color:#888; margin-bottom:20px; }
@media(max-width:768px) { .cart-layout{grid-template-columns:1fr} .cart-item{grid-template-columns:70px 1fr;grid-template-rows:auto auto auto} }

/* ── Checkout / Payment ───────────────────────────────────────────────── */
.payment-page h2 { font-size:1.5rem; font-weight:800; color:#17344C; margin-bottom:24px; }
.payment-page h2 i { color:#f02443; margin-right:8px; }
.payment-layout { display:grid; grid-template-columns:340px 1fr; gap:24px; }
.payment-summary { background:#fff; border-radius:16px; box-shadow:0 2px 16px rgba(0,0,0,.06); padding:20px; height:fit-content; position:sticky; top:90px; }
.payment-summary h3 { font-size:1rem; font-weight:800; color:#17344C; margin-bottom:16px; padding-bottom:10px; border-bottom:1px solid #f0f0f0; }
.pay-item { display:flex; align-items:center; gap:10px; margin-bottom:12px; }
.pay-item img { width:50px; height:50px; object-fit:contain; background:#f8f8f8; border-radius:8px; padding:4px; flex-shrink:0; }
.pay-item-info { flex:1; }
.pay-item-name { font-size:.83rem; font-weight:600; color:#17344C; display:block; }
.pay-item-qty  { font-size:.75rem; color:#888; }
.pay-item-price{ font-weight:700; color:#f02443; white-space:nowrap; font-size:.88rem; }
.pay-total { display:flex; justify-content:space-between; font-size:.88rem; color:#555; margin-top:8px; }
.pay-total.bold { font-size:1rem; font-weight:800; color:#17344C; border-top:1px solid #f0f0f0; padding-top:10px; margin-top:4px; }
.pay-total .green { color:#15803d; font-weight:700; }
.payment-form { background:#fff; border-radius:16px; box-shadow:0 2px 16px rgba(0,0,0,.06); padding:28px; }
.payment-form h3 { font-size:1rem; font-weight:800; color:#17344C; margin-bottom:18px; margin-top:4px; }
.payment-form .form-group { margin-bottom:14px; }
.payment-form .form-group label { display:block; font-size:.78rem; font-weight:700; color:#17344c; margin-bottom:5px; text-transform:uppercase; letter-spacing:.04em; }
.payment-form .form-group input,
.payment-form .form-group textarea { width:100%; padding:10px 14px; border:1.5px solid #e5e7eb; border-radius:8px; font-size:.9rem; color:#17344C; outline:none; transition:border .2s; box-sizing:border-box; font-family: 'urbane', sans-serif; }
.payment-form .form-group input:focus,
.payment-form .form-group textarea:focus { border-color:#43dde6; }
.payment-form .form-group textarea { resize:vertical; min-height:70px; }
.payment-methods { display:flex; flex-direction:column; gap:12px; margin-bottom:20px; }
.pay-method { display:flex; align-items:flex-start; gap:10px; border:2px solid #e5e7eb; border-radius:12px; padding:14px; cursor:pointer; transition:all .2s; }
.pay-method:has(input:checked) { border-color:#17344c; background:#f7fbff; }
.pay-method input { margin-top:3px; accent-color:#17344c; flex-shrink:0; }
.pay-method-content { display:flex; align-items:flex-start; gap:12px; }
.pay-method-content i { font-size:1.3rem; color:#17344c; margin-top:2px; }
.pay-method-content strong { display:block; font-size:.9rem; color:#17344C; }
.pay-method-content small { font-size:.78rem; color:#888; line-height:1.4; }
.btn-confirm-order { width:100%; padding:15px; background:#f02443; color:#fff; border:none; border-radius:12px; font-size:1rem; font-weight:800; cursor:pointer; transition:background .2s; font-family: 'urbane', sans-serif; display:flex; align-items:center; justify-content:center; gap:8px; }
.btn-confirm-order:hover { background:#c01235; }
@media(max-width:768px) { .payment-layout{grid-template-columns:1fr} }

/* ── Order Success ────────────────────────────────────────────────────── */
.success-page { max-width:680px; margin:60px auto; padding:0 16px 80px; }
.success-card { background:#fff; border-radius:20px; box-shadow:0 4px 32px rgba(0,0,0,.09); padding:36px; text-align:center; }
.success-icon { font-size:4rem; color:#22c55e; margin-bottom:14px; }
.success-card h2 { font-size:1.6rem; font-weight:800; color:#17344C; margin-bottom:8px; }
.success-card > p { color:#888; font-size:.9rem; margin-bottom:24px; }
.success-details { background:#f8fafc; border-radius:12px; padding:16px 20px; text-align:left; margin-bottom:20px; }
.success-row { display:flex; justify-content:space-between; padding:7px 0; font-size:.875rem; color:#555; border-bottom:1px solid #f0f0f0; }
.success-row:last-child { border:none; }
.success-row strong { color:#17344C; font-weight:700; }
.success-actions { display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin-top:20px; }
.success-actions .btn-auth { width:auto; padding:11px 22px; }

/* ── Shop page ────────────────────────────────────────────────────────── */
.filters-bar { display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-bottom:20px; }
.filters-bar select, .filters-bar input[type=number] { padding:9px 12px; border:1.5px solid #e5e7eb; border-radius:8px; font-size:.85rem; color:#17344C; outline:none; background:#fff; min-width:140px; }
.filters-bar select:focus, .filters-bar input:focus { border-color:#43dde6; }
.filters-bar button { padding:9px 18px; background:#17344c; color:#fff; border:none; border-radius:8px; font-size:.85rem; font-weight:600; cursor:pointer; transition:background .2s; }
.filters-bar button:hover { background:#f02443; }
.reset-btn { padding:9px 14px; background:#f0f0f0; color:#555; border-radius:8px; font-size:.85rem; font-weight:600; text-decoration:none; transition:background .2s; }
.reset-btn:hover { background:#e0e0e0; }
.active-filters { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-bottom:14px; font-size:.82rem; color:#888; }
.filter-tag { background:#f0f4ff; color:#17344c; border-radius:999px; padding:3px 10px; font-weight:600; display:flex; align-items:center; gap:5px; }
.filter-tag a { color:#f02443; text-decoration:none; font-weight:700; }

/* ── Pagination ───────────────────────────────────────────────────────── */
.pagination { display:flex; gap:5px; justify-content:center; margin-top:28px; flex-wrap:wrap; }
.page-btn { display:inline-flex; align-items:center; justify-content:center; min-width:36px; height:36px; padding:0 10px; border-radius:8px; font-size:.83rem; background:#fff; border:1px solid #e5e7eb; color:#17344C; text-decoration:none; transition:all .2s; }
.page-btn:hover { background:#17344c; color:#fff; border-color:#17344c; }
.page-btn.active { background:#f02443; color:#fff; border-color:#f02443; font-weight:700; }

/* Empty shop */
.empty-shop { grid-column:1/-1; text-align:center; padding:80px 20px; color:#888; }
.empty-shop i { font-size:3rem; display:block; margin-bottom:16px; color:#f0d0d8; }

/* Stock badges in shop */
.stock-ok { color:#15803d; font-size:.75rem; font-weight:600; display:flex; align-items:center; gap:4px; }
.stock-no  { color:#bbb; font-size:.75rem; font-weight:600; display:flex; align-items:center; gap:4px; }
.btn-disabled { background:#f0f0f0 !important; color:#bbb !important; cursor:not-allowed !important; }

/* ── Typography hierarchy ─────────────────────────────────────────────────
   degular     → h1, h2, h3 (+ .h1 .h2 .h3)
   urbane      → body + tout le reste par héritage
   IBM Plex Sans Arabic → :lang(ar)
   ──────────────────────────────────────────────────────────────────────── */

/* urbane already loaded via typekit (use.typekit.net/olz3wvw.css) */

/* degular — only for headings */
h1, h2, h3,
.h1, .h2, .h3,
.pd-title,
.smartlife-title,
.slider-title,
.hits-title,
.bl-title-light-left,
.bl-title-light-right,
.bd-title-left,
.bd-title-right,
.hero h1,
.hero h2,
.hero h3,
.main-card h1,
.card1 h3, .card2 h3, .card3 h3, .card4 h3,
.auth-box h2,
.profile-name,
.confirm-title {
  font-family: "degular", sans-serif;
}

/* IBM Plex Sans Arabic — all Arabic text */
:lang(ar),
[lang="ar"],
.bd-title-right,
.bl-title-light-right,
.bd-desc-dark-right,
.bl-desc-light-right {
  font-family: "IBM Plex Sans Arabic", "degular", sans-serif;
}

/* Load IBM Plex Sans Arabic from Google Fonts (added dynamically) */

/* ============================================================
   Champs de saisie — survol & focus unifiés en #43dde6 (tout le site)
   (global.css n'est pas chargé par l'admin : son thème rouge reste intact)
   ============================================================ */
input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=file]):hover,
select:hover,
textarea:hover { border-color: #43dde6; }
input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=file]):focus,
select:focus,
textarea:focus { border-color: #43dde6 !important; outline: none; }
