/* ============================================================
   site.css — Style du site public Paul et Zoé
   Couleurs et polices issues de la charte (theme-pauletzoe.css).
   Passe 2 : en-tête, navigation et pied de page complets.
   ============================================================ */
@import url('theme-pauletzoe.css');
@import url('pages-hover.css');

:root{
  --ink:var(--pz-encre); --muted:var(--pz-gris-doux); --line:var(--pz-ligne);
  --bg:var(--pz-fond); --panel:var(--pz-turquoise-pale);
  --accent:var(--pz-turquoise); --accent-soft:var(--pz-turquoise-clair);
  --rose:var(--pz-rose); --rose-ombre:var(--pz-rose-ombre); --vert:var(--pz-vert);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--pz-corps);color:var(--ink);background:var(--bg);line-height:1.6}
img{max-width:100%;height:auto}
a{color:var(--pz-turquoise-fonce);text-decoration:none}
a:hover{text-decoration:none}

/* ===================== EN-TÊTE ===================== */
.pz-header{font-family:var(--pz-corps);position:sticky;top:0;z-index:1000}

/* Bandeau supérieur */
.pz-topbar{background:var(--pz-turquoise)}
.pz-topbar-inner{max-width:1240px;margin:0 auto;padding:7px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;color:#fff;font-size:14px}
.pz-topbar-left{display:flex;align-items:center;gap:8px;font-weight:500}
.pz-topbar-left i{opacity:.85}
.pz-topbar-right{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.pz-topbar-right a,.pz-topbar-right span{color:#fff}
.pz-topbar-right>a,.pz-hours{display:flex;align-items:center;gap:7px;font-weight:500;text-decoration:none}
.pz-tel{font-weight:600 !important}
.pz-social-top{display:flex;align-items:center;gap:10px;padding-left:14px;border-left:1px solid rgba(255,255,255,.35)}
.pz-social-top a{width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;font-size:12px;transition:background .2s,color .2s}
.pz-social-top a:hover{color:var(--pz-turquoise);background:#fff}

/* Barre de navigation */
.pz-navbar{background:#fff;box-shadow:0 4px 24px rgba(0,0,0,.06)}
.pz-navbar-inner{max-width:1240px;margin:0 auto;padding:12px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.pz-logo{flex:none;display:block;line-height:0}
.pz-logo img{height:54px;width:auto}

.pz-nav{display:flex;align-items:center;gap:4px}
.pz-nav>a,.pz-sub-toggle{padding:10px 14px;border-radius:22px;color:var(--pz-encre);font-weight:600;font-size:15px;font-family:inherit;text-decoration:none;border:0;background:none;cursor:pointer;display:flex;align-items:center;gap:6px;transition:background .2s,color .2s}
.pz-nav>a:hover,.pz-sub-toggle:hover{background:var(--pz-cyan-doux);color:var(--pz-turquoise-fonce)}
.pz-nav>a[aria-current="page"],.pz-sub-toggle[aria-current="page"]{background:var(--pz-cyan-doux);color:var(--pz-turquoise-fonce)}
.pz-sub-toggle i{font-size:10px}

/* Sous-menus (survol, CSS pur) */
.pz-has-sub{position:relative}
.pz-sub{position:absolute;top:calc(100% + 6px);left:0;background:#fff;border-radius:18px;box-shadow:0 14px 40px rgba(0,0,0,.14);padding:8px;min-width:230px;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .18s,transform .18s,visibility .18s;z-index:20}
.pz-has-sub:hover .pz-sub,.pz-has-sub:focus-within .pz-sub{opacity:1;visibility:visible;transform:translateY(0)}
.pz-sub a{display:block;padding:11px 18px;border-radius:14px;color:var(--pz-encre);font-weight:500;font-size:14px;white-space:nowrap;text-decoration:none;transition:background .15s,color .15s}
.pz-sub-rose a:hover{background:#FCD9E9;color:var(--pz-rose-ombre)}
.pz-sub-vert a:hover{background:#E9FAC2;color:#668A1F}
.pz-sub-cyan a:hover{background:var(--pz-cyan-doux);color:var(--pz-turquoise-fonce)}

/* Boutons de nav */
.pz-nav>a.pz-btn-parent{margin-left:8px;padding:10px 16px !important;border-radius:22px;color:var(--pz-turquoise-fonce);font-weight:600;font-size:14px;border:2px solid var(--pz-cyan-doux);display:flex;align-items:center;gap:7px;text-decoration:none;background:#fff;transition:background .2s,color .2s,border-color .2s}
.pz-nav>a.pz-btn-parent:hover{background:var(--pz-turquoise);color:#fff;border-color:var(--pz-turquoise)}
.pz-nav>a.pz-btn-contact{margin-left:4px;width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,#F472B0,#E14C93);color:#fff;display:flex;align-items:center;justify-content:center;text-decoration:none;font-size:17px;box-shadow:0 6px 16px rgba(225,76,147,.38);transition:transform .22s,box-shadow .22s;flex:none}
.pz-nav>a.pz-btn-contact:hover{background:linear-gradient(135deg,#F472B0,#E14C93);transform:translateY(-2px);box-shadow:0 10px 22px rgba(225,76,147,.5)}

/* Burger + panneau mobile */
.pz-burger{display:none;border:0;background:none;font-size:24px;color:var(--pz-turquoise-fonce);cursor:pointer;padding:6px 10px}
.pz-mobile{border-top:1px solid #EEF1F2;padding:10px 16px calc(18px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:6px;background:#fff}
.pz-mobile[hidden]{display:none}
.pz-m-link,.pz-m-group>summary{padding:14px;color:#31363B;font-weight:600;font-size:16px;border-radius:14px;display:flex;align-items:center;gap:12px;text-decoration:none;cursor:pointer;list-style:none}
.pz-m-link i{color:var(--pz-turquoise);width:20px;text-align:center}
.pz-m-link:hover,.pz-m-group>summary:hover{background:#F4FBFD}
.pz-m-group{border-radius:14px}
.pz-m-group>summary{justify-content:space-between}
.pz-m-group>summary::-webkit-details-marker{display:none}
.pz-m-group>summary>span{display:flex;align-items:center;gap:12px}
.pz-m-group>summary i:last-child{transition:transform .2s;font-size:13px;color:var(--muted)}
.pz-m-group[open]>summary i:last-child{transform:rotate(180deg)}
.pz-m-group>a{padding:11px 14px 11px 46px;color:var(--pz-encre);font-weight:500;font-size:15px;border-radius:12px;display:block;text-decoration:none}
.pz-m-group>a:hover{background:var(--pz-cyan-doux);color:var(--pz-turquoise-fonce)}
.pz-m-parent{margin-top:10px;padding:14px;text-align:center;background:#F4FBFD;color:var(--pz-turquoise-fonce);font-weight:700;font-size:15px;border-radius:16px;border:2px solid var(--pz-cyan-doux);display:flex;align-items:center;justify-content:center;gap:10px;text-decoration:none}
.pz-m-contact{margin-top:2px;padding:15px;text-align:center;background:linear-gradient(135deg,#F472B0,#E14C93);color:#fff;font-weight:700;font-size:16px;border-radius:16px;box-shadow:0 8px 20px rgba(225,76,147,.32);display:flex;align-items:center;justify-content:center;gap:10px;text-decoration:none}

@media (max-width:1080px){
  .pz-nav{display:none}
  .pz-burger{display:block}
  .pz-topbar-right .pz-hours,.pz-topbar-left span{display:none}
}
@media (min-width:1081px){
  .pz-mobile{display:none !important}
}

/* ===================== CONTENU ===================== */
.pz-main{min-height:50vh}

/* ===================== PIED DE PAGE ===================== */
.pz-footer{font-family:var(--pz-corps)}

/* Newsletter */
.pz-nl{background:var(--pz-cyan-doux)}
.pz-nl-inner{max-width:1160px;margin:0 auto;padding:46px 24px;display:flex;align-items:center;justify-content:space-between;gap:36px;flex-wrap:wrap}
.pz-nl-inner h2{margin:0;color:var(--pz-turquoise-fonce);font-size:26px;font-weight:700;line-height:1.3;flex:1 1 340px}
.pz-nl-form{flex:1 1 320px;max-width:420px;width:100%}
.pz-nl-row{display:flex;gap:10px;flex-wrap:wrap}
.pz-nl-row input{flex:1 1 180px;border:2px solid #fff;background:#fff;border-radius:14px;padding:14px 16px;font-size:15px;font-family:inherit;color:var(--pz-encre);outline:none}
.pz-nl-row input:focus{border-color:var(--pz-turquoise)}
.pz-nl-row button{flex:none;border:0;background:var(--pz-rose);color:#fff;font-weight:700;font-size:15px;padding:14px 24px;border-radius:14px;cursor:pointer;font-family:inherit;box-shadow:0 6px 0 var(--pz-rose-ombre);transition:transform .15s,box-shadow .15s}
.pz-nl-row button:hover{transform:translateY(2px);box-shadow:0 4px 0 var(--pz-rose-ombre)}
.pz-nl-msg{margin:10px 2px 0;font-size:14px;font-weight:600}
.pz-nl-msg.is-ok{color:var(--pz-turquoise-fonce)}
.pz-nl-msg.is-err{color:#C0392B}

/* Bloc principal */
.pz-foot-main{background:var(--pz-turquoise);color:#fff;position:relative;overflow:hidden}
.pz-plane{position:absolute;right:24px;top:30px;width:220px;opacity:.9;pointer-events:none}
.pz-foot-main-inner{max-width:1160px;margin:0 auto;padding:52px 24px 40px;display:flex;flex-direction:column;align-items:center;gap:20px;text-align:center;position:relative;z-index:1}
.pz-foot-logo{height:58px;width:auto}
.pz-foot-addr{font-size:16px;line-height:1.9;font-weight:500}
.pz-foot-tel{margin-top:8px}
.pz-foot-addr a{color:#fff;text-decoration:none;font-weight:700}
.pz-foot-cta{display:inline-flex;align-items:center;gap:8px;color:#fff;text-decoration:none;font-weight:600;font-size:14.5px;border:2px solid rgba(255,255,255,.6);border-radius:26px;padding:9px 20px;transition:background .2s,border-color .2s}
.pz-foot-cta:hover{background:var(--pz-rose);border-color:var(--pz-rose)}
.pz-foot-social{display:flex;gap:14px}
.pz-foot-social a{width:44px;height:44px;border-radius:50%;border:2px solid rgba(255,255,255,.6);color:#fff;display:flex;align-items:center;justify-content:center;text-decoration:none;transition:background .2s,color .2s,border-color .2s}
.pz-foot-social a:hover{background:#fff;color:var(--pz-turquoise);border-color:#fff}

/* Bas de page */
.pz-foot-bottom{background:var(--pz-turquoise-fonce);color:rgba(255,255,255,.92);font-size:13.5px}
.pz-foot-bottom-inner{max-width:1160px;margin:0 auto;padding:18px 24px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.pz-foot-bottom-inner p{margin:0}
.pz-foot-bottom-inner a{color:#fff}
.pz-foot-bottom-inner p a{text-decoration:underline}
.pz-foot-legal{display:flex;gap:20px;flex-wrap:wrap}
.pz-foot-legal a{text-decoration:none}
.pz-foot-legal a:hover{text-decoration:underline}

@media (max-width:768px){
  .pz-plane{display:none}
  .pz-nl-inner h2{font-size:22px}
}

/* ===================== ONGLETS CSS (sans JS) ===================== */
.pz-tab-radio{position:absolute;opacity:0;pointer-events:none}
.pz-tab{cursor:pointer;border:0;background:#fff;color:var(--pz-encre);font-family:inherit;font-weight:600;font-size:15px;line-height:1.25;text-align:center;padding:14px 22px;border-radius:18px;border:2px solid var(--pz-turquoise-clair);transition:background .2s,color .2s,border-color .2s}
.pz-tab:hover{border-color:var(--pz-turquoise)}
.pz-pane{display:none}
/* Engagements : 3 onglets. Radios, section TABS et panneaux sont frères. */
#pz-eng-ethique:checked ~ #pane-ethique,
#pz-eng-eco:checked ~ #pane-eco,
#pz-eng-collab:checked ~ #pane-collab{display:block}
#pz-eng-ethique:checked ~ section label[for="pz-eng-ethique"],
#pz-eng-eco:checked ~ section label[for="pz-eng-eco"],
#pz-eng-collab:checked ~ section label[for="pz-eng-collab"]{background:var(--pz-turquoise);color:#fff;border-color:var(--pz-turquoise)}
/* Projet pédagogique : 2 onglets */
#pz-ped-env:checked ~ * #pane-ped-env,
#pz-ped-val:checked ~ * #pane-ped-val{display:block}
#pz-ped-env:checked ~ section label[for="pz-ped-env"],
#pz-ped-val:checked ~ section label[for="pz-ped-val"],
#pz-ped-env:checked ~ * label[for="pz-ped-env"],
#pz-ped-val:checked ~ * label[for="pz-ped-val"]{background:var(--pz-turquoise);color:#fff;border-color:var(--pz-turquoise)}

/* ===================== FORMULAIRES ===================== */
.pz-field{display:flex;flex-direction:column;gap:7px}
.pz-field>label{font-size:13.5px;font-weight:600;color:var(--pz-encre)}
.pz-input,.pz-select,.pz-textarea{font-family:var(--pz-corps);font-size:15px;color:var(--pz-encre);border:2px solid #E4E7EA;border-radius:12px;padding:12px 14px;background:#fff;transition:border-color .18s,box-shadow .18s;width:100%;box-sizing:border-box}
.pz-textarea{resize:vertical;min-height:130px}
.pz-input:focus,.pz-select:focus,.pz-textarea:focus{outline:none;border-color:var(--pz-turquoise);box-shadow:0 0 0 3px rgba(0,171,197,.14)}
/* Champ fichier stylé (remplace les zones drag-drop) */
.pz-file{position:relative;display:flex;align-items:center;gap:14px;border:2px dashed #B7E4EC;border-radius:16px;background:#F4FBFC;padding:18px;cursor:pointer;transition:border-color .18s,background .18s,box-shadow .18s;min-height:88px}
.pz-file:hover{border-color:var(--pz-turquoise);background:#EAF8FB}
.pz-file input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.pz-file-ic{width:46px;height:46px;flex:none;border-radius:12px;background:var(--pz-turquoise-clair);color:var(--pz-turquoise-fonce);display:flex;align-items:center;justify-content:center;font-size:20px}
.pz-file-t{font-size:14px;font-weight:600;color:var(--pz-encre);line-height:1.4}
.pz-file-t small{font-weight:500;color:var(--muted)}
@media (max-width:820px){
  .pz-formgrid{grid-template-columns:1fr !important}
  .pz-grid2{grid-template-columns:1fr !important}
}

/* ===================== GALERIE SIMPLE ===================== */
.pz-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.pz-gallery-item{display:block;overflow:hidden;border-radius:16px;line-height:0;box-shadow:0 8px 20px rgba(0,133,154,.10)}
.pz-gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease;display:block}
.pz-gallery-item:hover img{transform:scale(1.05)}
@media (max-width:640px){.pz-gallery{grid-template-columns:1fr}}

/* ===================== CORPS D'ARTICLE (.pz-body) =====================
   Feuille UNIQUE partagée par le rendu public ET l'aperçu du back-office :
   ce qui est saisi dans l'éditeur s'affiche à l'identique en front-office. */
.pz-body{color:var(--pz-encre)}
.pz-body>*:first-child{margin-top:0}
.pz-body p{margin:0 0 18px;font-size:16.5px;line-height:1.9;color:var(--pz-encre)}
.pz-body h2{margin:38px 0 12px;color:var(--pz-turquoise);font-weight:700;font-size:23px;line-height:1.3}
.pz-body h3{margin:30px 0 10px;color:var(--pz-turquoise-fonce);font-weight:700;font-size:19px;line-height:1.35}
.pz-body h4{margin:24px 0 8px;color:var(--pz-turquoise-fonce);font-weight:700;font-size:17px;line-height:1.4}
.pz-body ul,.pz-body ol{margin:0 0 20px;padding-left:22px}
.pz-body li{margin:0 0 9px;font-size:16.5px;line-height:1.75}
.pz-body img{max-width:100%;height:auto;border-radius:16px;margin:14px 0;display:block}
.pz-body a{color:var(--pz-turquoise);font-weight:600}
.pz-body a:hover{text-decoration:underline}
.pz-body strong,.pz-body b{color:#3d4145;font-weight:700}
.pz-body em,.pz-body i{font-style:italic}
.pz-body blockquote{margin:20px 0;padding:14px 22px;border-left:4px solid var(--pz-cyan-doux);background:var(--pz-turquoise-pale);border-radius:0 12px 12px 0;color:var(--pz-encre);font-style:italic}
.pz-body blockquote p:last-child{margin-bottom:0}

/* ===================== BLOG (liste + article) ===================== */
/* Bandeau liste */
.pz-blog-hero{background:linear-gradient(135deg,var(--pz-turquoise),var(--pz-turquoise-fonce))}
.pz-blog-hero-inner{max-width:1160px;margin:0 auto;padding:74px 24px 78px;text-align:center}
.pz-blog-kicker{font-family:var(--pz-titre-deco);color:#d6f4f9;font-size:30px;line-height:1;margin-bottom:6px}
.pz-blog-hero h1{margin:0;color:#fff;font-weight:700;font-size:clamp(30px,4.6vw,52px);line-height:1.12}
.pz-blog-intro{background:#fff}
.pz-blog-intro p{max-width:760px;margin:0 auto;padding:56px 24px 8px;text-align:center;font-size:17px;line-height:1.85}
/* Filtres catégories */
.pz-blog-filters{background:#fff;display:flex;gap:12px;justify-content:center;flex-wrap:wrap;padding:28px 24px 4px}
.pz-chip{padding:9px 20px;border-radius:22px;border:2px solid var(--pz-turquoise-clair);color:var(--pz-encre);font-weight:600;font-size:14px;text-decoration:none;transition:background .2s,color .2s,border-color .2s}
.pz-chip:hover{border-color:var(--pz-turquoise)}
.pz-chip.is-active{background:var(--pz-turquoise);color:#fff;border-color:var(--pz-turquoise)}
/* Grille de cartes */
.pz-blog-grid-wrap{background:#fff}
.pz-blog-grid{max-width:1160px;margin:0 auto;padding:36px 24px 72px;display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.pz-blog-empty{max-width:1160px;margin:0 auto;padding:20px 24px 72px;text-align:center;color:var(--muted)}
.pz-artcard{text-decoration:none;color:inherit;display:flex;flex-direction:column;background:#fff;border-radius:22px;overflow:hidden;box-shadow:0 10px 30px rgba(84,89,95,.10);transition:transform .25s,box-shadow .25s}
.pz-artcard:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(84,89,95,.16)}
.pz-artcard-img{height:210px;overflow:hidden}
.pz-artcard-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s}
.pz-artcard:hover .pz-artcard-img img{transform:scale(1.05)}
.pz-artcard-body{padding:26px 26px 30px;display:flex;flex-direction:column;flex:1}
.pz-artcard-cat{align-self:flex-start;font-size:12px;font-weight:600;letter-spacing:.4px;padding:5px 12px;border-radius:20px;margin-bottom:14px}
.pz-artcard-body h3{margin:0 0 10px;color:var(--pz-turquoise-fonce);font-weight:700;font-size:19px;line-height:1.35}
.pz-artcard-body p{margin:0 0 18px;font-size:14.5px;line-height:1.7;color:#6b7075}
.pz-artcard-more{margin-top:auto;color:var(--pz-rose);font-weight:600;font-size:14px}
.pz-artcard-more i{font-size:12px;margin-left:4px}
/* Article */
.pz-art-hero{position:relative;overflow:hidden}
.pz-art-hero-inner{max-width:900px;margin:0 auto;padding:58px 24px 62px;text-align:center}
.pz-art-badge{display:inline-block;background:rgba(255,255,255,.22);color:#fff;font-size:12px;font-weight:600;letter-spacing:.6px;padding:6px 14px;border-radius:20px;margin-bottom:16px}
.pz-art-hero h1{margin:0;color:#fff;font-weight:700;font-size:clamp(26px,3.8vw,42px);line-height:1.18}
.pz-art-date{margin-top:14px;color:rgba(255,255,255,.9);font-size:14px}
.pz-art-date i{margin-right:7px}
.pz-art-cover{max-width:940px;margin:0 auto;padding:0 24px;transform:translateY(-34px)}
.pz-art-cover img{width:100%;height:auto;border-radius:22px;box-shadow:0 22px 50px rgba(84,89,95,.22);display:block}
.pz-art-body{max-width:760px;margin:0 auto;padding:6px 24px 60px}
.pz-art-back{margin-top:44px;padding-top:30px;border-top:1px solid #eee}
.pz-art-back a{color:var(--pz-turquoise);font-weight:600;text-decoration:none;font-size:15px}
.pz-art-back a i{margin-right:8px;font-size:13px}
@media (max-width:900px){.pz-blog-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.pz-blog-grid{grid-template-columns:1fr}}

/* ===================== ESPACE PARENT (tableau de bord) ===================== */
.pz-parent-hero{background:linear-gradient(135deg,var(--pz-turquoise),var(--pz-turquoise-fonce))}
.pz-parent-hero-inner{max-width:1080px;margin:0 auto;padding:46px 24px 50px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.pz-parent-kicker{font-family:var(--pz-titre-deco);color:#d6f4f9;font-size:26px;line-height:1;margin-bottom:2px}
.pz-parent-hero h1{margin:0;color:#fff;font-weight:700;font-size:clamp(26px,3.4vw,38px)}
.pz-parent-hero p{margin:8px 0 0;color:rgba(255,255,255,.9);font-size:14.5px}
.pz-parent-logout{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.16);color:#fff;text-decoration:none;font-weight:600;font-size:14px;padding:11px 20px;border-radius:26px;transition:background .2s}
.pz-parent-logout:hover{background:rgba(255,255,255,.28)}
.pz-parent-wrap{max-width:1080px;margin:0 auto;padding:44px 24px 72px}
.pz-parent-block{margin-bottom:48px}
.pz-parent-block>h2{display:flex;align-items:center;gap:11px;color:var(--pz-turquoise-fonce);font-weight:700;font-size:22px;margin:0 0 22px}
.pz-parent-block>h2 i{color:var(--pz-turquoise)}
.pz-parent-empty{color:var(--muted);font-size:15px}
/* Documents */
.pz-doc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.pz-doc{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid var(--pz-turquoise-pale);border-radius:18px;padding:18px 20px;text-decoration:none;color:var(--pz-encre);box-shadow:0 8px 22px rgba(0,133,154,.07);transition:transform .2s,box-shadow .2s}
.pz-doc:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(0,133,154,.14)}
.pz-doc.is-soon{opacity:.62;cursor:default;pointer-events:none}
.pz-doc-ic{flex:none;width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,var(--pz-cyan-doux),var(--pz-turquoise));display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px}
.pz-doc-txt{display:flex;flex-direction:column;flex:1;min-width:0}
.pz-doc-txt strong{font-size:15.5px;color:var(--pz-turquoise-fonce)}
.pz-doc-txt small{color:var(--muted);font-size:12.5px;margin-top:2px}
.pz-doc-act{color:var(--pz-turquoise);font-size:15px}
/* Actualités */
.pz-news-list{display:flex;flex-direction:column;gap:16px}
.pz-news{display:flex;gap:16px;background:#fff;border-left:4px solid var(--pz-turquoise);border-radius:0 16px 16px 0;padding:18px 22px;box-shadow:0 8px 22px rgba(84,89,95,.07)}
.pz-news-ic{flex:none;width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:17px}
.pz-news-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap}
.pz-news-head h3{margin:0;color:var(--pz-encre);font-weight:700;font-size:17px}
.pz-news-head time{color:var(--muted);font-size:13px;white-space:nowrap}
.pz-news-body p{margin:7px 0 0;color:#5f6469;font-size:14.5px;line-height:1.7}
/* Galerie */
.pz-photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.pz-photo{margin:0;border-radius:16px;overflow:hidden;box-shadow:0 8px 22px rgba(84,89,95,.10);background:#fff}
.pz-photo img{width:100%;height:200px;object-fit:cover;display:block;transition:transform .4s}
.pz-photo:hover img{transform:scale(1.05)}
.pz-photo figcaption{padding:10px 14px;font-size:13px;color:#5f6469}
@media (max-width:720px){.pz-doc-grid,.pz-photo-grid{grid-template-columns:1fr}.pz-photo-grid{grid-template-columns:repeat(2,1fr)}}

/* ===================== ESPACE PARENT (rendu maquette) ===================== */
.pz-navlink{display:flex;align-items:center;gap:11px;padding:11px 14px;border-radius:12px;color:#54595F;text-decoration:none;font-weight:600;font-size:14px;transition:background .2s,color .2s}
.pz-navlink:hover{background:#F1FAFB;color:#00859A}
.pz-navlink i{width:18px;text-align:center}
.pz-doc-card{transition:transform .2s,box-shadow .2s}
.pz-doc-card:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(0,133,154,.12)}
.pz-doc-soon{opacity:.72;cursor:default;pointer-events:none}
.pz-mosaic{column-count:3;column-gap:12px}
.pz-mosaic .pz-gal-item{break-inside:avoid;margin-bottom:12px;display:block;width:100%;border-radius:14px;overflow:hidden;cursor:pointer;padding:0;border:0;background:none;font:inherit;text-align:left}
.pz-gal-item img{transition:transform .5s ease;display:block;width:100%;height:auto;border-radius:14px}
.pz-gal-item:hover img{transform:scale(1.08)}
.pz-gal-item:focus-visible{outline:3px solid #00ABC5;outline-offset:2px}
@media(max-width:900px){.pz-parent-grid{grid-template-columns:1fr !important}.pz-side{position:static !important}.pz-mosaic{column-count:2}}
@media(max-width:560px){.pz-mosaic{column-count:1}}

/* ---- Visionneuse (lightbox) de la galerie parent ---- */
.pz-lb{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center}
.pz-lb[hidden]{display:none}
.pz-lb-backdrop{position:absolute;inset:0;background:rgba(15,32,39,.86);backdrop-filter:blur(3px);cursor:zoom-out}
.pz-lb-stage{position:relative;z-index:1;margin:0;max-width:92vw;max-height:88vh;display:flex;flex-direction:column;align-items:center;gap:12px}
.pz-lb-img{max-width:92vw;max-height:78vh;width:auto;height:auto;border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.5);background:#fff;object-fit:contain}
.pz-lb-cap{display:flex;flex-direction:column;align-items:center;gap:2px;color:#fff;text-align:center;font-size:14px}
.pz-lb-caption{font-weight:600}
.pz-lb-counter{font-size:12px;opacity:.75}
.pz-lb-btn{position:absolute;z-index:2;border:0;cursor:pointer;background:rgba(255,255,255,.14);color:#fff;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:19px;transition:background .15s}
.pz-lb-btn:hover{background:rgba(255,255,255,.28)}
.pz-lb-close{top:18px;right:18px;width:44px;height:44px}
.pz-lb-prev{left:18px;top:50%;transform:translateY(-50%)}
.pz-lb-next{right:18px;top:50%;transform:translateY(-50%)}
.pz-lb-prev[disabled],.pz-lb-next[disabled]{opacity:.3;cursor:default}
@media(max-width:560px){
  .pz-lb-prev{left:8px}.pz-lb-next{right:8px}
  .pz-lb-btn{width:42px;height:42px;font-size:17px}
  .pz-lb-img{max-height:70vh}
}
