/**
 * Zaoui Dot Com — Styles principaux
 *
 * Variables CSS, reset minimal, typographie, couleurs,
 * layout global (container, sections, grilles).
 *
 * Convention : toutes les classes sont prefixees zdot- (BEM).
 *
 * @package ZaouiDotCom
 * @since   1.0.0
 */

/* =========================================================================
   VARIABLES CSS
   ========================================================================= */

:root {
    /* Couleurs — palette premium sobre */
    --zdot-color-primary: #1a1a2e;
    --zdot-color-accent: #2d6a8a;
    --zdot-color-accent-hover: #1f4f6b;
    --zdot-color-text: #2c2c2c;
    --zdot-color-text-light: #6b6b6b;
    --zdot-color-bg: #ffffff;
    --zdot-color-bg-alt: #f7f7f9;
    --zdot-color-border: #e0e0e0;

    /* Typographie */
    --zdot-font-heading: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --zdot-font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --zdot-font-size-base: 1rem;
    --zdot-line-height: 1.65;

    /* Espacements */
    --zdot-space-xs: 0.5rem;
    --zdot-space-sm: 1rem;
    --zdot-space-md: 1.25rem;
    --zdot-space-lg: 1.5rem;
    --zdot-space-xl: 1.75rem;

    /* Conteneur */
    --zdot-container-width: 1140px;
    --zdot-container-narrow: 800px;
    --zdot-container-padding: 1.5rem;
}

/* =========================================================================
   RESET MINIMAL (complement GeneratePress)
   ========================================================================= */

*,
*::before,
*::after {
    box-sizing: border-box;
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

/* =========================================================================
   TYPOGRAPHIE
   ========================================================================= */

body {
    font-family: var(--zdot-font-body);
    font-size: var(--zdot-font-size-base);
    line-height: var(--zdot-line-height);
    color: var(--zdot-color-text);
    background-color: var(--zdot-color-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4 {
    font-family: var(--zdot-font-heading);
    font-weight: 600;
    line-height: 1.25;
    color: var(--zdot-color-primary);
    margin-top: 0;
}

h1 { font-size: 2.25rem; }
h2 { font-size: 1.75rem; }
h3 { font-size: 1.25rem; }

p {
    margin-top: 0;
    margin-bottom: var(--zdot-space-sm);
}

a {
    color: var(--zdot-color-accent);
    text-decoration: none;
    transition: color 0.2s ease;
}

a:hover,
a:focus {
    color: var(--zdot-color-accent-hover);
}

/* =========================================================================
   LAYOUT — CONTENEUR
   ========================================================================= */

.zdot-container {
    max-width: var(--zdot-container-width);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--zdot-container-padding);
    padding-right: var(--zdot-container-padding);
}

.zdot-container--narrow {
    max-width: var(--zdot-container-narrow);
}

/* =========================================================================
   SECTIONS
   ========================================================================= */

.zdot-section {
    padding-top: var(--zdot-space-xl);
    padding-bottom: var(--zdot-space-xl);
}

.zdot-section--alt {
    background-color: var(--zdot-color-bg-alt);
}

.zdot-section__title {
    text-align: center;
    margin-bottom: var(--zdot-space-lg);
}

.zdot-section__text {
    max-width: var(--zdot-container-narrow);
    margin-left: auto;
    margin-right: auto;
}

.zdot-section__cta {
    text-align: center;
    margin-top: var(--zdot-space-md);
}

/* =========================================================================
   GRILLES
   ========================================================================= */

.zdot-grid {
    display: grid;
    gap: var(--zdot-space-md);
}

.zdot-grid--2 {
    grid-template-columns: repeat(2, 1fr);
}

.zdot-grid--3 {
    grid-template-columns: repeat(3, 1fr);
}

.zdot-grid--4 {
    grid-template-columns: repeat(4, 1fr);
}

.zdot-grid--cred {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    text-align: center;
}

/* =========================================================================
   BOUTONS
   ========================================================================= */

.zdot-btn {
    display: inline-block;
    padding: 0.875rem 2rem;
    font-family: var(--zdot-font-body);
    font-size: 0.95rem;
    font-weight: 500;
    text-align: center;
    text-decoration: none;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.2s ease, color 0.2s ease;
    border: 2px solid transparent;
}

.zdot-btn--primary {
    background-color: var(--zdot-color-accent);
    color: #ffffff;
    border-color: var(--zdot-color-accent);
}

.zdot-btn--primary:hover,
.zdot-btn--primary:focus {
    background-color: var(--zdot-color-accent-hover);
    border-color: var(--zdot-color-accent-hover);
    color: #ffffff;
}

.zdot-btn--secondary {
    background-color: transparent;
    color: var(--zdot-color-accent);
    border-color: var(--zdot-color-accent);
}

.zdot-btn--secondary:hover,
.zdot-btn--secondary:focus {
    background-color: var(--zdot-color-accent);
    color: #ffffff;
}

/* =========================================================================
   PAGE WRAPPER
   ========================================================================= */

.zdot-site {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.zdot-page {
    flex: 1;
}

/* =========================================================================
   VISUEL INTRODUCTION (Approche)
   ========================================================================= */

.zdot-intro__visual {
    max-width: var(--zdot-container-narrow);
    margin: var(--zdot-space-md) auto;
    text-align: center;
}

.zdot-intro__img {
    border-radius: 6px;
    margin-left: auto;
    margin-right: auto;
}

/* =========================================================================
   NEUTRALISATION LAYOUT GENERATEPRESS
   ========================================================================= */

.site-content {
    display: block;
}

.site-main {
    margin: 0;
}
