/* =============================================
   styles.css — Styles principaux JaiMaZone
   ============================================= */

/* BASE */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{background:var(--black);color:var(--cream);font-family:var(--font-body);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
button{cursor:pointer;border:none;background:none;font-family:inherit;}

/* NAV */
.nav{position:sticky;top:0;z-index:100;background:rgba(10,10,10,.88);backdrop-filter:blur(18px) saturate(1.4);border-bottom:1px solid var(--border);padding:0 var(--padding-x);height:64px;display:flex;align-items:center;gap:24px;}
.nav-logo{font-family:var(--font-display);font-size:22px;font-weight:800;letter-spacing:-.5px;white-space:nowrap;}
.nav-logo span{color:var(--orange);}
.nav-search{flex:1;max-width:480px;position:relative;}
.nav-search input{width:100%;background:var(--card);border:1.5px solid var(--border);border-radius:50px;padding:9px 20px 9px 44px;color:var(--cream);font-family:var(--font-body);font-size:14px;outline:none;transition:border-color var(--transition);}
.nav-search input::placeholder{color:var(--grey-md);}
.nav-search input:focus{border-color:var(--orange);}
.nav-search-icon{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:var(--grey-md);pointer-events:none;}
.nav-meta{margin-left:auto;display:flex;align-items:center;gap:6px;font-size:12px;color:var(--grey-lt);white-space:nowrap;}
.nav-dot{width:7px;height:7px;border-radius:50%;background:var(--green);animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.3;}}

/* HERO */
.hero{padding:clamp(48px,8vw,96px) var(--padding-x) clamp(40px,6vw,72px);display:grid;grid-template-columns:1fr auto;gap:32px;align-items:end;border-bottom:1px solid var(--border);position:relative;overflow:hidden;}
.hero::before{content:'';position:absolute;top:-120px;right:-80px;width:560px;height:560px;background:radial-gradient(circle,rgba(255,149,0,.12) 0%,transparent 65%);pointer-events:none;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(255,149,0,.12);border:1px solid rgba(255,149,0,.3);color:var(--orange);font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:6px 14px;border-radius:50px;margin-bottom:20px;}
.hero-title{font-family:var(--font-display);font-size:clamp(32px,5.5vw,68px);font-weight:800;line-height:1.05;letter-spacing:-1.5px;margin-bottom:18px;}
.hero-title em{font-style:normal;color:var(--orange);}
.hero-subtitle{color:var(--grey-lt);font-size:16px;max-width:520px;line-height:1.7;}
.hero-stats{display:flex;flex-direction:column;gap:16px;padding:24px;background:var(--card);border:1px solid var(--border);border-radius:var(--r-xl);min-width:200px;text-align:right;}
.hero-stat-num{font-family:var(--font-display);font-size:36px;font-weight:800;color:var(--orange);line-height:1;}
.hero-stat-label{font-size:12px;color:var(--grey-lt);margin-top:2px;}
.hero-stat-divider{height:1px;background:var(--border);}

/* FILTRES */
.filters-wrap{padding:20px var(--padding-x);border-bottom:1px solid var(--border);position:sticky;top:64px;z-index:90;background:rgba(10,10,10,.92);backdrop-filter:blur(16px);}
.filters{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px;}
.filters::-webkit-scrollbar{display:none;}
.filter-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:50px;font-size:13px;font-weight:500;white-space:nowrap;transition:all var(--transition);border:1.5px solid var(--border);color:var(--grey-lt);background:var(--card);}
.filter-btn:hover{border-color:var(--orange);color:var(--orange);}
.filter-btn.active{background:var(--orange);border-color:var(--orange);color:var(--black);font-weight:600;}

/* RESULTS BAR */
.results-bar{padding:16px var(--padding-x);display:flex;align-items:center;justify-content:space-between;gap:12px;}
.results-count{font-size:13px;color:var(--grey-lt);}
.results-count strong{color:var(--cream);}
.sort-select{background:var(--card);border:1.5px solid var(--border);color:var(--cream);padding:7px 14px;border-radius:var(--r-sm);font-family:var(--font-body);font-size:13px;outline:none;cursor:pointer;}

/* GRILLE */
.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;padding:8px var(--padding-x) clamp(40px,6vw,80px);}

/* CARTE */
.product-card{background:var(--card);border:1.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);position:relative;animation:fadeUp .45s ease both;}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover);border-color:rgba(255,149,0,.35);}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px);}to{opacity:1;transform:translateY(0);}}
.card-rank{position:absolute;top:12px;left:12px;width:32px;height:32px;border-radius:50%;background:rgba(10,10,10,.85);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:12px;font-weight:700;color:var(--grey-lt);z-index:2;}
.card-rank.top3{background:var(--orange);border-color:var(--orange);color:var(--black);}
.card-badge{position:absolute;top:12px;right:12px;padding:4px 10px;border-radius:50px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;z-index:2;}
.badge-gold{background:var(--gold);color:#000;}
.badge-red{background:var(--red);color:#fff;}
.badge-green{background:var(--green);color:#fff;}
.badge-blue{background:var(--blue);color:#fff;}
.badge-pink{background:var(--pink);color:#fff;}
.card-image{height:190px;display:flex;align-items:center;justify-content:center;background:#191919;border-bottom:1px solid var(--border);font-size:72px;position:relative;overflow:hidden;}
.card-image::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent 60%,rgba(28,28,28,.6));}
.card-body{padding:18px;flex:1;display:flex;flex-direction:column;gap:10px;}
.card-category{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--orange);}
.card-title{font-family:var(--font-display);font-size:15px;font-weight:700;line-height:1.35;color:var(--cream);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.card-desc{font-size:13px;color:var(--grey-lt);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.card-points{display:flex;flex-wrap:wrap;gap:5px;margin-top:2px;}
.card-point{font-size:11px;padding:3px 9px;background:rgba(255,149,0,.08);border:1px solid rgba(255,149,0,.2);border-radius:50px;color:var(--orange-lt);}
.card-rating{display:flex;align-items:center;gap:8px;}
.stars{color:var(--gold);font-size:13px;letter-spacing:1px;}
.rating-num{font-size:13px;font-weight:600;color:var(--cream);}
.rating-count{font-size:12px;color:var(--grey-md);}
.card-footer{padding:14px 18px 18px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;}
.card-price{display:flex;flex-direction:column;gap:2px;}
.price-current{font-family:var(--font-display);font-size:22px;font-weight:800;color:var(--orange);line-height:1;}
.price-old{font-size:12px;color:var(--grey-md);text-decoration:line-through;}
.btn-amazon{display:inline-flex;align-items:center;gap:8px;background:var(--orange);color:var(--black);font-weight:700;font-size:13px;padding:10px 18px;border-radius:var(--r-sm);transition:all var(--transition);white-space:nowrap;}
.btn-amazon:hover{background:var(--orange-lt);transform:scale(1.04);}

/* ÉTATS SPÉCIAUX */
.empty-state{grid-column:1/-1;text-align:center;padding:80px 24px;color:var(--grey-md);}
.empty-state .icon{font-size:48px;margin-bottom:16px;}
.empty-state h3{font-family:var(--font-display);font-size:20px;color:var(--cream);margin-bottom:8px;}
.loading-state{grid-column:1/-1;text-align:center;padding:80px 24px;color:var(--grey-md);display:flex;flex-direction:column;align-items:center;gap:16px;}
.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--orange);border-radius:50%;animation:spin 0.8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* BANDEAU AFFILIATION */
.affil-banner{margin:0 var(--padding-x) 32px;padding:14px 20px;background:rgba(255,149,0,.06);border:1px solid rgba(255,149,0,.2);border-radius:var(--r-md);display:flex;align-items:center;gap:12px;font-size:13px;color:var(--grey-lt);}
.affil-banner strong{color:var(--cream);}

/* FOOTER */
.footer{border-top:1px solid var(--border);padding:clamp(32px,5vw,56px) var(--padding-x);display:grid;grid-template-columns:1fr 1fr 1fr;gap:32px;}
.footer-brand p{font-size:13px;color:var(--grey-md);line-height:1.7;margin-top:12px;}
.footer-col h4{font-family:var(--font-display);font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--grey-lt);margin-bottom:14px;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:8px;}
.footer-col ul li a{font-size:13px;color:var(--grey-md);transition:color var(--transition);}
.footer-col ul li a:hover{color:var(--orange);}
.footer-bottom{border-top:1px solid var(--border);padding:20px var(--padding-x);display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:12px;color:var(--grey-md);flex-wrap:wrap;}
.footer-bottom a{color:var(--grey-md);transition:color var(--transition);}
.footer-bottom a:hover{color:var(--orange);}

/* SCROLL TOP */
.scroll-top{position:fixed;bottom:24px;right:24px;width:44px;height:44px;background:var(--orange);color:var(--black);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(255,149,0,.4);opacity:0;transform:translateY(16px);transition:all var(--transition);pointer-events:none;z-index:200;}
.scroll-top.visible{opacity:1;transform:translateY(0);pointer-events:all;}
.scroll-top:hover{background:var(--orange-lt);}

/* RESPONSIVE */
@media(max-width:900px){
  .hero{grid-template-columns:1fr;}
  .hero-stats{flex-direction:row;min-width:unset;text-align:left;align-items:center;}
  .hero-stat-divider{width:1px;height:40px;}
  .footer{grid-template-columns:1fr 1fr;}
  .footer-brand{grid-column:1/-1;}
}
@media(max-width:600px){
  .nav-meta{display:none;}
  .products-grid{grid-template-columns:1fr;}
  .footer{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;text-align:center;}
}
