/* ============================================================
   plage.css — Design "wahoo" plages (Azur Vacances)
   Réutilise les variables + nav + footer + .wrap/.eyebrow/.dash-title
   d'azur.css. Ici uniquement le spécifique des 2 pages :
     .pl  → liste "Plages du Var"  (activites/plages.html)
     .pf  → fiche plage            (plages/<slug>.html, généré PHP)
   ============================================================ */

/* ============================================================
   LISTE  (.pl)
   ============================================================ */

/* ----- HERO ----- */
.pl-hero{position:relative;height:100vh;min-height:680px;max-height:920px;overflow:hidden;color:#fff;background:#06243a}
.pl-hero .hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 55%;
  animation:pl-kenburns 26s ease-in-out infinite alternate;transform-origin:center 60%}
@keyframes pl-kenburns{0%{transform:scale(1.06)}100%{transform:scale(1.18) translateY(-1.5%)}}
.pl-hero .hero-grad{position:absolute;inset:0;background:
  linear-gradient(180deg, rgba(6,36,58,.55) 0%, rgba(6,36,58,0) 22%, rgba(6,36,58,0) 50%, rgba(6,36,58,.35) 75%, var(--cream) 100%)}
.pl-hero .hero-sun{position:absolute;left:18%;top:34%;width:46vw;height:46vw;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle, rgba(255,220,140,.55) 0%, rgba(255,180,110,.22) 32%, rgba(255,180,110,0) 62%);
  mix-blend-mode:screen;animation:pl-sunpulse 7s ease-in-out infinite}
@keyframes pl-sunpulse{0%,100%{opacity:.75;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}
.pl-hero .hero-shimmer{position:absolute;left:0;right:0;bottom:0;height:42%;pointer-events:none;opacity:.5;mix-blend-mode:screen;
  background:repeating-linear-gradient(95deg, rgba(255,255,255,0) 0 38px, rgba(255,255,255,.12) 40px 42px, rgba(255,255,255,0) 44px 80px);
  animation:pl-shimmer 9s linear infinite}
@keyframes pl-shimmer{0%{transform:translateX(0)}100%{transform:translateX(-80px)}}
.pl-hero .orb{position:absolute;border-radius:50%;pointer-events:none;background:radial-gradient(circle,rgba(255,255,255,.9),rgba(255,255,255,0) 70%);filter:blur(.5px);opacity:0;animation:pl-floaty linear infinite}
@keyframes pl-floaty{0%{opacity:0;transform:translateY(20px) scale(.6)}15%{opacity:.8}85%{opacity:.7}100%{opacity:0;transform:translateY(-120px) scale(1)}}

.pl-hero .hero-content{position:relative;z-index:10;height:100%;display:flex;flex-direction:column;justify-content:center;padding-top:40px}
.pl-hero .hero-kicker{display:inline-flex;align-items:center;gap:12px;font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;
  background:rgba(255,255,255,.14);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.28);
  padding:9px 18px;border-radius:999px;width:max-content;color:#fff;
  opacity:0;animation:pl-rise .8s .15s cubic-bezier(.2,.8,.3,1) forwards}
.pl-hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(48px,9vw,124px);line-height:.92;letter-spacing:-.03em;margin:22px 0 0;max-width:16ch;
  text-shadow:0 4px 40px rgba(6,36,58,.4);font-variation-settings:"opsz" 144}
.pl-hero h1 .l{display:inline-block;opacity:0;transform:translateY(40px);animation:pl-rise .9s cubic-bezier(.2,.8,.3,1) forwards}
.pl-hero h1 em{font-style:italic;font-weight:500;color:var(--olive)}
@keyframes pl-rise{to{opacity:1;transform:none}}
.pl-hero .hero-sub{margin-top:24px;font-size:clamp(16px,2vw,21px);color:rgba(255,255,255,.92);max-width:46ch;font-weight:400;line-height:1.5;
  opacity:0;animation:pl-rise .8s .7s cubic-bezier(.2,.8,.3,1) forwards}
.pl-hero .hero-actions{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap;opacity:0;animation:pl-rise .8s .85s cubic-bezier(.2,.8,.3,1) forwards}
.pl-hero .btn-pill{background:var(--corail);box-shadow:0 10px 26px -8px rgba(255,122,77,.6)}
.pl-hero .btn-pill:hover{background:#e25f30}
.pl-hero .btn-glass{display:inline-flex;align-items:center;gap:9px;padding:14px 24px;border-radius:999px;background:rgba(255,255,255,.16);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);color:#fff;font-weight:600;font-size:14px;transition:background .2s,transform .2s}
.pl-hero .btn-glass:hover{background:rgba(255,255,255,.26);transform:translateY(-2px)}

.pl-hero .live-bar{position:absolute;left:0;right:0;bottom:34px;z-index:12;opacity:0;animation:pl-rise .8s 1s cubic-bezier(.2,.8,.3,1) forwards}
.pl-hero .live-inner{display:flex;gap:0;background:rgba(8,24,43,.52);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.22);border-radius:18px;overflow:hidden;max-width:760px;box-shadow:0 16px 44px -18px rgba(6,36,58,.7)}
.pl-hero .live-cell{flex:1;padding:16px 22px;border-right:1px solid rgba(255,255,255,.18);display:flex;align-items:center;gap:13px}
.pl-hero .live-cell:last-child{border-right:0}
.pl-hero .live-ico{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-size:19px;flex:none;background:rgba(255,255,255,.2)}
.pl-hero .live-k{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.82)}
.pl-hero .live-v{font-family:var(--serif);font-size:26px;font-weight:600;line-height:1;margin-top:2px;font-variation-settings:"opsz" 144;color:#fff;text-shadow:0 1px 10px rgba(6,36,58,.35)}
.pl-hero .live-v small{font-size:14px;font-weight:500}
@media(max-width:680px){.pl-hero .live-bar{display:none}}
.pl-hero .scroll-cue{position:absolute;right:34px;bottom:30px;left:auto;transform:none;z-index:12;display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,.85);font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;animation:pl-bob 2s ease-in-out infinite}
@keyframes pl-bob{0%,100%{transform:translateY(0)}50%{transform:translateY(7px)}}
@media(max-width:980px){.pl-hero .scroll-cue{display:none}}
@media(max-width:680px){.pl-hero .scroll-cue{display:none}}

/* ----- FILTER BAR ----- */
.pl .filters{position:sticky;top:0;z-index:25;background:rgba(245,250,254,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--line-soft);padding:16px 0}
.pl .filters-inner{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.pl .chip{padding:9px 17px;border-radius:999px;border:1px solid var(--line);font-size:13px;font-weight:600;color:var(--ink-soft);background:#fff;transition:all .2s;white-space:nowrap}
.pl .chip.active{background:var(--turq);color:#fff;border-color:var(--turq)}
.pl .chip:hover:not(.active){border-color:var(--corail);color:var(--corail)}
.pl .filters-count{margin-left:auto;font-size:13px;color:var(--ink-mute);font-weight:500}
.pl .filters-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.pl .filters-right .filters-count{margin-left:0}
.pl .ville-select{border:1px solid var(--line);border-radius:999px;padding:9px 16px;font-size:13px;font-weight:600;color:var(--ink-soft);background:#fff;cursor:pointer;transition:border-color .2s}
.pl .ville-select:hover{border-color:var(--corail)}
@media(max-width:560px){.pl .filters-right{width:100%;justify-content:space-between}}

/* ----- INTRO ----- */
.pl .intro{padding:80px 0 30px;text-align:center}
.pl .intro .dash-title{justify-content:center}
.pl .intro h2{font-family:var(--serif);font-size:clamp(32px,4.5vw,52px);font-weight:600;line-height:1.05;letter-spacing:-.02em;margin:14px 0 0;font-variation-settings:"opsz" 144}
.pl .intro h2 em{font-style:italic;font-weight:500;color:var(--corail)}
.pl .intro p{max-width:54ch;margin:16px auto 0;color:var(--ink-soft);font-size:17px;line-height:1.6}

/* ----- BEACH GRID ----- */
.pl .grid-section{padding:40px 0 60px}
.pl .beach-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:24px;grid-auto-flow:dense}
.pl .beach{grid-column:span 4;position:relative;border-radius:18px;overflow:hidden;min-height:340px;display:flex;align-items:flex-end;color:#fff;box-shadow:var(--shadow-soft);cursor:pointer;transition:transform .4s cubic-bezier(.2,.8,.3,1),box-shadow .4s;
  opacity:0;transform:translateY(28px)}
.pl .beach.in{opacity:1;transform:none}
.pl .beach:hover{transform:translateY(-6px);box-shadow:var(--shadow-card)}
.pl .beach:hover .beach-bg{transform:scale(1.08)}
.pl .beach-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background:#0E2E45;transition:transform .9s cubic-bezier(.2,.8,.3,1)}
.pl .beach::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,36,58,0) 30%,rgba(6,36,58,.4) 60%,rgba(6,36,58,.9) 100%)}
.pl .beach-feat{grid-column:span 8;min-height:480px}
.pl .beach-tall{grid-column:span 4;min-height:480px}
@media(max-width:1024px){.pl .beach,.pl .beach-feat,.pl .beach-tall{grid-column:span 6;min-height:320px}}
@media(max-width:680px){.pl .beach-grid{gap:18px}.pl .beach,.pl .beach-feat,.pl .beach-tall{grid-column:span 12;min-height:300px}}
.pl .beach-body{position:relative;z-index:2;padding:24px 26px;width:100%}
/* lien étiré : toute la carte (image comprise) est cliquable */
.pl .beach-link{position:absolute;inset:0;z-index:5}
.pl .beach-badges{position:absolute;top:18px;left:18px;z-index:3;display:flex;gap:8px;flex-wrap:wrap}
.pl .badge{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;padding:6px 11px;border-radius:999px;background:rgba(255,255,255,.92);color:var(--nuit);backdrop-filter:blur(6px)}
.pl .badge.coup{background:var(--corail);color:#fff}
.pl .badge.flag{background:#2563EB;color:#fff;display:inline-flex;align-items:center;gap:5px}
.pl .beach-temp{position:absolute;top:16px;right:16px;z-index:3;width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.18);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.4);display:grid;place-items:center;text-align:center;line-height:1}
.pl .beach-temp b{font-family:var(--serif);font-size:18px;font-weight:600;display:block}
.pl .beach-temp span{font-family:var(--mono);font-size:7px;letter-spacing:.1em;opacity:.85;text-transform:uppercase}
.pl .beach-loc{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.85);display:flex;align-items:center;gap:6px}
.pl .beach-name{font-family:var(--serif);font-size:27px;font-weight:600;line-height:1.05;letter-spacing:-.01em;margin:6px 0 0;font-variation-settings:"opsz" 144}
.pl .beach-feat .beach-name{font-size:40px}
.pl .beach-name em{font-style:italic;font-weight:500}
.pl .beach-meta{margin-top:10px;display:flex;gap:14px;flex-wrap:wrap;font-size:12.5px;color:rgba(255,255,255,.9)}
.pl .beach-meta span{display:flex;align-items:center;gap:6px}
.pl .beach-go{position:absolute;right:22px;bottom:22px;z-index:3;width:42px;height:42px;border-radius:50%;background:#fff;color:var(--nuit);display:grid;place-items:center;font-size:18px;transform:translateX(8px);opacity:0;transition:all .35s}
.pl .beach:hover .beach-go{transform:none;opacity:1}
.pl #empty-msg{text-align:center;color:var(--ink-mute);padding:60px 0;font-size:15px}
.pl .load-more{display:inline-flex;align-items:center;gap:9px;padding:14px 28px;border-radius:999px;background:var(--nuit);color:#fff;font-weight:600;font-size:14px;cursor:pointer;box-shadow:var(--shadow-soft);transition:background .2s,transform .2s}
.pl .load-more:hover{background:var(--nuit-deep);transform:translateY(-2px)}

/* ----- TYPE PICKER ----- */
.pl .types{padding:70px 0;background:var(--cream-deep)}
.pl .types-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;margin-top:40px}
@media(max-width:900px){.pl .types-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.pl .types-grid{grid-template-columns:repeat(2,1fr)}}
.pl .type-card{background:#fff;border-radius:16px;padding:26px 18px;text-align:center;box-shadow:var(--shadow-soft);transition:transform .3s,box-shadow .3s;border:1px solid var(--line-soft);cursor:pointer}
.pl .type-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-card)}
.pl .type-emoji{font-size:34px;line-height:1}
.pl .type-name{font-family:var(--serif);font-size:17px;font-weight:600;margin-top:12px;letter-spacing:-.01em}
.pl .type-count{font-family:var(--mono);font-size:11px;color:var(--ink-mute);margin-top:4px;letter-spacing:.06em}

/* ----- CTA newsletter ----- */
.pl .cta{position:relative;padding:120px 0;color:#fff;overflow:hidden;text-align:center}
.pl .cta-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.62)}
.pl .cta-inner{position:relative;z-index:2;max-width:640px;margin:0 auto}
.pl .cta .dash-title{justify-content:center;color:#fff}
.pl .cta h2{font-family:var(--serif);font-size:clamp(34px,5vw,60px);font-weight:600;line-height:1.05;letter-spacing:-.02em;margin:14px 0 0;font-variation-settings:"opsz" 144}
.pl .cta h2 em{font-style:italic;font-weight:500;color:var(--olive)}
.pl .cta p{margin:16px auto 0;font-size:17px;color:rgba(255,255,255,.9);max-width:46ch}
.pl .cta-form{display:flex;gap:8px;margin:30px auto 0;max-width:480px;background:rgba(255,255,255,.95);border-radius:999px;padding:6px}
.pl .cta-form input{flex:1;border:0;background:transparent;padding:13px 20px;outline:none;font-size:15px;color:var(--ink)}
.pl .cta-form button{padding:13px 24px;border-radius:999px;background:var(--corail);color:#fff;font-weight:600;font-size:14px}
.pl .cta-form button:hover{background:#e25f30}

/* ============================================================
   FICHE  (.pf)
   ============================================================ */
.pf .wrap{max-width:1240px}

/* ----- HERO ----- */
.pf-hero{position:relative;height:88vh;min-height:600px;max-height:820px;overflow:hidden;color:#fff;background:#06243a}
.pf-hero .hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 50%;
  animation:pf-kb 24s ease-in-out infinite alternate;transform-origin:center}
@keyframes pf-kb{0%{transform:scale(1.05)}100%{transform:scale(1.16)}}
.pf-hero .hero-shimmer{position:absolute;left:0;right:0;bottom:0;height:38%;pointer-events:none;opacity:.45;mix-blend-mode:screen;
  background:repeating-linear-gradient(95deg, rgba(255,255,255,0) 0 38px, rgba(255,255,255,.12) 40px 42px, rgba(255,255,255,0) 44px 80px);animation:pf-sh 9s linear infinite}
@keyframes pf-sh{to{transform:translateX(-80px)}}
.pf-hero .hero-grad{position:absolute;inset:0;background:linear-gradient(180deg, rgba(6,36,58,.5) 0%, rgba(6,36,58,0) 28%, rgba(6,36,58,0) 45%, rgba(6,36,58,.85) 100%)}
.pf-hero .hero-content{position:relative;z-index:10;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding-bottom:130px}
.pf-hero .hero-back{position:absolute;top:104px;left:0;font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.8);display:inline-flex;align-items:center;gap:8px;opacity:0;animation:pf-rise .7s .1s forwards}
.pf-hero .hero-back:hover{color:#fff}
.pf-hero .hero-badges{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:18px;opacity:0;animation:pf-rise .8s .2s forwards}
.pf-hero .hb{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;padding:7px 13px;border-radius:999px;background:rgba(255,255,255,.18);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.3)}
.pf-hero .hb.coup{background:var(--corail);border-color:transparent}
.pf-hero .hb.flag{background:#2563EB;border-color:transparent}
.pf-hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(46px,8vw,100px);line-height:.92;letter-spacing:-.03em;margin:0;text-shadow:0 4px 40px rgba(6,36,58,.4);font-variation-settings:"opsz" 144;opacity:0;animation:pf-rise .9s .3s forwards}
.pf-hero h1 em{font-style:italic;font-weight:500;color:var(--olive)}
.pf-hero .hero-loc{margin-top:16px;font-size:18px;color:rgba(255,255,255,.9);display:flex;align-items:center;gap:9px;opacity:0;animation:pf-rise .8s .45s forwards}
@keyframes pf-rise{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}

/* ----- LIVE CONDITIONS (overlapping card) ----- */
.pf .conditions{position:relative;z-index:20;margin-top:-90px}
.pf .cond-card{background:#fff;border-radius:22px;box-shadow:var(--shadow-card);padding:8px;display:grid;grid-template-columns:repeat(5,1fr)}
@media(max-width:820px){.pf .cond-card{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.pf .cond-card{grid-template-columns:1fr}}
.pf .cond-cell{padding:22px 24px;border-right:1px solid var(--line-soft);display:flex;align-items:center;gap:15px}
.pf .cond-cell:last-child{border-right:0}
@media(max-width:820px){.pf .cond-cell:nth-child(2n){border-right:0}.pf .cond-cell{border-bottom:1px solid var(--line-soft)}}
.pf .cond-ico{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;font-size:23px;flex:none;background:var(--cream-deep)}
.pf .cond-ico.warm{background:#FFF3DD}
.pf .cond-ico.sea{background:#E0F3FB}
.pf .cond-k{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute)}
.pf .cond-v{font-family:var(--serif);font-size:30px;font-weight:600;line-height:1;margin-top:4px;font-variation-settings:"opsz" 144}
.pf .cond-v small{font-size:15px;font-weight:500;color:var(--ink-mute)}
.pf .cond-update{text-align:center;font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--ink-mute);margin-top:14px;text-transform:uppercase}
.pf .cond-update .live{display:inline-block;width:7px;height:7px;background:var(--bon,#1F9D6B);border-radius:50%;margin-right:6px;animation:pf-pulse 2s infinite}
@keyframes pf-pulse{0%,100%{opacity:.4}50%{opacity:1}}

/* ----- BODY LAYOUT ----- */
.pf .content{padding:70px 0 90px}
.pf .layout{display:grid;grid-template-columns:1fr 380px;gap:56px;align-items:start}
@media(max-width:980px){.pf .layout{grid-template-columns:1fr}}
.pf .lead{font-family:var(--serif);font-size:27px;line-height:1.4;font-weight:500;letter-spacing:-.01em;color:var(--ink);font-variation-settings:"opsz" 96}
.pf .lead em{font-style:italic;color:var(--corail)}
.pf .prose{margin-top:22px;font-size:16.5px;line-height:1.75;color:var(--ink-soft)}
.pf .prose p{margin:0 0 16px}
.pf .block-title{font-family:var(--serif);font-size:26px;font-weight:600;letter-spacing:-.015em;margin:0;font-variation-settings:"opsz" 144}
.pf .section-mt{margin-top:54px}

/* highlights */
.pf .highlights{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:24px}
@media(max-width:560px){.pf .highlights{grid-template-columns:1fr}}
.pf .hl{background:#fff;border:1px solid var(--line-soft);border-radius:14px;padding:18px 20px;display:flex;gap:14px;align-items:flex-start;box-shadow:var(--shadow-soft)}
.pf .hl-ico{font-size:24px;flex:none}
.pf .hl b{display:block;font-family:var(--serif);font-size:16px;font-weight:600}
.pf .hl span{font-size:13.5px;color:var(--ink-mute)}

/* équipements pills */
.pf .equip{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.pf .eq-pill{background:#fff;border:1px solid var(--line-soft);border-radius:999px;padding:9px 16px;font-size:13.5px;font-weight:500;color:var(--ink-soft);box-shadow:var(--shadow-soft)}

/* gallery */
.pf .gallery{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:170px 170px;gap:12px;margin-top:24px}
.pf .gallery a{border-radius:14px;overflow:hidden;position:relative;background:#0E2E45}
.pf .gallery a:first-child{grid-row:span 2}
.pf .gallery img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.pf .gallery a:hover img{transform:scale(1.06)}
.pf .gallery .more{position:absolute;inset:0;background:rgba(14,46,69,.55);display:grid;place-items:center;color:#fff;font-family:var(--serif);font-size:22px;font-weight:600}
@media(max-width:560px){.pf .gallery{grid-template-columns:1fr 1fr;grid-template-rows:130px 130px}.pf .gallery a:first-child{grid-row:span 1;grid-column:span 2}}

/* access steps */
.pf .steps{margin-top:24px;display:flex;flex-direction:column;gap:0}
.pf .step{display:grid;grid-template-columns:auto 1fr;gap:18px;padding:18px 0;border-bottom:1px solid var(--line-soft);align-items:start}
.pf .step:last-child{border-bottom:0}
.pf .step-n{width:34px;height:34px;border-radius:50%;background:var(--turq);color:#fff;display:grid;place-items:center;font-family:var(--mono);font-weight:600;font-size:14px;flex:none}
.pf .step b{font-family:var(--serif);font-size:17px;font-weight:600}
.pf .step p{margin:4px 0 0;font-size:14.5px;color:var(--ink-soft)}

/* tip / warn box */
.pf .tip{margin-top:30px;background:linear-gradient(120deg,#FFF7E6,#FFF0D6);border:1px solid #F4D99A;border-radius:16px;padding:24px 26px;display:flex;gap:16px}
.pf .tip-ico{font-size:30px;flex:none}
.pf .tip b{font-family:var(--serif);font-size:18px;font-weight:600;color:#9A6B12}
.pf .tip p{margin:6px 0 0;font-size:14.5px;color:#7C5A1A;line-height:1.6}
.pf .tip.warn{background:linear-gradient(120deg,#FFF1E9,#FFE6D8);border-color:#F4B48F}
.pf .tip.warn b{color:#B4480F}
.pf .tip.warn p{color:#8A4419}

/* ----- SIDEBAR ----- */
.pf .sidebar{position:sticky;top:24px;display:flex;flex-direction:column;gap:20px}
.pf .card{background:#fff;border-radius:18px;box-shadow:var(--shadow-soft);border:1px solid var(--line-soft);overflow:hidden}
.pf .card-pad{padding:24px 26px}
.pf .card h3{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute);margin:0 0 16px;font-weight:600}
.pf .infos{display:flex;flex-direction:column}
.pf .info-row{display:flex;justify-content:space-between;gap:14px;padding:11px 0;border-bottom:1px solid var(--line-soft);font-size:14px}
.pf .info-row:last-child{border-bottom:0}
.pf .info-row dt{color:var(--ink-mute)}
.pf .info-row dd{margin:0;font-weight:600;text-align:right}
.pf .water-quality{text-align:center;padding:26px}
.pf .wq-badge{display:inline-block;font-family:var(--serif);font-size:20px;font-weight:600;padding:10px 22px;border-radius:999px}
.pf .wq-badge.exc{background:rgba(31,157,107,.12);color:#1F9D6B}
.pf .wq-badge.bon{background:rgba(37,99,235,.10);color:#2563EB}
.pf .wq-badge.suf{background:rgba(217,119,6,.12);color:#B45309}
.pf .wq-badge.ins{background:rgba(220,38,38,.10);color:#DC2626}
.pf .wq-sub{font-size:12px;color:var(--ink-mute);margin-top:10px}
.pf #plage-map{height:200px;width:100%;background:linear-gradient(135deg,#cfe8f5,#a8d8ee)}
.pf .btn-map{display:block;text-align:center;padding:13px;font-weight:600;font-size:14px;border-radius:12px}
.pf .btn-map.g{background:var(--turq);color:#fff;margin:14px 16px 0}
.pf .btn-map.g:hover{background:var(--turq-deep)}
.pf .btn-map.w{background:#33CCFF;color:#fff;margin:8px 16px 16px}
.pf .btn-map.w:hover{background:#28b8e8}
.pf .all-beaches{display:block;text-align:center;background:var(--nuit);color:#fff;padding:15px;border-radius:14px;font-weight:600;font-size:14px}
.pf .all-beaches:hover{background:var(--nuit-deep)}

/* ----- NEARBY ----- */
.pf .nearby{background:var(--cream-deep);padding:80px 0}
.pf .nearby-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px}
@media(max-width:860px){.pf .nearby-grid{grid-template-columns:1fr}}
.pf .nb{position:relative;border-radius:16px;overflow:hidden;min-height:260px;display:flex;align-items:flex-end;color:#fff;box-shadow:var(--shadow-soft);transition:transform .35s}
.pf .nb:hover{transform:translateY(-5px)}
.pf .nb:hover .nb-bg{transform:scale(1.07)}
.pf .nb-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s}
.pf .nb::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(6,36,58,.85))}
.pf .nb-body{position:relative;z-index:2;padding:20px 22px}
.pf .nb-loc{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.8)}
.pf .nb-name{font-family:var(--serif);font-size:22px;font-weight:600;margin-top:4px;font-variation-settings:"opsz" 144}

/* Crédits photos (CC BY / BY-SA) — discret, sous la galerie */
.pf .photo-credits{font-size:12px;line-height:1.5;color:var(--ink-mute);margin:14px 0 0;font-style:italic}
.pf .photo-credits a{color:var(--turq-deep);text-decoration:underline;text-underline-offset:2px}
.pf .photo-credits a:hover{color:var(--corail)}

@media(prefers-reduced-motion:reduce){
  .pl-hero .hero-img,.pf-hero .hero-img,.pl-hero .hero-sun,.pl-hero .hero-shimmer,.pf-hero .hero-shimmer,.pl-hero .orb,.pl-hero .scroll-cue{animation:none!important}
  .pl-hero h1 .l,.pl-hero .hero-kicker,.pl-hero .hero-sub,.pl-hero .hero-actions,.pl-hero .live-bar,
  .pf-hero .hero-back,.pf-hero .hero-badges,.pf-hero h1,.pf-hero .hero-loc{animation:none!important;opacity:1!important;transform:none!important}
  .pl .beach{opacity:1!important;transform:none!important}
}
