/*
Theme Name: Chien Vous Parle Child
Theme URI: https://example.com/chien-vous-parle-child
Description: Child theme for Chien Vous Parle (safe customizations).
Author: Chien Vous Parle
Template: chien-vous-parle
Version: 0.2.27
Text Domain: chien-vous-parle-child
*/

/* Ajoutez vos surcharges ici. */

/* --- Sidepanel menu redesign --- */
.cvg-sidepanel{
  width: 320px;
  right: -340px;
  padding: 86px 20px 20px;
  background: var(--cvg-green);
  border-left: 1px solid rgba(var(--cvg-beige-rgb),0.12);
}

.cvg-sidepanel .cvg-menu{
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.cvg-sidepanel .cvg-menu a{
  font-family: var(--cvg-font-hand);
  font-weight: 400;
  font-size: 18px;
  padding: 12px 14px;
  border-radius: 14px;
  background: rgba(var(--cvg-beige-rgb),0.06);
  border: 1px solid rgba(var(--cvg-beige-rgb),0.12);
  text-decoration: none;
  transition: background .2s ease, transform .2s ease, opacity .2s ease;
}

.cvg-sidepanel .cvg-menu a:hover{
  background: rgba(var(--cvg-beige-rgb),0.14);
  border-color: rgba(var(--cvg-beige-rgb),0.22);
  transform: translateX(2px);
  opacity: 1;
}

.cvg-sidepanel .current-menu-item > a{
  background: rgba(var(--cvg-beige-rgb),0.14);
  text-decoration: none;
}

/* --- Cards aligned with palette --- */
:root{
  --cvg-green-rgb: 33,61,31;
  --cvg-beige-rgb: 232,213,180;
  --cvg-card-bg: #f8f1e4;
  --cvg-card-bg-alt: #f3e7d2;
  --cvg-card-border: rgba(33,59,31,0.10);
}

.cvg-card{
  background: var(--cvg-card-bg);
  border: 1px solid var(--cvg-card-border);
  box-shadow: 0 6px 18px rgba(0,0,0,.08);
}

.cvg-section--alt .cvg-card{
  background: var(--cvg-card-bg-alt);
}

.cvg-card h1,
.cvg-card h2,
.cvg-card h3{
  color: var(--cvg-green);
}

.cvg-card input[type="text"],
.cvg-card input[type="email"],
.cvg-card input[type="tel"],
.cvg-card textarea,
.cvg-card select{
  width: 100%;
  background: #fff;
  border: 1px solid rgba(33,59,31,0.18);
  border-radius: 12px;
  padding: .6rem .8rem;
}

/* Titres visibles sur fond beige */
.cvg-section h1,
.cvg-section h2,
.cvg-section h3,
.cvg-section h4,
.cvg-section .wp-block-heading,
.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4 {
  color: var(--cvg-green) !important;
}

/* Mais dans le hero (fond vert), on garde un texte clair */
.cvg-hero .cvg-hero__title,
.cvg-hero .cvg-hero__subtitle,
.cvg-hero h1,
.cvg-hero h2 {
  color: var(--cvg-beige) !important;
}


/* Helpers for ACF-controlled sizing */
.cvg-img--constrained {
  width: 100%;
  height: auto;
  object-fit: cover;
  display: block;
}

/* Prevent CSS grid stretching from forcing media columns to a smaller height */
.cvg-grid{align-items:start;}

/* Match text-card height to media-card height when side-by-side (>= 900px) */
@media(min-width:900px){
  .cvg-grid--match-media > .cvg-card:not(.cvg-card--media){
    align-self: stretch;
    display: flex;
    flex-direction: column;
  }
}

.cvg-card img {
  max-width: 100%;
}

/* Media cards: image flush (no inner frame) without cropping */
.cvg-card.cvg-card--media{
  padding: 0 !important;
  overflow: hidden;
  display: block;
  align-self: start; /* prevent grid stretch from forcing image crop */
}
.cvg-card.cvg-card--media img{
  width: 100%;
  height: auto !important;
  max-height: none !important;
  object-fit: contain !important;
  object-position: center top;
  display: block;
  border: 0 !important;
  border-radius: 0 !important;
}



/* --- Petsitting / Tarifs --- */
.cvg-pricing-wrap{margin-top: 12px;}
.cvg-pricing-table{
  width:100%;
  border-collapse:collapse;
  margin-top:8px;
  font-size: 16px;
}
.cvg-pricing-table th,
.cvg-pricing-table td{
  border:1px solid rgba(var(--cvg-beige-rgb),.25);
  padding:10px 12px;
}
.cvg-pricing-table th{
  background: rgba(var(--cvg-beige-rgb),.12);
  font-weight:700;
  text-align:left;
}
.cvg-pricing-help{
  margin-top:8px;
  font-size: 14px;
}

/* Petsitting responsive layout override (child) */
.cvg-petsitting-grid{grid-template-columns:1fr;}
.cvg-petsitting-card .cvg-petsitting-inner{display:grid;gap:18px;align-items:start;}
@media(min-width:900px){
  /* Two-column only when an image is present; otherwise content uses full width */
  .cvg-petsitting-card .cvg-petsitting-inner.has-media{grid-template-columns:minmax(220px,320px) 1fr;}
  .cvg-petsitting-card .cvg-petsitting-inner.no-media{grid-template-columns:1fr;}
}
.cvg-petsitting-body{min-width:0;}
.cvg-petsitting-media img{width:100%;height:auto;display:block;border-radius:18px;}


/* --- Contact / Réserver: cards + buttons --- */
.cvg-card--service{
  display: flex;
  flex-direction: column;
}

.cvg-card__actions{
  margin-top: auto;
}

.cvg-btn--block{
  width: 100%;
  text-align: center;
}

.cvg-btn--disabled{
  opacity: .55;
  pointer-events: none;
  box-shadow: none;
}


/* --- Modern header & footer (child) --- */

:root{
  --cvg-header-blur: 0px;
  --cvg-header-bg: var(--cvg-green);
}

/* Header: modern translucent surface + desktop menu */
.cvg-header{
  background: var(--cvg-header-bg);
box-shadow: 0 10px 30px rgba(0,0,0,.15);
  border-bottom: 1px solid rgba(var(--cvg-beige-rgb),0.10);
  transition: background .2s ease, box-shadow .2s ease, border-color .2s ease;
}

body.cvg-scrolled .cvg-header{
  background: var(--cvg-header-bg);
  box-shadow: 0 12px 34px rgba(0,0,0,.18);
  border-bottom-color: rgba(var(--cvg-beige-rgb),0.16);
}

.cvg-header__inner{height:78px; gap:14px;}
.cvg-header__nav{display:none;}

@media(min-width:900px){
  .cvg-header__nav{display:block;}
  .cvg-burger{display:none;}
  .cvg-menu--desktop{
    margin:0; padding:0; list-style:none;
    display:flex; align-items:center; gap:10px;
  }
  .cvg-menu--desktop a{
    display:inline-flex;
    align-items:center;
    padding:10px 12px;
    border-radius:999px;
    text-decoration:none;
    color:var(--cvg-beige);
    position:relative;
  }
  .cvg-menu--desktop a::after{
    content:"";
    position:absolute;
    left:14px; right:14px; bottom:6px;
    height:2px;
    background:rgba(var(--cvg-beige-rgb),0.75);
    transform:scaleX(0);
    transform-origin:left;
    transition:transform .18s ease;
  }
  .cvg-menu--desktop a:hover{
    text-decoration:none;
    background:rgba(var(--cvg-beige-rgb),0.10);
  }
  .cvg-menu--desktop a:hover::after,
  .cvg-menu--desktop .current-menu-item > a::after,
  .cvg-menu--desktop .current_page_item > a::after{
    transform:scaleX(1);
  }
  .cvg-menu--desktop .current-menu-item > a,
  .cvg-menu--desktop .current_page_item > a{
    background:rgba(var(--cvg-beige-rgb),0.14);
  }
}

/* Burger: soft hover + open animation (driven by html.cvg-menu-open) */
.cvg-burger{
  border-radius:14px;
  transition:background .15s ease, transform .15s ease;
}
.cvg-burger:hover{
  background:rgba(var(--cvg-beige-rgb),0.10);
  transform:translateY(-1px);
}
html.cvg-menu-open .cvg-burger span:nth-child(1){
  transform:translateY(7px) rotate(45deg);
}
html.cvg-menu-open .cvg-burger span:nth-child(2){
  opacity:0;
}
html.cvg-menu-open .cvg-burger span:nth-child(3){
  transform:translateY(-7px) rotate(-45deg);
}

/* Footer: gradient surface + bottom bar */
.cvg-footer{
  position:relative;
  background: var(--cvg-green);
  border-top:1px solid rgba(var(--cvg-beige-rgb),0.12);
  padding:54px 0 0;
  overflow:hidden;
}
.cvg-footer::before,
.cvg-footer::after{
  content: none;
}

.cvg-footer__grid{position:relative;}
.cvg-footer p{opacity:.92;}

/* Footer nav lists under logo */
.cvg-footer__nav{
  margin-top:18px;
}
.cvg-footer-links{
  list-style:none;
  margin:12px 0 0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.cvg-footer-links--legal{
  margin-top:22px;
}
.cvg-footer-links li{
  margin:0;
}


.cvg-social-link{
  border-radius:14px;
  background:rgba(var(--cvg-beige-rgb),0.08);
  border:1px solid rgba(var(--cvg-beige-rgb),0.12);
  transition:transform .15s ease, background .15s ease, border-color .15s ease;
}
.cvg-social-link:hover{
  text-decoration:none;
  transform:translateY(-1px);
  background:rgba(var(--cvg-beige-rgb),0.12);
  border-color:rgba(var(--cvg-beige-rgb),0.20);
}
.cvg-social-link:focus-visible{
  outline:2px solid rgba(var(--cvg-beige-rgb),0.65);
  outline-offset:3px;
}

.cvg-footer-links a{
  display:inline-flex;
  padding:6px 8px;
  border-radius:10px;
}
.cvg-footer-links a:hover{
  text-decoration:none;
  background:rgba(var(--cvg-beige-rgb),0.10);
}

.cvg-footer__bottom{
  margin-top:34px;
  border-top:1px solid rgba(var(--cvg-beige-rgb),0.12);
  padding:16px 0 18px;
  position:relative;
}
.cvg-footer__bottom-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.cvg-footer__copy{font-size:14px; opacity:.86;}

.cvg-footer-bottom-menu{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.cvg-footer-bottom-menu a{
  font-size:14px;
  opacity:.92;
  text-decoration:none;
  padding:6px 8px;
  border-radius:10px;
}
.cvg-footer-bottom-menu a:hover{
  background:rgba(var(--cvg-beige-rgb),0.10);
  text-decoration:none;
}


/* --- Typography: Dosis for body + home hero subtitle --- */
:root{
  --cvg-font-body: "Dosis", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  --cvg-font-hand: "Sue Ellen Francisco", cursive;
}

/* Body text */
body{
  font-family: var(--cvg-font-body);
  font-weight: 400;
}



/* Buttons font */
.cvg-btn,
.wp-block-button .wp-block-button__link,
.wp-element-button,
button,
input[type="submit"],
input[type="button"],
input[type="reset"]{
  font-family: var(--cvg-font-body) !important;
}
/* Homepage hero subtitle */
.cvg-hero__subtitle{
    font-family: var(--cvg-font-hand);
  font-weight: 400;
  letter-spacing: .3px;

}



/* --- Services: accordÃ©on (rÃ©sumÃ© + dÃ©tails au clic) --- */
.cvg-service-accordion.cvg-card{
  padding: 0;
  overflow: hidden;
}

/*
  Services (desktop): Ã©viter le "grand bloc vide" Ã  cÃ´tÃ© dâun service ouvert.
  - Les items ne sâÃ©tirent plus en hauteur (align-self)
  - Un service ouvert prend toute la largeur (span 2 colonnes) pour pousser les autres en dessous
*/
details.cvg-service-accordion{
  align-self: start;
}

@media (min-width: 900px){
  details.cvg-service-accordion[open]{
    grid-column: 1 / -1;
  }
}

.cvg-service-accordion > summary{
  list-style: none;
  cursor: pointer;
  padding: 18px 18px;
  display: flex;
  gap: 16px;
  align-items: center;
}


/* Services: quand l'accordÃ©on est ouvert, supprimer les sÃ©parateurs internes */
details.cvg-service-accordion[open] > summary{
  border-bottom: none;
}

.cvg-service-accordion > summary::-webkit-details-marker{ display:none; }

.cvg-service-thumb{
  flex: 0 0 auto;
  width: 120px;
  border-radius: 14px;
  object-fit: cover;
}

.cvg-service-summary-text{
  flex: 1 1 auto;
  min-width: 0;
}

.cvg-service-title{
  margin: 0 0 6px 0;
}

.cvg-service-teaser{
  margin: 0 0 8px 0;
  opacity: .85;
}
/* Service ouvert : masquer l'intro (rÃ©sumÃ©) */
details[open] > summary .cvg-service-teaser{
  display: none;
}
details[open] > summary .cvg-service-hint{
  display: none;
}


/* Service ouvert : compacter l'espace (intro masquée) */
details.cvg-service-accordion[open] > summary{
  padding-top: 16px;
  padding-bottom: 10px;
  align-items: flex-start;
}
details.cvg-service-accordion[open] > summary .cvg-service-title{
  margin-bottom: 0;
}
details.cvg-service-accordion[open] .cvg-service-details{
  padding-top: 8px;
}
.cvg-service-details h4{
  margin-top: 0;
}


.cvg-service-hint{
  font-size: .95rem;
  opacity: .65;
}

.cvg-service-chevron{
  flex: 0 0 auto;
  width: 14px;
  height: 14px;
  border-right: 2px solid var(--cvg-green);
  border-bottom: 2px solid var(--cvg-green);
  transform: rotate(-45deg);
  transition: transform .2s ease;
  opacity: .8;
  margin-left: 6px;
}

details[open] > summary .cvg-service-chevron{
  transform: rotate(45deg);
}

.cvg-service-details{
  padding: 10px 18px 18px 18px;
  border-top: none;
}

/* Services: Packs / forfaits (bloc distinct dans la zone "Tarifs") */
.cvg-packs-box{
  margin-top: 12px;
  padding: 12px 14px;
  background: var(--cvg-card-bg-alt);
  border: 1px dashed rgba(33,59,31,0.22);
  border-left: 6px solid rgba(33,59,31,0.35);
  border-radius: 16px;
}
.cvg-packs-header{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}
.cvg-packs-header h4{
  margin: 0;
  font-size: 18px;
}
.cvg-packs-badge{
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 12px;
  letter-spacing: .2px;
  background: rgba(var(--cvg-beige-rgb),0.18);
  border: 1px solid rgba(33,59,31,0.14);
  color: var(--cvg-green);
  white-space: nowrap;
}
.cvg-packs-content > *:first-child{ margin-top: 0; }
.cvg-packs-content > *:last-child{ margin-bottom: 0; }
.cvg-packs-content ul,
.cvg-packs-content ol{
  margin: 0.75rem 0 0.75rem 1.25rem;
  padding: 0;
}
.cvg-packs-content li{ margin: 0.25rem 0; }

.cvg-service-bottom{
  margin-top: 12px;
  display: flex;
  gap: 12px;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}

.cvg-service-bottom p{
  margin: 0;
}

@media (max-width: 620px){
  .cvg-service-accordion > summary{
    padding: 16px;
    align-items: flex-start;
  }
  .cvg-service-thumb{
    width: 96px;
  }
  .cvg-service-details{
    padding: 0 16px 16px 16px;
  }
}


/* Services: nice lists inside accordion */
.cvg-whyhow-text ul,
.cvg-whyhow-text ol{
  margin: 0.75rem 0 0.75rem 1.25rem;
  padding: 0;
}
.cvg-whyhow-text li{
  margin: 0.25rem 0;
}
.cvg-whyhow-text ul ul,
.cvg-whyhow-text ul ol,
.cvg-whyhow-text ol ul,
.cvg-whyhow-text ol ol{
  margin-top: 0.35rem;
  margin-bottom: 0;
}

/* Hero: garder un padding horizontal (le parent met padding:90px 0 sur .cvg-hero__content) */
.cvg-hero__content{
  padding-left: 20px;
  padding-right: 20px;
}
@media (max-width: 620px){
  .cvg-hero__content{
    padding-left: 18px;
    padding-right: 18px;
  }
}
/* Rich text blocks (ACF WYSIWYG) */
.cvg-richtext > *:first-child { margin-top: 0; }
.cvg-richtext > *:last-child { margin-bottom: 0; }
.cvg-richtext p { margin: 0 0 12px; }
.cvg-richtext ul,
.cvg-richtext ol { margin: 0 0 12px 1.2em; padding: 0; }
.cvg-richtext li { margin: 0 0 6px; }
.cvg-richtext ul ul,
.cvg-richtext ol ol,
.cvg-richtext ul ol,
.cvg-richtext ol ul { margin-bottom: 0; }


/* WYSIWYG generic (services page extra section) */
.cvg-wysiwyg > *:first-child{ margin-top: 0; }
.cvg-wysiwyg > *:last-child{ margin-bottom: 0; }
.cvg-wysiwyg ul,
.cvg-wysiwyg ol{
  margin: 0.75rem 0 0.75rem 1.25rem;
  padding: 0;
}
.cvg-wysiwyg li{ margin: 0.25rem 0; }
.cvg-wysiwyg ul ul,
.cvg-wysiwyg ul ol,
.cvg-wysiwyg ol ul,
.cvg-wysiwyg ol ol{
  margin-top: 0.5rem;
}


/* --- Legal pages (CGV): ensure readable content even if animations/CSS override colors --- */
.cvg-legal-content{
  opacity: 1 !important;
  transform: none !important;
  color: var(--cvg-green) !important;
}
.cvg-legal-content p,
.cvg-legal-content li,
.cvg-legal-content span,
.cvg-legal-content div{
  color: var(--cvg-green) !important;
}
.cvg-legal-content a{
  color: var(--cvg-brown) !important;
}
