/*
Theme Name:   La Poste Sénégal — Kadence Child
Theme URI:    https://www.laposte.sn
Description:  Thème enfant Kadence — charte graphique La Poste Sénégal (couleurs, typographie, cartes, boutons).
Author:       La Poste Sénégal DSI
Author URI:   https://www.laposte.sn
Template:     kadence
Version:      1.0.0
License:      Private
Text Domain:  laposte-kadence-child
*/

/* ============================================================
   0. TOKENS CSS — Charte La Poste Sénégal
   ============================================================ */
:root {
  /* Couleurs brand */
  --lp-cyan:        #1f9ee2;   /* Accent / liens actifs / CTAs secondaires */
  --lp-blue:        #2B6CB0;   /* Boutons primaires */
  --lp-dark:        #215387;   /* Hover boutons / liens foncés */
  --lp-navy:        #1A202C;   /* Texte principal */
  --lp-bg-light:    #F4F6F9;   /* Fond sections alternées */
  --lp-card-border: #E8ECF2;   /* Bordures cartes */
  --lp-white:       #ffffff;

  /* Typographie */
  --lp-font-heading: 'Outfit', system-ui, -apple-system, sans-serif;
  --lp-font-body:    system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --lp-weight-normal:   400;
  --lp-weight-semibold: 600;
  --lp-weight-bold:     700;

  /* Layout */
  --lp-max-width:        1290px;
  --lp-section-padding:  72px;
  --lp-radius-card:      12px;
  --lp-radius-button:    50px;
  --lp-shadow-card:      rgba(0, 0, 0, 0.08) 0px 4px 20px 0px;
  --lp-btn-padding:      13px 28px;
}

/* Surcharge palette Kadence */
:root {
  --global-palette1: #1f9ee2;
  --global-palette2: #2B6CB0;
  --global-palette3: #215387;
  --global-palette4: #1A202C;
  --global-palette5: #F4F6F9;
  --global-palette6: #E8ECF2;
  --global-palette7: #ffffff;
  --global-palette8: #4A5568;
}

/* ============================================================
   1. TYPOGRAPHIE GLOBALE
   ============================================================ */
body {
  font-family: var(--lp-font-body);
  font-size: 16px;
  line-height: 1.7;
  color: var(--lp-navy);
  background-color: var(--lp-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6,
.wp-block-heading {
  font-family: var(--lp-font-heading);
  font-weight: var(--lp-weight-bold);
  color: var(--lp-navy);
  line-height: 1.2;
  margin-bottom: 0.6em;
}

h1 { font-size: clamp(2rem, 4vw, 3rem); }
h2 { font-size: clamp(1.6rem, 3vw, 2.25rem); }
h3 { font-size: clamp(1.3rem, 2.5vw, 1.75rem); }
h4 { font-size: 1.25rem; }
h5 { font-size: 1.1rem; }
h6 { font-size: 1rem; }

p { line-height: 1.7; color: var(--lp-navy); }

a {
  color: var(--lp-cyan);
  text-decoration: none;
  transition: color 0.2s ease;
}
a:hover { color: var(--lp-dark); }

/* ============================================================
   2. LAYOUT
   ============================================================ */
.site {
  max-width: 100%;
  overflow-x: hidden;
}

.container,
.wp-block-group.alignwide,
.kb-section-container {
  max-width: var(--lp-max-width);
  margin-left: auto;
  margin-right: auto;
  padding-left: 24px;
  padding-right: 24px;
}

/* ============================================================
   3. BOUTONS
   ============================================================ */
.wp-block-button__link,
.kb-button,
.button,
a.button,
input[type="submit"],
button.wp-element-button,
.lp-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: var(--lp-btn-padding);
  background-color: var(--lp-blue);
  color: var(--lp-white) !important;
  border-radius: var(--lp-radius-button);
  font-family: var(--lp-font-heading);
  font-weight: var(--lp-weight-semibold);
  font-size: 0.95rem;
  border: 2px solid transparent;
  cursor: pointer;
  text-decoration: none;
  transition: background-color 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
  white-space: nowrap;
}

.wp-block-button__link:hover,
.kb-button:hover,
.button:hover,
input[type="submit"]:hover,
.lp-btn:hover {
  background-color: var(--lp-dark);
  color: var(--lp-white) !important;
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(33, 83, 135, 0.35);
}

/* Variante cyan */
.lp-btn-cyan,
.wp-block-button.is-style-fill .wp-block-button__link.lp-btn-cyan {
  background-color: var(--lp-cyan);
}
.lp-btn-cyan:hover { background-color: var(--lp-dark); }

/* Variante outline */
.lp-btn-outline,
.wp-block-button.is-style-outline .wp-block-button__link {
  background-color: transparent;
  color: var(--lp-blue) !important;
  border-color: var(--lp-blue);
}
.lp-btn-outline:hover,
.wp-block-button.is-style-outline .wp-block-button__link:hover {
  background-color: var(--lp-blue);
  color: var(--lp-white) !important;
}

/* ============================================================
   4. CARTES
   ============================================================ */
.lp-card,
.wp-block-group.lp-card {
  background: var(--lp-white);
  border: 1px solid var(--lp-card-border);
  border-radius: var(--lp-radius-card);
  box-shadow: var(--lp-shadow-card);
  padding: 32px;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.lp-card:hover {
  transform: translateY(-4px);
  box-shadow: rgba(0, 0, 0, 0.13) 0px 8px 32px 0px;
}
.lp-card h3 {
  font-size: 1.15rem;
  margin-bottom: 10px;
}
.lp-card p {
  font-size: 0.9rem;
  color: #4A5568;
  line-height: 1.6;
  margin-bottom: 20px;
}
.lp-card-icon {
  width: 56px;
  height: 56px;
  background: linear-gradient(135deg, var(--lp-cyan), var(--lp-blue));
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  color: var(--lp-white);
  font-size: 1.5rem;
}

/* ============================================================
   5. SECTIONS
   ============================================================ */
.lp-section {
  padding: var(--lp-section-padding) 24px;
}
.lp-section-white { background-color: var(--lp-white); }
.lp-section-light { background-color: var(--lp-bg-light); }

.lp-section-header {
  text-align: center;
  max-width: 700px;
  margin: 0 auto 48px;
}
.lp-section-header .lp-eyebrow {
  display: inline-block;
  font-family: var(--lp-font-heading);
  font-size: 0.8rem;
  font-weight: var(--lp-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--lp-cyan);
  margin-bottom: 12px;
}
.lp-section-header h2 { font-size: clamp(1.6rem, 3vw, 2.25rem); margin-bottom: 16px; }
.lp-section-header p { color: #4A5568; font-size: 1.05rem; }

/* ============================================================
   6. NAVIGATION
   ============================================================ */
#masthead,
.site-header,
.wp-block-template-part.header {
  background-color: var(--lp-white);
  border-bottom: 1px solid var(--lp-card-border);
  box-shadow: rgba(0, 0, 0, 0.04) 0px 2px 8px 0px;
}

/* Items nav */
#primary-navigation .menu-item > a,
.kadence-navigation .menu-item > a,
nav.navigation-primary .menu-item > a {
  font-family: var(--lp-font-heading);
  font-weight: var(--lp-weight-semibold);
  font-size: 0.9rem;
  color: var(--lp-navy);
  text-decoration: none;
  transition: color 0.2s ease;
}
#primary-navigation .menu-item > a:hover,
.kadence-navigation .menu-item > a:hover,
nav.navigation-primary .menu-item > a:hover {
  color: var(--lp-cyan);
}
#primary-navigation .current-menu-item > a,
.kadence-navigation .current-menu-item > a {
  color: var(--lp-blue);
}

/* Dropdown */
#primary-navigation .sub-menu,
.kadence-navigation .sub-menu {
  border: 1px solid var(--lp-card-border);
  border-radius: var(--lp-radius-card);
  box-shadow: var(--lp-shadow-card);
  background: var(--lp-white);
  padding: 8px 0;
}
#primary-navigation .sub-menu .menu-item > a,
.kadence-navigation .sub-menu .menu-item > a {
  font-size: 0.87rem;
  padding: 8px 20px;
}

/* ============================================================
   7. PIED DE PAGE
   ============================================================ */
#colophon,
.site-footer,
.wp-block-template-part.footer {
  background-color: var(--lp-navy);
  color: rgba(255, 255, 255, 0.8);
}
#colophon a,
.site-footer a {
  color: rgba(255, 255, 255, 0.8);
}
#colophon a:hover,
.site-footer a:hover {
  color: var(--lp-white);
}
#colophon h3,
.site-footer h3 {
  color: var(--lp-white);
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 16px;
}

/* ============================================================
   8. PAGE SHORTCODE (template pleine largeur)
   ============================================================ */
.lp-shortcode-page {
  min-height: 60vh;
}
.lp-shortcode-wrapper {
  max-width: var(--lp-max-width);
  margin: 0 auto;
  padding: 48px 24px 72px;
}
.lp-page-title {
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  color: var(--lp-navy);
  margin-bottom: 32px;
  padding-bottom: 20px;
  border-bottom: 2px solid var(--lp-card-border);
}

/* ============================================================
   9. FORMULAIRES
   ============================================================ */
input[type="text"],
input[type="email"],
input[type="search"],
input[type="tel"],
textarea,
select {
  border: 1px solid var(--lp-card-border);
  border-radius: 8px;
  padding: 12px 16px;
  font-family: var(--lp-font-body);
  font-size: 0.95rem;
  color: var(--lp-navy);
  background: var(--lp-white);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  width: 100%;
  box-sizing: border-box;
}
input[type="text"]:focus,
input[type="email"]:focus,
input[type="search"]:focus,
textarea:focus,
select:focus {
  border-color: var(--lp-cyan);
  box-shadow: 0 0 0 3px rgba(31, 158, 226, 0.15);
  outline: none;
}

/* ============================================================
   10. BREADCRUMB
   ============================================================ */
.breadcrumb-trail,
.kadence-breadcrumbs {
  font-size: 0.85rem;
  color: #718096;
  padding: 12px 0;
}
.breadcrumb-trail a,
.kadence-breadcrumbs a {
  color: var(--lp-cyan);
}
.breadcrumb-trail a:hover,
.kadence-breadcrumbs a:hover {
  color: var(--lp-dark);
}

/* ============================================================
   11. RESPONSIVE
   ============================================================ */
@media (max-width: 768px) {
  :root {
    --lp-section-padding: 48px;
  }
  .lp-shortcode-wrapper {
    padding: 32px 16px 56px;
  }
  h1 { font-size: 1.9rem; }
  h2 { font-size: 1.5rem; }
}

@media (max-width: 480px) {
  :root {
    --lp-section-padding: 36px;
  }
  .wp-block-button__link,
  .kb-button,
  .lp-btn {
    width: 100%;
    justify-content: center;
  }
}
