/* ============================================================
   Supplement CSS — Shop, Catalog, Product, Cart
   À ajouter à la fin de public/assets/css/app.css
   ============================================================ */

/* ============================================================
   HERO SECTION
   ============================================================ */
.hero { background: linear-gradient(135deg, #0f0e17 0%, #1a1a2e 100%); padding: 80px 0 64px; overflow: hidden; }
.hero-container { max-width: 1280px; margin: 0 auto; padding: 0 24px; display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
.hero-badge { display: inline-block; background: rgba(108,99,255,.2); color: var(--color-primary); border: 1px solid rgba(108,99,255,.3); padding: 6px 14px; border-radius: 999px; font-size: .8rem; font-weight: 600; margin-bottom: 20px; }
.hero-title { font-size: clamp(2rem, 4vw, 3rem); font-weight: 900; color: #fff; line-height: 1.15; margin-bottom: 16px; letter-spacing: -0.5px; }
.hero-gradient { background: linear-gradient(135deg, var(--color-primary), var(--color-accent)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.hero-subtitle { color: rgba(255,255,255,.7); font-size: 1.05rem; margin-bottom: 32px; line-height: 1.6; }
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 40px; }
.btn-lg { padding: 14px 28px; font-size: 1rem; }
.hero-stats { display: flex; gap: 28px; }
.hero-stat-value { display: block; font-size: 1.5rem; font-weight: 800; color: #fff; }
.hero-stat-label { font-size: .78rem; color: rgba(255,255,255,.55); }

/* Code window decoratif */
.hero-visual { display: flex; align-items: center; justify-content: center; }
.code-window { background: #1e1e2e; border-radius: 12px; overflow: hidden; box-shadow: 0 20px 60px rgba(0,0,0,.5), 0 0 0 1px rgba(255,255,255,.08); width: 100%; max-width: 420px; }
.code-titlebar { background: #2a2a3e; padding: 10px 14px; display: flex; align-items: center; gap: 8px; }
.dot { width: 12px; height: 12px; border-radius: 50%; }
.dot-red { background: #ff5f56; }
.dot-yellow { background: #ffbd2e; }
.dot-green { background: #27c93f; }
.code-filename { margin-left: 8px; font-size: .8rem; color: rgba(255,255,255,.5); font-family: var(--font-mono); }
.code-body { padding: 20px; margin: 0; font-family: var(--font-mono); font-size: .85rem; line-height: 1.8; color: #cdd6f4; background: transparent; overflow-x: auto; }
.token-kw   { color: #cba6f7; }
.token-cls  { color: #89dceb; }
.token-fn   { color: #89b4fa; }
.token-type { color: #f9e2af; }
.token-var  { color: #cdd6f4; }
.token-comment { color: #6c7086; font-style: italic; }

/* ============================================================
   SECTIONS PUBLIQUES
   ============================================================ */
.section-container { max-width: 1280px; margin: 0 auto; padding: 0 24px; }
.products-section { padding: 60px 0; }
.products-section-alt { background: var(--color-surface-2); }
.section-header-public { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 28px; }
.section-title-public { font-size: 1.3rem; font-weight: 800; }
.section-subtitle { color: var(--color-text-muted); font-size: .875rem; margin-top: 4px; }
.products-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 20px; }

/* ============================================================
   PRODUCT CARD
   ============================================================ */
.product-card { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; transition: transform var(--transition), box-shadow var(--transition); }
.product-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.product-card-link { display: block; }
.product-card-image { position: relative; aspect-ratio: 16/9; overflow: hidden; background: var(--color-surface-2); }
.product-card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; }
.product-card:hover .product-card-image img { transform: scale(1.04); }
.product-card-placeholder { display: flex; align-items: center; justify-content: center; height: 100%; font-size: 3rem; color: var(--color-text-muted); }
.product-card-badge { position: absolute; top: 10px; left: 10px; padding: 3px 10px; border-radius: 999px; font-size: .72rem; font-weight: 700; }
.badge-sale     { background: var(--color-error); color: #fff; }
.badge-featured { background: #fbbf24; color: #78350f; }
.product-card-body { padding: 16px; }
.product-card-meta { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.product-card-category { font-size: .72rem; font-weight: 600; color: var(--color-primary); text-transform: uppercase; letter-spacing: .5px; }
.product-card-rating { font-size: .78rem; color: var(--color-text-muted); }
.rating-count { color: var(--color-text-muted); }
.product-card-title { font-size: .95rem; font-weight: 700; line-height: 1.4; margin-bottom: 6px; }
.product-card-title a { color: var(--color-text); }
.product-card-title a:hover { color: var(--color-primary); text-decoration: none; }
.product-card-desc { font-size: .8rem; color: var(--color-text-muted); line-height: 1.5; margin-bottom: 14px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.product-card-footer { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.price-normal, .price-normal-lg { font-weight: 800; color: var(--color-text); font-size: 1rem; }
.price-sale    { font-weight: 800; color: var(--color-error); font-size: 1rem; }
.price-sale-lg { font-weight: 900; color: var(--color-error); font-size: 1.5rem; }
.price-original { text-decoration: line-through; color: var(--color-text-muted); font-size: .85rem; margin-left: 6px; }
.price-original-lg { text-decoration: line-through; color: var(--color-text-muted); font-size: 1rem; margin-left: 8px; }
.discount-pct { background: var(--color-error); color: #fff; padding: 2px 8px; border-radius: 999px; font-size: .78rem; font-weight: 700; margin-left: 8px; }

/* ============================================================
   CATEGORIES
   ============================================================ */
.categories-section { padding: 16px 0; background: var(--color-surface); border-bottom: 1px solid var(--color-border); }
.categories-grid { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; }
.category-chip { display: inline-flex; align-items: center; gap: 6px; padding: 7px 16px; border-radius: 999px; background: var(--color-surface-2); border: 1.5px solid var(--color-border); font-size: .85rem; font-weight: 500; color: var(--color-text); transition: all var(--transition); text-decoration: none; }
.category-chip:hover { background: var(--color-primary); color: #fff; border-color: var(--color-primary); text-decoration: none; }
.category-icon { font-size: 1rem; }
.category-chip-more { color: var(--color-primary); font-weight: 600; }

/* ============================================================
   CTA SECTION
   ============================================================ */
.cta-section { padding: 64px 0; }
.cta-card { background: linear-gradient(135deg, var(--color-primary), var(--color-accent)); border-radius: var(--radius-xl); padding: 56px; text-align: center; color: #fff; }
.cta-card h2 { font-size: 1.8rem; font-weight: 800; margin-bottom: 12px; }
.cta-card p  { font-size: 1rem; opacity: .85; margin-bottom: 28px; }
.cta-card .btn-primary { background: #fff; color: var(--color-primary); }
.cta-card .btn-primary:hover { background: rgba(255,255,255,.9); }

/* ============================================================
   CATALOG PAGE
   ============================================================ */
.catalog-page { max-width: 1280px; margin: 40px auto; padding: 0 24px; }
.catalog-container { display: grid; grid-template-columns: 240px 1fr; gap: 28px; align-items: start; }
.catalog-sidebar { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: 20px; position: sticky; top: 80px; }
.filter-group { margin-bottom: 20px; padding-bottom: 20px; border-bottom: 1px solid var(--color-border); }
.filter-group:last-of-type { border-bottom: none; margin-bottom: 0; }
.filter-title { font-size: .8rem; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; color: var(--color-text-muted); margin-bottom: 10px; }
.filter-list { display: flex; flex-direction: column; gap: 6px; }
.filter-radio { display: flex; align-items: center; gap: 8px; cursor: pointer; font-size: .875rem; padding: 4px 0; }
.filter-radio input { accent-color: var(--color-primary); }
.price-range-inputs { display: flex; align-items: center; gap: 8px; }
.input-sm { padding: 7px 10px; font-size: .8rem; }
.catalog-header { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 20px; }
.catalog-title { font-size: 1.2rem; font-weight: 800; }
.catalog-count { color: var(--color-text-muted); font-size: .875rem; }
.empty-catalog { text-align: center; padding: 60px 24px; background: var(--color-surface); border-radius: var(--radius-lg); border: 1px solid var(--color-border); }
.empty-icon { font-size: 3rem; display: block; margin-bottom: 12px; }

/* ============================================================
   PAGINATION
   ============================================================ */
.pagination { display: flex; gap: 6px; justify-content: center; margin-top: 32px; flex-wrap: wrap; }
.page-btn { display: inline-flex; align-items: center; justify-content: center; min-width: 36px; height: 36px; padding: 0 10px; border-radius: var(--radius-sm); border: 1.5px solid var(--color-border); background: var(--color-surface); color: var(--color-text); font-size: .875rem; text-decoration: none; transition: all var(--transition); }
.page-btn:hover { border-color: var(--color-primary); color: var(--color-primary); text-decoration: none; }
.page-btn.active { background: var(--color-primary); border-color: var(--color-primary); color: #fff; font-weight: 700; }
.page-ellipsis { display: inline-flex; align-items: center; padding: 0 6px; color: var(--color-text-muted); }
.table-pagination { display: flex; gap: 4px; justify-content: center; margin-top: 16px; }

/* ============================================================
   FICHE PRODUIT
   ============================================================ */
.product-page { max-width: 1280px; margin: 32px auto; padding: 0 24px; }
.product-container {}
.breadcrumb { display: flex; align-items: center; gap: 6px; font-size: .82rem; color: var(--color-text-muted); margin-bottom: 24px; flex-wrap: wrap; }
.breadcrumb a { color: var(--color-text-muted); }
.breadcrumb a:hover { color: var(--color-primary); }
.breadcrumb span:not([class]) { opacity: .5; }
.product-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: start; }
.product-gallery { position: sticky; top: 80px; }
.product-main-image { width: 100%; border-radius: var(--radius-lg); box-shadow: var(--shadow-md); }
.product-image-placeholder { aspect-ratio: 16/9; background: var(--color-surface-2); border-radius: var(--radius-lg); display: flex; align-items: center; justify-content: center; font-size: 5rem; }
.product-category-link { font-size: .78rem; font-weight: 600; color: var(--color-primary); text-transform: uppercase; letter-spacing: .5px; display: inline-block; margin-bottom: 8px; }
.product-title { font-size: 1.6rem; font-weight: 900; line-height: 1.2; margin-bottom: 12px; letter-spacing: -.3px; }
.product-rating { display: flex; align-items: center; gap: 8px; margin-bottom: 16px; }
.star { font-size: 1.1rem; }
.star-filled { color: #fbbf24; }
.star-empty  { color: var(--color-border); }
.rating-text { font-size: .875rem; color: var(--color-text-muted); }
.product-price-block { margin: 20px 0; padding: 16px 0; border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); }
.price-normal-lg { font-size: 1.8rem; font-weight: 900; }
.sale-countdown { font-size: .82rem; color: var(--color-error); margin-top: 8px; }
.product-meta-list { list-style: none; display: flex; flex-direction: column; gap: 8px; margin: 20px 0; }
.product-meta-list li { display: flex; justify-content: space-between; font-size: .875rem; padding: 8px 0; border-bottom: 1px dashed var(--color-border); }
.meta-label { color: var(--color-text-muted); font-weight: 500; }
.product-files-preview { background: var(--color-surface-2); border-radius: var(--radius-md); padding: 14px 16px; margin: 16px 0; }
.product-files-preview h3 { font-size: .875rem; font-weight: 700; margin-bottom: 10px; }
.product-files-preview ul { list-style: none; display: flex; flex-direction: column; gap: 6px; }
.product-files-preview li { font-size: .82rem; display: flex; align-items: center; gap: 6px; }
.file-size { color: var(--color-text-muted); }
.product-actions { display: flex; flex-direction: column; gap: 10px; margin: 24px 0; }
.product-guarantees { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 16px; }
.guarantee-item { font-size: .78rem; color: var(--color-text-muted); padding: 6px 10px; background: var(--color-surface-2); border-radius: var(--radius-sm); text-align: center; }
.product-description-content { font-size: .95rem; line-height: 1.8; color: var(--color-text); }
.product-description-content h2, .product-description-content h3 { margin: 20px 0 10px; font-weight: 700; }
.product-description-content ul, .product-description-content ol { margin: 12px 0 12px 20px; }
.product-description-content li { margin-bottom: 4px; }
.product-description-content code { background: var(--color-surface-2); padding: 2px 6px; border-radius: 4px; font-family: var(--font-mono); font-size: .85em; }
.product-description-content pre { background: #1e1e2e; color: #cdd6f4; padding: 16px; border-radius: 8px; overflow-x: auto; font-family: var(--font-mono); font-size: .875rem; }

/* ============================================================
   PANIER
   ============================================================ */
.cart-page { max-width: 1100px; margin: 40px auto; padding: 0 24px; }
.cart-layout { display: grid; grid-template-columns: 1fr 320px; gap: 28px; align-items: start; }
.cart-items { display: flex; flex-direction: column; gap: 12px; }
.cart-item { display: grid; grid-template-columns: 80px 1fr auto auto; gap: 16px; align-items: center; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 14px; }
.cart-item-image img { width: 80px; height: 80px; object-fit: cover; border-radius: var(--radius-sm); }
.cart-item-placeholder { width: 80px; height: 80px; background: var(--color-surface-2); border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; font-size: 2rem; }
.cart-item-name { font-weight: 600; margin-bottom: 4px; }
.cart-item-meta { font-size: .8rem; color: var(--color-text-muted); }
.cart-item-price { font-weight: 700; font-size: 1.05rem; white-space: nowrap; }
.btn-remove { background: none; border: 1.5px solid var(--color-border); color: var(--color-text-muted); width: 30px; height: 30px; border-radius: 50%; cursor: pointer; font-size: .85rem; display: flex; align-items: center; justify-content: center; transition: all var(--transition); }
.btn-remove:hover { background: var(--color-error); border-color: var(--color-error); color: #fff; }
.empty-cart { text-align: center; padding: 80px 24px; background: var(--color-surface); border-radius: var(--radius-xl); border: 1px solid var(--color-border); }
.cart-total-row { display: flex; justify-content: space-between; padding: 8px 0; font-size: .9rem; }
.cart-total-final { font-size: 1.05rem; border-top: 1px solid var(--color-border); margin-top: 8px; padding-top: 12px; }
.cart-trust { margin-top: 16px; display: flex; flex-direction: column; gap: 4px; font-size: .8rem; color: var(--color-text-muted); }
.cart-trust p { display: flex; align-items: center; gap: 6px; }

/* ============================================================
   ESPACE CLIENT — détail commande
   ============================================================ */
.order-detail-header { display: flex; justify-content: space-between; align-items: center; }
.order-detail-date { font-size: .875rem; color: var(--color-text-muted); margin-bottom: 4px; }
.order-detail-item { display: grid; grid-template-columns: auto 1fr auto; gap: 16px; align-items: start; padding: 16px 0; border-bottom: 1px solid var(--color-border); }
.order-detail-item:last-child { border-bottom: none; }
.order-detail-item-info { display: flex; align-items: start; gap: 14px; }
.order-thumb { width: 64px; height: 64px; object-fit: cover; border-radius: var(--radius-sm); }
.order-thumb-placeholder { width: 64px; height: 64px; background: var(--color-surface-2); border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; font-size: 1.8rem; flex-shrink: 0; }
.order-item-name { font-weight: 600; font-size: .9rem; margin-bottom: 4px; }
.order-item-meta { font-size: .78rem; color: var(--color-text-muted); }
.order-license-key { font-size: .78rem; margin-top: 6px; }
.order-license-key code { background: var(--color-surface-2); padding: 2px 8px; border-radius: 4px; font-family: var(--font-mono); }
.order-detail-item-right { display: flex; flex-direction: column; align-items: flex-end; gap: 8px; }
.order-item-price { font-weight: 700; font-size: 1rem; }
.download-token-block { display: flex; flex-direction: column; align-items: flex-end; gap: 6px; }
.dl-token-info { font-size: .72rem; color: var(--color-text-muted); }
.order-financials { display: flex; flex-direction: column; }
.financial-row { display: flex; justify-content: space-between; padding: 8px 0; border-bottom: 1px solid var(--color-border); font-size: .9rem; }
.financial-row:last-child { border-bottom: none; }
.financial-row-total { font-size: 1.05rem; margin-top: 4px; }
.order-ref { font-family: var(--font-mono); font-size: .82rem; background: var(--color-surface-2); padding: 2px 8px; border-radius: 4px; }

/* ============================================================
   ADMIN — Table & Barre de recherche
   ============================================================ */
.admin-search-bar { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.table-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
.table-count { font-size: .875rem; color: var(--color-text-muted); }
.product-admin-link { font-weight: 600; color: var(--color-text); }
.product-admin-link:hover { color: var(--color-primary); }
.log-row { transition: background var(--transition); }
.severity-row-warning  td { background: rgba(245,158,11,.04); }
.severity-row-critical td { background: rgba(239,68,68,.06); }

/* ============================================================
   MODAL
   ============================================================ */
.modal { position: fixed; inset: 0; z-index: 1000; display: flex; align-items: center; justify-content: center; padding: 24px; }
.modal-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.6); backdrop-filter: blur(4px); }
.modal-content { position: relative; background: var(--color-surface); border-radius: var(--radius-lg); padding: 24px; max-width: 560px; width: 100%; max-height: 80vh; overflow-y: auto; box-shadow: var(--shadow-lg); }
.modal-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; }
.modal-header h3 { font-weight: 700; }
.modal-close { background: none; border: none; font-size: 1.2rem; cursor: pointer; color: var(--color-text-muted); padding: 4px 8px; }
.modal-close:hover { color: var(--color-text); }
.modal-json { background: #1e1e2e; color: #cdd6f4; padding: 16px; border-radius: 8px; font-family: var(--font-mono); font-size: .8rem; overflow-x: auto; white-space: pre; }

/* ============================================================
   ACCESSIBILITÉ
   ============================================================ */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.using-mouse *:focus { outline: none !important; }
*:focus-visible { outline: 2px solid var(--color-primary); outline-offset: 2px; }

/* Cart counter animation */
@keyframes cartBounce {
  0%   { transform: scale(1); }
  40%  { transform: scale(1.4); }
  70%  { transform: scale(0.9); }
  100% { transform: scale(1); }
}
.cart-bounce { animation: cartBounce 0.35s ease; }

/* Navbar scroll */
.navbar-scrolled { box-shadow: 0 2px 20px rgba(0,0,0,.1); }

/* ============================================================
   RESPONSIVE SUPPLEMENT
   ============================================================ */
@media (max-width: 1024px) {
  .hero-container      { grid-template-columns: 1fr; }
  .hero-visual         { display: none; }
  .product-layout      { grid-template-columns: 1fr; }
  .product-gallery     { position: static; }
  .catalog-container   { grid-template-columns: 1fr; }
  .catalog-sidebar     { position: static; }
  .cart-layout         { grid-template-columns: 1fr; }
  .product-guarantees  { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
  .hero { padding: 48px 0 40px; }
  .products-section { padding: 40px 0; }
  .products-grid { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 14px; }
  .cart-item { grid-template-columns: 64px 1fr auto; }
  .cart-item-price { grid-column: 2; }
  .btn-remove { grid-column: 3; grid-row: 1; }
  .order-detail-item { grid-template-columns: 1fr; }
  .order-detail-item-right { align-items: flex-start; }
}
