/*
Theme Name: BooksDZ Theme
Theme URI: https://booksdz.com
Author: BooksDZ
Description: Thème premium pour BooksDZ - La Librairie d'Excellence
Version: 1.0.0
Text Domain: booksdz
*/


/* =============================================
   BooksDZ – Style Premium
   ============================================= */
:root {
  --primary: #4f63ff;
  --primary-dark: #3448e0;
  --accent: #f59e0b;
  --success: #10b981;
  --dark-900: #0d0f1a;
  --dark-800: #141627;
  --dark-700: #1c1f35;
  --dark-600: #252849;
  --dark-400: #3a3f6e;
  --dark-200: #6b72a8;
  --text-light: #e2e5ff;
  --text-muted: #8b91c4;
  --white: #ffffff;
  --card-bg: #ffffff;
  --body-bg: #f4f6ff;
  --border: #e0e4f7;
  --gold: #c9a227;
  --font: 'Cairo','Tajawal',sans-serif;
  --r: 12px;
  --r-lg: 20px;
  --sh: 0 4px 24px rgba(79,99,255,.12);
  --sh-lg: 0 12px 48px rgba(79,99,255,.22);
  --tr: all .28s cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--font);background:var(--body-bg);color:#1a1d3a;direction:rtl;overflow-x:hidden;}
a{text-decoration:none;color:inherit;}
img{display:block;max-width:100%;}

/* ---- Announce Bar ---- */
.announce-bar{background:linear-gradient(90deg,var(--primary-dark),var(--primary));color:#fff;text-align:center;padding:9px 12px;font-size:.82rem;font-weight:600;letter-spacing:.01em;}

/* ---- Header ---- */
.site-header{background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:200;box-shadow:0 2px 16px rgba(0,0,0,.06);}
.header-inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:16px;padding:10px 24px;}

/* Left */
.header-left{position:relative;}
.cat-toggle-btn{display:flex;align-items:center;gap:8px;background:var(--dark-700);color:var(--text-light);border:none;border-radius:8px;padding:8px 14px;cursor:pointer;font-family:var(--font);font-size:.85rem;font-weight:700;transition:var(--tr);}
.cat-toggle-btn:hover{background:var(--dark-600);}
.hamburger{display:flex;flex-direction:column;gap:4px;}
.hamburger span{display:block;width:18px;height:2px;background:var(--text-light);border-radius:2px;transition:var(--tr);}
.cat-menu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--sh-lg);min-width:220px;overflow:hidden;display:none;z-index:300;flex-direction:column;}
.cat-menu.open{display:flex;}
.cat-item{padding:11px 18px;font-size:.9rem;font-weight:600;color:#1a1d3a;transition:var(--tr);border-bottom:1px solid #f0f2ff;}
.cat-item:last-child{border-bottom:none;}
.cat-item:hover{background:var(--body-bg);color:var(--primary);}

/* Logo */
.header-logo{text-align:center;}
.logo-link{display:flex;flex-direction:column;align-items:center;gap:2px;}
.logo-icon{font-size:2rem;line-height:1;}
.logo-main{font-size:1.55rem;font-weight:900;color:#1a1d3a;letter-spacing:-1px;}
.logo-dz{color:var(--primary);}
.logo-sub{font-size:.65rem;color:var(--text-muted);letter-spacing:.06em;font-weight:500;}

/* Right */
.header-right{display:flex;align-items:center;gap:10px;justify-content:flex-end;}
.search-wrap{position:relative;}
.search-input{border:1.5px solid var(--border);border-radius:999px;padding:8px 16px 8px 36px;font-family:var(--font);font-size:.85rem;outline:none;width:200px;background:var(--body-bg);transition:var(--tr);direction:rtl;}
.search-input:focus{border-color:var(--primary);background:#fff;width:240px;box-shadow:0 0 0 3px rgba(79,99,255,.1);}
.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:.9rem;pointer-events:none;}
.cart-btn{position:relative;background:var(--dark-700);border:none;border-radius:999px;width:42px;height:42px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--tr);}
.cart-btn:hover{background:var(--primary);}
.cart-icon{font-size:1.1rem;}
.cart-count{position:absolute;top:-3px;left:-3px;background:var(--accent);color:#fff;font-size:.65rem;font-weight:800;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;}

/* ---- Hero Banner ---- */
.hero-banner{position:relative;background:var(--dark-800);min-height:260px;display:flex;align-items:center;overflow:hidden;}
.hero-bg-overlay{position:absolute;inset:0;background:linear-gradient(135deg,var(--dark-900) 0%,var(--dark-600) 100%);opacity:.9;}
.hero-bg-overlay::after{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%234f63ff' fill-opacity='0.05'%3E%3Cpath d='M0 40L40 0H20L0 20M40 40V20L20 40'/%3E%3C/g%3E%3C/svg%3E");}
.hero-banner-content{position:relative;z-index:1;text-align:center;padding:48px 24px;}
.hero-eyebrow{font-size:.88rem;color:rgba(255,255,255,.6);margin-bottom:10px;}
.hero-title{font-size:2.4rem;font-weight:900;color:#fff;line-height:1.2;margin-bottom:12px;}
.hero-sub{font-size:1rem;color:rgba(255,255,255,.7);margin-bottom:28px;}
.hero-cta{display:inline-block;background:var(--gold);color:#1a1d3a;padding:12px 32px;border-radius:999px;font-weight:800;font-size:.95rem;transition:var(--tr);box-shadow:0 6px 24px rgba(201,162,39,.35);}
.hero-cta:hover{transform:translateY(-2px);box-shadow:0 10px 32px rgba(201,162,39,.45);}

/* ---- Trust Strip ---- */
.trust-strip{background:#fff;border-bottom:1px solid var(--border);padding:12px 0;}
.trust-items{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;}
.trust-item{display:flex;align-items:center;gap:6px;font-size:.82rem;font-weight:600;color:#44476b;}
.t-icon{font-size:1rem;}
.trust-sep{color:var(--border);font-size:1.2rem;}

/* ---- Catalogue Main ---- */
.catalogue-main{padding:48px 0 72px;}
.container{max-width:1180px;margin:0 auto;padding:0 20px;}
.cat-section-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:36px;gap:16px;flex-wrap:wrap;}
.cat-title{font-size:1.6rem;font-weight:900;color:#1a1d3a;}
.cat-desc{font-size:.88rem;color:var(--text-muted);margin-top:4px;}
.cat-sort{display:flex;align-items:center;gap:8px;font-size:.85rem;color:#44476b;font-weight:600;}
.cat-sort select{border:1.5px solid var(--border);border-radius:8px;padding:6px 12px;font-family:var(--font);font-size:.85rem;outline:none;background:#fff;cursor:pointer;}

/* ---- Products Grid ---- */
.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:28px;}

/* ---- Product Card ---- */
.product-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh);transition:var(--tr);display:flex;flex-direction:column;position:relative;cursor:pointer;}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--sh-lg);}
.product-card.bestseller{border:2px solid var(--accent);}
.product-card.pack{border:2px solid var(--primary);}
.card-badge{position:absolute;top:14px;right:14px;z-index:2;border-radius:999px;padding:4px 13px;font-size:.73rem;font-weight:800;color:#fff;}
.badge-hot{background:linear-gradient(135deg,#ef4444,#dc2626);}
.badge-new{background:linear-gradient(135deg,var(--success),#059669);}
.badge-pack{background:linear-gradient(135deg,var(--primary),var(--primary-dark));}
.badge-promo{background:linear-gradient(135deg,var(--accent),#d97706);}
.card-img-wrap{height:280px;background:linear-gradient(135deg,#f0f3ff,#e4e9ff);overflow:hidden;display:flex;align-items:center;justify-content:center;}
.card-img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease;}
.product-card:hover .card-img{transform:scale(1.04);}
.card-body{padding:18px;flex:1;display:flex;flex-direction:column;gap:7px;}
.card-cat{font-size:.72rem;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.05em;}
.card-title{font-size:1.05rem;font-weight:800;color:#1a1d3a;line-height:1.35;}
.card-desc{font-size:.82rem;color:#6b7280;flex:1;line-height:1.6;}
.card-rating{font-size:.78rem;color:#9ca3af;}
.card-pricing{display:flex;align-items:center;justify-content:space-between;margin-top:6px;}
.price-old{font-size:.82rem;color:#9ca3af;text-decoration:line-through;}
.price-new{font-size:1.3rem;font-weight:900;color:var(--primary);}
.free-delivery{font-size:.72rem;background:#f0fdf4;color:var(--success);padding:3px 10px;border-radius:999px;font-weight:700;border:1px solid #bbf7d0;}
.card-cta{margin-top:12px;width:100%;padding:13px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;border-radius:var(--r);font-family:var(--font);font-size:.95rem;font-weight:800;cursor:pointer;transition:var(--tr);box-shadow:0 4px 16px rgba(79,99,255,.25);}
.card-cta:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(79,99,255,.38);}
.card-cta.pack-cta{background:linear-gradient(135deg,#7c3aed,#6d28d9);}
.sold-count{font-size:.75rem;color:var(--text-muted);text-align:center;margin-top:6px;}

/* ---- Testimonials ---- */
.testimonials-sec{background:var(--dark-800);padding:64px 0;}
.sec-title{text-align:center;font-size:1.6rem;font-weight:900;color:#fff;margin-bottom:36px;}
.testi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;}
.testi-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-lg);padding:24px;transition:var(--tr);}
.testi-card:hover{background:rgba(255,255,255,.11);transform:translateY(-3px);}
.testi-stars{font-size:.9rem;margin-bottom:10px;}
.testi-card p{color:rgba(255,255,255,.8);font-size:.88rem;line-height:1.7;font-style:italic;margin-bottom:16px;}
.testi-author{display:flex;align-items:center;gap:10px;}
.testi-av{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#7c3aed);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem;}
.testi-author strong{display:block;color:#fff;font-size:.88rem;}
.testi-author small{color:rgba(255,255,255,.5);font-size:.75rem;}

/* ---- Footer ---- */
.site-footer{background:var(--dark-900);padding:48px 0 0;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;padding-bottom:40px;}
.footer-brand .logo-main{font-size:1.4rem;font-weight:900;color:#fff;}
.footer-brand p{margin-top:8px;font-size:.82rem;color:rgba(255,255,255,.5);line-height:1.7;}
.footer-col h4{color:#fff;font-size:.9rem;margin-bottom:12px;}
.footer-col{display:flex;flex-direction:column;gap:8px;}
.footer-col a{color:rgba(255,255,255,.55);font-size:.82rem;transition:var(--tr);}
.footer-col a:hover{color:var(--accent);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);text-align:center;padding:16px;font-size:.78rem;color:rgba(255,255,255,.35);}

/* ===========================================
   DARK MODAL – matches reference screenshot
   =========================================== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:12px;opacity:0;pointer-events:none;transition:opacity .3s ease;}
.modal-overlay.active{opacity:1;pointer-events:all;}

.dark-modal{background:var(--dark-800);border:1px solid var(--dark-400);border-radius:var(--r-lg);width:100%;max-width:470px;max-height:96vh;overflow-y:auto;position:relative;box-shadow:0 32px 80px rgba(0,0,0,.6);transform:translateY(24px) scale(.97);transition:transform .38s cubic-bezier(.34,1.56,.64,1);}
.modal-overlay.active .dark-modal{transform:translateY(0) scale(1);}

/* Product strip */
.modal-product-strip{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--dark-700);border-bottom:1px solid var(--dark-400);border-radius:var(--r-lg) var(--r-lg) 0 0;}
.modal-product-strip img{width:52px;height:64px;object-fit:cover;border-radius:6px;border:1px solid var(--dark-400);}
.modal-strip-info{flex:1;}
.modal-strip-title{font-size:.9rem;font-weight:700;color:var(--text-light);line-height:1.3;}
.modal-strip-badge{display:inline-block;margin-top:4px;background:rgba(79,99,255,.2);color:#a5b4fc;border-radius:999px;padding:2px 10px;font-size:.72rem;font-weight:700;}
.modal-x-btn{background:rgba(255,255,255,.08);border:none;color:rgba(255,255,255,.6);width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:var(--tr);margin-right:auto;}
.modal-x-btn:hover{background:rgba(255,255,255,.15);color:#fff;}

/* Form section */
.modal-form-section{padding:22px 22px 24px;}
.modal-main-title{font-size:1.5rem;font-weight:900;color:var(--white);text-align:center;margin-bottom:4px;}
.modal-main-sub{font-size:.82rem;color:var(--text-muted);text-align:center;margin-bottom:20px;}

/* Dark fields */
.dark-field{position:relative;margin-bottom:12px;}
.dark-field input{width:100%;background:var(--dark-700);border:1.5px solid var(--dark-400);border-radius:var(--r);color:var(--text-light);font-family:var(--font);font-size:.92rem;padding:13px 16px 13px 44px;outline:none;transition:var(--tr);direction:rtl;}
.dark-field input::placeholder{color:var(--text-muted);}
.dark-field input:focus{border-color:var(--primary);background:var(--dark-600);box-shadow:0 0 0 3px rgba(79,99,255,.18);}
.dark-field-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:.95rem;pointer-events:none;}

/* Dark row (wilaya + commune) */
.dark-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px;}
.dark-select-wrap{position:relative;}
.dark-select-wrap select{width:100%;background:var(--dark-700);border:1.5px solid var(--dark-400);border-radius:var(--r);color:var(--text-light);font-family:var(--font);font-size:.85rem;padding:13px 36px 13px 36px;outline:none;appearance:none;-webkit-appearance:none;cursor:pointer;direction:rtl;transition:var(--tr);}
.dark-select-wrap select:focus{border-color:var(--primary);background:var(--dark-600);}
.dark-select-wrap select option{background:var(--dark-800);color:var(--text-light);}
.dark-sel-icon{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:.85rem;pointer-events:none;}
.dark-sel-arrow{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:.75rem;color:var(--text-muted);pointer-events:none;}

/* Delivery buttons */
.delivery-section{margin-bottom:14px;}
.delivery-label{font-size:.82rem;color:var(--text-muted);text-align:center;margin-bottom:10px;}
.delivery-btns{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.deliv-btn{background:var(--dark-700);border:1.5px solid var(--dark-400);border-radius:var(--r);color:var(--text-muted);font-family:var(--font);font-size:.88rem;font-weight:700;padding:13px 10px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:5px;transition:var(--tr);}
.deliv-btn:hover{border-color:var(--primary);color:var(--text-light);}
.deliv-btn.active{border-color:var(--primary);background:rgba(79,99,255,.18);color:#a5b4fc;}
.deliv-icon{font-size:1.3rem;}

/* Price summary */
.price-summary{background:var(--dark-700);border:1px solid var(--dark-400);border-radius:var(--r);padding:14px 16px;margin-bottom:16px;display:flex;flex-direction:column;gap:9px;}
.price-row{display:flex;justify-content:space-between;font-size:.88rem;color:var(--text-muted);}
.price-row span:last-child{font-weight:700;color:var(--text-light);}
.price-total{border-top:1px dashed var(--dark-400);padding-top:9px;margin-top:4px;font-size:1rem;}
.price-total span:first-child{color:var(--white);font-weight:800;font-size:1rem;}
.price-total span:last-child{color:var(--primary);font-size:1.2rem;font-weight:900;}

/* Confirm button */
.confirm-btn{width:100%;padding:15px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border:none;border-radius:var(--r);color:#fff;font-family:var(--font);font-size:1rem;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:var(--tr);box-shadow:0 6px 24px rgba(79,99,255,.35);margin-bottom:10px;}
.confirm-btn:hover{transform:translateY(-2px);box-shadow:0 10px 32px rgba(79,99,255,.48);}
.confirm-btn:active{transform:translateY(0);}
.confirm-icon{font-size:1rem;}
.secure-note{text-align:center;font-size:.78rem;color:var(--success);font-weight:600;}

/* Success */
.modal-success{padding:48px 28px;text-align:center;}
.success-anim{font-size:4rem;margin-bottom:16px;animation:pop .5s cubic-bezier(.34,1.56,.64,1);}
@keyframes pop{from{transform:scale(0)}to{transform:scale(1)}}
.modal-success h3{font-size:1.4rem;font-weight:900;color:var(--white);margin-bottom:10px;}
.modal-success p{color:var(--text-muted);font-size:.92rem;margin-bottom:8px;}
.success-brand{color:var(--primary)!important;font-weight:700;margin-bottom:24px!important;}

/* ---- Responsive ---- */
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;}.footer-brand{grid-column:1/-1;}}
@media(max-width:640px){
  .header-inner{grid-template-columns:auto 1fr auto;gap:10px;}
  .header-left{order:1;}.header-logo{order:2;}.header-right{order:3;}
  .search-input{width:120px;}.search-input:focus{width:150px;}
  .hero-title{font-size:1.6rem;}
  .products-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .dark-row{grid-template-columns:1fr;}
}
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-track{background:var(--body-bg);}
::-webkit-scrollbar-thumb{background:#c7cbeb;border-radius:999px;}
