/* ==========================================================================
   Mokhtar GSM — Design Tokens v3
   « Boutique de confiance × Expertise Tech Premium »
   Extraction logo : Rouge #E0070C · Navy #00002A · Cyan #00C2FF
   Inclure EN PREMIER dans le layout public (avant brand.css / app.css)
   ========================================================================== */

:root {
    /* ==================================================================
       TOKENS MINIMALISTES (contrat)
       ================================================================== */
    --color-primary: #0A1F44;
    --color-accent:  #FF6B35;
    --color-whatsapp: #25D366;
    --color-bg-light: #F7F8FA;
    --color-bg-white: #FFFFFF;
    --color-text-main: #1A1A1A;
    --color-text-muted: #6B7280;
    --color-border: #E5E7EB;
    --color-success: #16A34A;
    --color-error: #DC2626;

    --font-main: 'Inter', system-ui, -apple-system, sans-serif;
    --fs-h1: 2.25rem;
    --fs-h2: 1.5rem;
    --fs-h3: 1.25rem;
    --fs-body: 1rem;
    --fs-small: 0.875rem;

    --space-xs: 8px;
    --space-sm: 16px;
    --space-md: 24px;
    --space-lg: 48px;
    --space-xl: 80px;

    --radius-sm: 6px;
    --radius-md: 12px;
    --shadow-card: 0 2px 8px rgba(0,0,0,0.06);

    /* ==================================================================
       ADN VISUEL — palette extraite du logo (Digital-First)
       ================================================================== */

    /* Rouge Énergie — promos, urgence, stock faible */
    /* Nouveau système minimal : l'« accent » remplace l'ancien rouge logo */
    --color-brand-red:        #FF6B35;
    --color-brand-red-hover:  #E65E2E;
    --color-brand-red-active: #D4542A;
    --color-brand-red-soft:   rgba(255, 107, 53, 0.14);
    --color-brand-red-muted:  rgba(255, 107, 53, 0.08);

    /* Deep Navy — titres, header, footer, CTA principaux */
    /* Bleu marine unique */
    --color-navy:             #0A1F44;
    --color-navy-hover:       #071736;
    --color-navy-active:      #06122C;
    --color-navy-soft:        rgba(10, 31, 68, 0.08);
    --color-navy-muted:       rgba(10, 31, 68, 0.05);

    /* Cyan Tech — nouveautés, micro-interactions, highlights */
    /* Ancien « cyan tech » → accent unique, pour garder une palette simple */
    --color-accent-tech:      #FF6B35;
    --color-accent-tech-hover:#E65E2E;
    --color-accent-tech-soft: rgba(255, 107, 53, 0.14);
    --color-accent-tech-muted:rgba(255, 107, 53, 0.08);

    /* WhatsApp — canal de confiance Maroc */
    --color-whatsapp:         #25D366;
    --color-whatsapp-hover:   #1DA851;
    --color-whatsapp-soft:    rgba(37, 211, 102, 0.14);

    /* Alias sémantiques */
    --color-primary:          var(--color-navy);
    --color-primary-hover:    var(--color-navy-hover);
    --color-primary-active:   var(--color-navy-active);
    --color-primary-soft:     var(--color-navy-soft);
    --color-primary-muted:    var(--color-navy-muted);

    --color-secondary:        var(--color-navy);
    --color-secondary-hover:  var(--color-navy-hover);
    --color-secondary-soft:   var(--color-navy-soft);

    --color-accent-promo:        var(--color-brand-red);
    --color-accent-promo-hover:  var(--color-brand-red-hover);
    --color-accent-promo-soft:   var(--color-brand-red-soft);
    --color-accent-promo-text:   #7F1D1D;

    /* ==================================================================
       NEUTRES — surfaces froides, interface aérée
       ================================================================== */

    --color-bg:             #FFFFFF;
    --color-bg-soft:        #F7F8FA;
    --color-bg-muted:       #F1F5F9;
    --color-surface:        #FFFFFF;
    --color-surface-raised: #FFFFFF;
    --color-surface-float:  #F8FAFC;

    --color-text:           #1A1A1A;
    --color-text-muted:     #6B7280;
    --color-text-subtle:      #94A3B8;
    --color-heading:        var(--color-navy);

    --color-border:         #E5E7EB;
    --color-border-strong:  #CBD5E1;
    --color-divider:        #F1F5F9;

    --color-on-primary:     #FFFFFF;
    --color-on-secondary:   #FFFFFF;
    --color-on-promo:       #FFFFFF;
    --color-on-dark-muted:  #C7D2FE;

    /* ==================================================================
       ÉTATS — feedback, stock, formulaires
       ================================================================== */

    --color-success:        #16A34A;
    --color-success-soft:   rgba(22, 163, 74, 0.12);
    --color-success-text:   #166534;

    --color-danger:         #DC2626;
    --color-danger-soft:    rgba(220, 38, 38, 0.12);
    --color-danger-text:    #991B1B;

    --color-warning:        #D97706;
    --color-warning-soft:   rgba(217, 119, 6, 0.12);
    --color-warning-text:   #92400E;

    --color-info:           var(--color-accent-tech);
    --color-info-soft:      var(--color-accent-tech-soft);

    --color-stock-ok:       #16A34A;
    --color-stock-low:      var(--color-brand-red);
    --color-stock-out:      #64748B;

    --color-focus-ring:     rgba(0, 194, 255, 0.45);
    --focus-ring:           0 0 0 3px var(--color-focus-ring);

    /* ==================================================================
       TYPOGRAPHIE
       Display : Plus Jakarta Sans · Body : Inter · Prix : tabular-nums
       ================================================================== */

    --font-display: 'Inter', system-ui, -apple-system, sans-serif;
    --font-body:    'Inter', system-ui, -apple-system, sans-serif;
    --font-mono:    ui-monospace, 'Cascadia Code', monospace;

    --text-xs:   0.75rem;
    --text-sm:   0.875rem;
    --text-base: 1rem;
    --text-lg:   1.125rem;
    --text-xl:   1.25rem;
    --text-2xl:  1.5rem;
    --text-3xl:  1.875rem;
    --text-4xl:  2.25rem;
    --text-5xl:  3rem;

    --font-normal:    400;
    --font-medium:    500;
    --font-semibold:  600;
    --font-bold:      700;
    --font-extrabold: 800;

    --leading-tight:   1.2;
    --leading-snug:    1.35;
    --leading-normal:  1.6;
    --leading-relaxed: 1.75;

    --tracking-tight:  -0.02em;
    --tracking-normal:  0;
    --tracking-wide:    0.04em;
    --tracking-wider:   0.08em;

    --text-price:      1.15rem;
    --text-price-lg:   1.5rem;
    --text-price-old:  0.9rem;
    --weight-price:    800;

    /* ==================================================================
       ESPACEMENTS (échelle 4px)
       ================================================================== */

    --space-0:  0;
    --space-1:  0.25rem;
    --space-2:  0.5rem;
    --space-3:  0.75rem;
    --space-4:  1rem;
    --space-5:  1.25rem;
    --space-6:  1.5rem;
    --space-8:  2rem;
    --space-10: 2.5rem;
    --space-12: 3rem;
    --space-16: 4rem;
    --space-20: 5rem;

    --section-y:    3.5rem;
    --section-y-lg: 5rem;
    --container-px: 1rem;

    /* ==================================================================
       RAYONS, OMBRES, TRANSITIONS
       ================================================================== */

    --radius-xs:   6px;
    --radius-sm:   6px;
    --radius-md:   12px;
    --radius-lg:   20px;
    --radius-xl:   28px;
    --radius-pill: 999px;

    --shadow-xs:  0 1px 2px rgba(0, 0, 42, 0.04);
    --shadow-sm:  0 1px 3px rgba(0, 0, 42, 0.06);
    --shadow-md:  0 2px 8px rgba(0,0,0,0.06);
    --shadow-lg:  0 20px 25px -5px rgba(0, 0, 42, 0.08), 0 8px 10px -6px rgba(0, 0, 42, 0.04);
    --shadow-xl:  0 25px 50px -12px rgba(0, 0, 42, 0.12);
    --shadow-card:        0 2px 8px rgba(0,0,0,0.06);
    --shadow-card-hover:  0 20px 25px -5px rgba(0, 0, 0, 0.08), 0 8px 10px -6px rgba(0, 0, 0, 0.04);

    --transition-fast:   0.15s ease;
    --transition-base:   0.2s ease;
    --transition-lift:   0.3s ease;
    --transition-slow:   0.35s ease;
    --transition-spring: 0.4s cubic-bezier(0.34, 1.4, 0.64, 1);

    /* ==================================================================
       COMPOSANTS
       ================================================================== */

    --header-height:  72px;
    --header-bg:      rgba(255, 255, 255, 0.98);
    --topbar-bg:      var(--color-navy);
    --topbar-text:    var(--color-on-dark-muted);

    --btn-height:      44px;
    --btn-height-sm:   36px;
    --btn-height-lg:   52px;
    --btn-radius:      12px;
    --btn-font-weight: var(--font-semibold);
    --btn-lift:        -2px;

    --card-radius:       var(--radius-md);
    --card-border:       none;
    --card-thumb-ratio:  1 / 1;
    --badge-promo-bg:    var(--color-brand-red);
    --badge-promo-color: var(--color-on-promo);

    --hero-min-height: 420px;
    --hero-overlay:    linear-gradient(105deg, rgba(0, 0, 42, 0.92) 0%, rgba(0, 0, 42, 0.55) 55%, rgba(0, 0, 42, 0.25) 100%);
    --hero-title-size: clamp(1.875rem, 4vw, 3rem);

    --footer-bg:   var(--color-navy);
    --footer-text: var(--color-on-dark-muted);

    --touch-target-min: 44px;

    --z-dropdown: 1050;
    --z-sticky:   1030;
    --z-fixed:    1040;
    --z-modal:    1060;

    /* ==================================================================
       ALIAS LEGACY (brand.css / app.css)
       ================================================================== */

    --brand-primary:       var(--color-navy);
    --brand-primary-dark:  var(--color-navy-hover);
    --brand-primary-soft:  var(--color-navy-soft);
    --brand-secondary:     var(--color-navy);
    --brand-accent:        var(--color-accent-tech);
    --brand-red:           var(--color-brand-red);
    --whatsapp:            var(--color-whatsapp);
    --success:             var(--color-success);
    --danger:              var(--color-danger);
    --warning:             var(--color-warning);
    --bg:                  var(--color-bg);
    --bg-soft:             var(--color-bg-soft);
    --surface:             var(--color-surface);
    --text:                var(--color-text);
    --text-muted:          var(--color-text-muted);
    --heading:             var(--color-heading);
    --border:              var(--color-border);
    --transition:          var(--transition-lift);

    --bs-primary:            var(--color-navy);
    --bs-primary-rgb:        0, 0, 42;
    --bs-link-color:         var(--color-navy);
    --bs-link-hover-color:   var(--color-accent-tech-hover);
    --bs-body-color:         var(--color-text);
    --bs-body-font-family:   var(--font-body);
    --bs-border-radius:      0.75rem;
}

/* ---------- Utilitaires typographiques ---------- */
.font-display { font-family: var(--font-display); }
.font-body    { font-family: var(--font-body); }

.text-h1 {
    font-family: var(--font-display);
    font-size: clamp(var(--text-3xl), 4vw, var(--text-5xl));
    font-weight: var(--font-extrabold);
    line-height: var(--leading-tight);
    letter-spacing: var(--tracking-tight);
    color: var(--color-heading);
}
.text-h2 {
    font-family: var(--font-display);
    font-size: clamp(var(--text-2xl), 3vw, var(--text-4xl));
    font-weight: var(--font-extrabold);
    line-height: var(--leading-tight);
    letter-spacing: var(--tracking-tight);
    color: var(--color-heading);
}
.text-h3 {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: var(--font-bold);
    line-height: var(--leading-snug);
    letter-spacing: var(--tracking-tight);
    color: var(--color-heading);
}
.text-h4 {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    font-weight: var(--font-bold);
    line-height: var(--leading-snug);
    color: var(--color-heading);
}
.text-body    { font-size: var(--text-base); line-height: var(--leading-normal); }
.text-caption { font-size: var(--text-sm); color: var(--color-text-muted); line-height: var(--leading-normal); }
.text-price,
.text-price-lg {
    font-variant-numeric: tabular-nums;
    font-feature-settings: "tnum" 1;
    font-weight: var(--weight-price);
    color: var(--color-heading);
}
.text-price    { font-size: var(--text-price); }
.text-price-lg { font-size: var(--text-price-lg); }

:focus-visible {
    outline: none;
    box-shadow: var(--focus-ring);
}
