/* ==========================================================================
   Padelcourt — site.css
   Design system (peau LP) + header global + footer global + réalisations.
   ========================================================================== */

/* Fonts self-hosted (woff2 latin) — supprime la requete bloquante Google Fonts */
@font-face{font-family:'Barlow';font-style:normal;font-weight:300;font-display:swap;src:url('../fonts/barlow-300.woff2') format('woff2');}
@font-face{font-family:'Barlow';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/barlow-400.woff2') format('woff2');}
@font-face{font-family:'Barlow';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/barlow-500.woff2') format('woff2');}
@font-face{font-family:'Barlow';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/barlow-600.woff2') format('woff2');}
@font-face{font-family:'Barlow';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/barlow-700.woff2') format('woff2');}
@font-face{font-family:'Barlow Condensed';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/barlow-condensed-500.woff2') format('woff2');}
@font-face{font-family:'Barlow Condensed';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/barlow-condensed-600.woff2') format('woff2');}
@font-face{font-family:'Barlow Condensed';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/barlow-condensed-700.woff2') format('woff2');}

:root {
  --pc-bg: #050B1A;
  --pc-bg-alt: #0A1226;
  --pc-bg-card: #10193A;
  --pc-yellow: #FFEB00;
  --pc-yellow-deep: #E5D300;
  --pc-cyan: #3DB4FF;
  --pc-cyan-soft: rgba(61, 180, 255, 0.15);
  --pc-white: #FFFFFF;
  --pc-text: #E2E8F0;
  --pc-muted: #94A3B8;
  --pc-muted-2: #64748B;
  --pc-border: rgba(255, 255, 255, 0.1);
  --pc-border-strong: rgba(255, 255, 255, 0.2);
  --pc-border-yellow: rgba(255, 235, 0, 0.3);
  --pc-header-h: 68px;
  --pc-font: "Barlow", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --pc-display: "Barlow Condensed", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
.pc-brand-name, .pc-footer-brand, .pc-single-title, .pc-footer-col h4 { font-family: var(--pc-display); }

/* --- Reset léger appliqué uniquement à notre périmètre --- */
.pc-body {
  margin: 0;
  background: var(--pc-bg);
  color: var(--pc-text);
  font-family: var(--pc-font);
  font-size: 16px;
  line-height: 1.55;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
.pc-body * { box-sizing: border-box; }
.pc-body img { max-width: 100%; height: auto; display: block; }
.pc-body a { color: inherit; text-decoration: none; }

.pc-skip-link {
  position: absolute; left: -9999px; top: 0; z-index: 200;
  background: var(--pc-yellow); color: var(--pc-bg);
  padding: 10px 18px; font-weight: 700;
}
.pc-skip-link:focus { left: 8px; top: 8px; }

/* ==========================================================================
   HEADER
   ========================================================================== */
.pc-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(5, 11, 26, 0.85);
  backdrop-filter: saturate(1.4) blur(14px);
  -webkit-backdrop-filter: saturate(1.4) blur(14px);
  border-bottom: 1px solid var(--pc-border);
}
.pc-header-inner {
  max-width: 1440px; margin: 0 auto; padding: 0 32px;
  height: var(--pc-header-h);
  display: flex; align-items: center; gap: 28px;
}

/* Brand */
.pc-brand { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.pc-brand picture { display: flex; }
/* specificite (0,2,0) pour battre `.pc-body img` (0,1,1) qui force height:auto */
.pc-brand .pc-brand-logo { height: 20px; width: auto; display: block; }
.pc-mobile-nav-head .pc-brand-logo { height: 22px; width: auto; }
.pc-footer-brand .pc-footer-logo { height: 32px; width: auto; display: block; }
/* anciens styles texte de marque (conservés au cas où) */
.pc-brand-mark {
  width: 30px; height: 30px; background: var(--pc-yellow); color: var(--pc-bg);
  font-weight: 700; font-size: 1.05rem;
  display: flex; align-items: center; justify-content: center;
}
.pc-brand-name { font-weight: 700; font-size: 1.1rem; color: var(--pc-white); letter-spacing: -0.01em; }
.pc-brand-sup { font-size: 0.55em; vertical-align: super; color: var(--pc-muted); margin-left: 1px; }

/* Nav */
.pc-nav { flex: 1; }
.pc-nav-menu {
  list-style: none; margin: 0; padding: 0;
  display: flex; align-items: center; gap: 4px;
}
.pc-nav-menu li { margin: 0; }
.pc-nav-menu a {
  display: inline-block; padding: 8px 14px;
  font-size: 0.92rem; font-weight: 600; color: var(--pc-text);
  border-radius: 6px; transition: color 0.2s ease, background 0.2s ease;
}
.pc-nav-menu a:hover,
.pc-nav-menu .current-menu-item > a,
.pc-nav-menu .current_page_item > a { color: var(--pc-yellow); }

/* Header actions */
.pc-header-actions { display: flex; align-items: center; gap: 16px; flex-shrink: 0; }
.pc-header-phone {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 0.88rem; font-weight: 600; color: var(--pc-text);
}
.pc-header-phone svg { width: 14px; height: 14px; color: var(--pc-yellow); }
.pc-header-phone:hover { color: var(--pc-white); }
.pc-header-cta {
  display: inline-flex; align-items: center; gap: 9px;
  background: var(--pc-yellow) !important; color: var(--pc-bg) !important;
  padding: 11px 22px; font-size: 0.9rem; font-weight: 700; letter-spacing: 0.02em;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.pc-header-cta:hover { transform: translateY(-1px); box-shadow: 0 6px 20px rgba(255, 235, 0, 0.25); }
.pc-header-cta svg { width: 14px; height: 14px; }
.pc-header-cta--block { width: 100%; justify-content: center; padding: 14px; }

/* Burger (mobile only) */
.pc-burger {
  display: none; flex-direction: column; gap: 5px;
  width: 42px; height: 42px; align-items: center; justify-content: center;
  background: transparent; border: 1px solid var(--pc-border-strong); cursor: pointer;
  flex-shrink: 0;
}
.pc-burger span { width: 20px; height: 2px; background: var(--pc-white); transition: transform 0.3s ease, opacity 0.3s ease; }
.pc-burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.pc-burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.pc-burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile drawer */
.pc-mobile-nav {
  position: fixed; top: 0; right: 0; bottom: 0; z-index: 150;
  width: min(360px, 86vw);
  background: var(--pc-bg-alt); border-left: 1px solid var(--pc-border);
  padding: 24px; transform: translateX(100%);
  transition: transform 0.32s cubic-bezier(0.4, 0, 0.2, 1);
  overflow-y: auto;
}
.pc-mobile-nav.is-open { transform: translateX(0); }
.pc-mobile-nav-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 28px; }
.pc-mobile-close { background: transparent; border: 0; color: var(--pc-white); font-size: 2rem; line-height: 1; cursor: pointer; }
.pc-mobile-menu { list-style: none; margin: 0 0 28px; padding: 0; }
.pc-mobile-menu li { border-bottom: 1px solid var(--pc-border); }
.pc-mobile-menu a { display: block; padding: 16px 4px; font-size: 1.1rem; font-weight: 600; color: var(--pc-text); }
.pc-mobile-menu a:hover, .pc-mobile-menu .current-menu-item > a { color: var(--pc-yellow); }
.pc-mobile-nav-actions { display: flex; flex-direction: column; gap: 14px; }
.pc-mobile-phone { font-size: 1.05rem; font-weight: 700; color: var(--pc-yellow); }
/* Drawer : forcer la nav en liste verticale meme si le fallback sort .pc-nav-menu (horizontal) */
.pc-mobile-nav .pc-nav-menu { display: block; gap: 0; margin: 0 0 28px; }
.pc-mobile-nav .pc-nav-menu li { display: block; width: 100%; margin: 0; border-bottom: 1px solid var(--pc-border); }
.pc-mobile-nav .pc-nav-menu a { display: block; padding: 16px 4px; font-size: 1.15rem; font-weight: 600; color: var(--pc-white); }
.pc-mobile-nav .pc-nav-menu a:hover { color: var(--pc-yellow); }
.pc-mobile-overlay { position: fixed; inset: 0; z-index: 140; background: rgba(0, 0, 0, 0.6); }

@media (max-width: 1024px) {
  .pc-header-inner { justify-content: space-between; }
  .pc-nav { display: none; }
  .pc-header-actions { display: none; }
  .pc-burger { display: flex; margin-left: auto; }
  .pc-nav { order: 3; }
}
@media (min-width: 1025px) {
  .pc-mobile-nav, .pc-mobile-overlay { display: none; }
}
@media (max-width: 560px) {
  .pc-header-inner { padding: 0 18px; gap: 14px; }
  .pc-brand .pc-brand-logo { height: 18px; }
}

/* ==========================================================================
   MAIN — wrapper de contenu
   ========================================================================== */
.pc-main { display: block; }

/* ==========================================================================
   RÉALISATIONS — grille bento (shortcode [chantiers_grid])
   ========================================================================== */
.pc-reals-grid {
  max-width: 1440px; margin: 0 auto; padding: 0 32px;
  display: grid; grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: 120px; gap: 12px;
}
.pc-real {
  position: relative; overflow: hidden;
  background: var(--pc-bg-card); border: 1px solid var(--pc-border);
  background-size: cover; background-position: center;
  transition: transform 0.4s ease, border-color 0.4s ease;
  grid-column: span 4; grid-row: span 2;
}
.pc-real--lg { grid-column: span 6; grid-row: span 3; }
.pc-real:hover { transform: translateY(-4px); border-color: var(--pc-border-yellow); }
.pc-real-overlay { position: absolute; inset: 0; z-index: 1; background: linear-gradient(180deg, transparent 35%, rgba(0, 0, 0, 0.75) 100%); }
.pc-real--placeholder { background: linear-gradient(160deg, #1a3a5c 0%, #061224 100%); }
.pc-real--placeholder:nth-child(3n) { background: linear-gradient(160deg, #2d4d18 0%, #1a2e0f 100%); }
.pc-real--placeholder:nth-child(3n+1) { background: linear-gradient(160deg, #b85436 0%, #6b2412 100%); }
.pc-real-cap { position: absolute; left: 20px; right: 20px; bottom: 18px; z-index: 2; display: flex; flex-direction: column; gap: 4px; }
.pc-real-city { font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 600; color: var(--pc-yellow); }
.pc-real-name { font-size: 1.2rem; font-weight: 700; color: var(--pc-white); letter-spacing: -0.01em; line-height: 1.15; text-shadow: 0 2px 12px rgba(0, 0, 0, 0.6); }
.pc-real-meta { font-size: 0.82rem; color: var(--pc-text); }
.pc-reals-empty { text-align: center; color: var(--pc-muted); padding: 48px 0; }

@media (max-width: 780px) {
  .pc-reals-grid { grid-template-columns: 1fr; grid-auto-rows: 220px; padding: 0 18px; }
  .pc-real, .pc-real--lg { grid-column: 1 / -1; grid-row: span 1; }
}

/* ==========================================================================
   SINGLE CHANTIER
   ========================================================================== */
.pc-single-chantier { padding: 56px 0 96px; }
.pc-single-inner { max-width: 880px; margin: 0 auto; padding: 0 24px; }
.pc-single-back { display: inline-block; margin-bottom: 32px; color: var(--pc-cyan); font-weight: 600; font-size: 0.9rem; }
.pc-single-back:hover { color: var(--pc-yellow); }
.pc-single-eyebrow { font-size: 0.78rem; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 700; color: var(--pc-yellow); margin: 0 0 12px; }
.pc-single-title { font-size: clamp(2rem, 5vw, 3.4rem); line-height: 1.05; letter-spacing: -0.03em; color: var(--pc-white); margin: 0 0 24px; }
.pc-single-meta { list-style: none; display: flex; flex-wrap: wrap; gap: 32px; padding: 20px 0; margin: 0 0 32px; border-top: 1px solid var(--pc-border); border-bottom: 1px solid var(--pc-border); }
.pc-single-meta li { display: flex; flex-direction: column; gap: 4px; font-size: 1.1rem; font-weight: 700; color: var(--pc-white); }
.pc-single-meta li span { font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600; color: var(--pc-muted); }
.pc-single-photo { margin: 0 0 32px; overflow: hidden; }
.pc-single-photo img { width: 100%; }
.pc-single-body { color: var(--pc-text); line-height: 1.75; font-size: 1.05rem; }
.pc-single-body p { margin: 0 0 18px; }
.pc-single-cta { margin-top: 48px; padding-top: 32px; border-top: 1px solid var(--pc-border); display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 18px; }
.pc-single-cta p { font-size: 1.3rem; font-weight: 700; color: var(--pc-white); margin: 0; }

/* Bouton primaire réutilisable */
.pc-btn-primary {
  display: inline-flex; align-items: center; gap: 12px;
  background: var(--pc-yellow); color: var(--pc-bg);
  padding: 16px 28px; font-size: 0.95rem; font-weight: 700;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.pc-btn-primary:hover { transform: translateY(-2px); box-shadow: 0 10px 30px rgba(255, 235, 0, 0.25); }

/* ==========================================================================
   FOOTER
   ========================================================================== */
.pc-footer { background: var(--pc-bg); padding: 64px 0 36px; border-top: 1px solid var(--pc-border); }
.pc-footer-inner { max-width: 1280px; margin: 0 auto; padding: 0 32px; }
.pc-footer-top { display: grid; grid-template-columns: 1.5fr 1fr 1.1fr 1fr; gap: 40px; padding-bottom: 44px; border-bottom: 1px solid var(--pc-border); }
.pc-footer-brand { font-size: 2rem; font-weight: 700; letter-spacing: -0.02em; color: var(--pc-white); }
.pc-footer-brand sup { font-size: 0.4em; color: var(--pc-yellow); vertical-align: super; }
.pc-footer-tagline { font-size: 1rem; line-height: 1.55; color: var(--pc-text); max-width: 360px; margin: 10px 0 18px; }
.pc-footer-certifs { display: flex; flex-direction: column; gap: 4px; font-size: 0.82rem; color: var(--pc-muted); }
.pc-footer-col h4 { font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--pc-yellow); margin: 0 0 16px; font-weight: 700; }
.pc-footer-menu { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.pc-footer-menu li { margin: 0; }
.pc-footer-menu a { white-space: nowrap; }
.pc-footer-col a, .pc-footer-col p { font-size: 0.95rem; line-height: 1.7; color: var(--pc-text); margin: 0; }
.pc-footer-menu a:hover, .pc-footer-contact a:hover { color: var(--pc-yellow); }
.pc-footer-contact p { margin-bottom: 6px; }
.pc-footer-hours { color: var(--pc-muted); font-size: 0.88rem; margin-top: 10px; }
.pc-footer-bottom { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 16px; padding-top: 24px; font-size: 0.82rem; color: var(--pc-muted); }
.pc-footer-legal a { color: var(--pc-muted); transition: color 0.2s ease; }
.pc-footer-legal a:hover { color: var(--pc-yellow); }
.pc-footer-credit { color: var(--pc-muted); font-weight: 600; text-decoration: none; transition: color 0.2s ease; }
.pc-footer-credit:hover { color: var(--pc-yellow); }

@media (max-width: 1000px) {
  .pc-footer-top { grid-template-columns: 1fr 1fr; gap: 32px 40px; }
}
@media (max-width: 780px) {
  .pc-footer-top { grid-template-columns: 1fr 1fr; gap: 28px 24px; }
  .pc-footer-brand-col { grid-column: 1 / -1; }
  .pc-footer-inner { padding: 0 18px; }
  .pc-footer-brand .pc-footer-logo { height: 28px; }
}
@media (max-width: 380px) {
  .pc-footer-top { grid-template-columns: 1fr; }
}

/* ==========================================================================
   ACCESSIBILITÉ — focus visible
   ========================================================================== */
.pc-body a:focus-visible,
.pc-body button:focus-visible { outline: 2px solid var(--pc-cyan); outline-offset: 2px; }
