/*
Theme Name: Bien Vivre Saint-Méen - Logo Colors
Theme URI: https://bienvivre-stmeen.fr
Author: Association Bien vivre à Saint-Méen-le-Grand
Description: Thème WordPress vitrine complet pour l'association Bien vivre à Saint-Méen-le-Grand et sa section Comité des fêtes, adapté aux couleurs du logo officiel.
Version: 3.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GPL v2 or later
Text Domain: bienvivre-stmeen
Tags: association, event, community, custom-logo, responsive, light
*/

:root{
  --navy:#16243d;
  --navy-2:#0c172b;
  --blue:#0877dc;
  --blue-soft:#edf6ff;
  --teal:#02bdb6;
  --teal-dark:#009b98;
  --teal-soft:#e9fbfa;
  --orange:#ff5a1f;
  --orange-2:#ff7a1a;
  --magenta:#d82958;
  --green:#4f9e24;
  --text:#172033;
  --muted:#61708a;
  --line:#e4ebf4;
  --soft:#f7fafc;
  --white:#ffffff;
  --radius:18px;
  --shadow:0 14px 34px rgba(22,36,61,.08);
  --shadow-soft:0 6px 18px rgba(22,36,61,.06);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,Arial,Helvetica,sans-serif;color:var(--text);background:#fff;line-height:1.5;font-size:16px}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.container{width:min(1220px,92%);margin:0 auto}

/* Header */
.site-header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50;box-shadow:0 3px 16px rgba(22,36,61,.04)}
.header-inner{min-height:92px;display:flex;align-items:center;justify-content:space-between;gap:28px}
.brand{display:flex;align-items:center;gap:16px;min-width:280px}
.brand img{width:84px;height:auto}
.brand-title{font-weight:900;color:var(--navy);font-size:1.42rem;line-height:1;letter-spacing:.02em;text-transform:uppercase}
.brand-title span{display:block;color:var(--teal);font-size:.86rem;margin-top:5px;letter-spacing:.035em}
.brand-subtitle{color:var(--orange);font-weight:800;font-size:.84rem;margin-top:2px}
.nav{display:flex;align-items:center;gap:30px;font-weight:800;font-size:.96rem;color:var(--navy)}
.nav a{position:relative;padding:34px 0;transition:.2s;color:var(--navy)}
.nav a:hover,.nav a.active,.current-menu-item>a{color:var(--blue)}
.nav a:after,.current-menu-item>a:after{content:"";position:absolute;left:0;right:0;bottom:24px;height:3px;border-radius:999px;background:transparent;transition:.2s}
.nav a:hover:after,.nav a.active:after,.current-menu-item>a:after{background:var(--orange)}
.mobile-menu-note{display:none;color:var(--muted);font-weight:700}

/* Decorative shapes */
.decor-left,.decor-right{position:absolute;pointer-events:none;z-index:1;opacity:.95}
.decor-left{left:-62px;top:0;width:180px;height:260px;border-left:18px solid var(--teal);border-bottom:18px solid var(--blue);border-radius:0 0 0 180px;transform:rotate(8deg)}
.decor-right{right:-85px;bottom:-76px;width:230px;height:230px;border-top:24px solid var(--teal);border-right:24px solid var(--blue);border-radius:0 190px 0 0;transform:rotate(12deg)}
.dot{position:absolute;border-radius:50%;z-index:2}.dot.orange{background:var(--orange)}.dot.blue{background:var(--blue)}.dot.teal{background:var(--teal)}.dot.magenta{background:var(--magenta)}

/* Hero */
.hero{position:relative;overflow:hidden;background:#fff;border-bottom:1px solid var(--line)}
.hero-grid{display:grid;grid-template-columns:.92fr 1.55fr;min-height:310px;align-items:center}
.hero-content{padding:34px 0 38px;position:relative;z-index:5}
.hero h1{font-size:clamp(2.15rem,4vw,4.25rem);line-height:1.02;margin:0 0 14px;color:var(--navy);font-weight:950;letter-spacing:-.035em}
.hero h1 span{color:var(--teal)}
.hero p{max-width:560px;margin:0 0 24px;color:#26344f;font-size:1.07rem;font-weight:600}
.hero-image{align-self:stretch;min-height:310px;background:linear-gradient(90deg,rgba(255,255,255,.8) 0%,rgba(255,255,255,.12) 17%,rgba(0,0,0,.04) 100%), url('https://images.unsplash.com/photo-1501386761578-eac5c94b800a?auto=format&fit=crop&w=1600&q=80') center/cover;border-radius:0;position:relative}
.hero-image:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.9),rgba(255,255,255,0) 25%)}
.btns{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 23px;border-radius:9px;border:2px solid transparent;font-weight:900;line-height:1;cursor:pointer;transition:.2s;box-shadow:var(--shadow-soft)}
.btn-blue{background:var(--blue);color:white}.btn-blue:hover{background:#0462b8;transform:translateY(-1px)}
.btn-orange{background:var(--orange);color:white}.btn-orange:hover{background:#e84910;transform:translateY(-1px)}
.btn-teal{background:var(--teal);color:white}.btn-teal:hover{background:var(--teal-dark);transform:translateY(-1px)}
.btn-outline{background:#fff;border-color:var(--teal);color:var(--teal-dark);box-shadow:none}.btn-outline:hover{background:var(--teal-soft)}

/* Sections */
.section{padding:18px 0;border-bottom:1px solid var(--line)}
.section.pad{padding:52px 0}.section.soft{background:var(--soft)}
.section-title{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:16px}
.section-title h2,.section h2{margin:0;color:var(--blue);font-size:1.55rem;letter-spacing:-.025em;font-weight:950}.section-title h2 .accent,.section h2 .accent{color:var(--teal)}
.section-title a{color:var(--blue);font-weight:900;font-size:.92rem}.section-title a:hover{color:var(--orange)}
.kicker{font-weight:950;color:var(--teal);text-transform:none;font-size:1rem;display:inline-flex;gap:6px;align-items:center}

.home-row-1{display:grid;grid-template-columns:1.02fr 1.65fr .95fr;gap:24px;align-items:stretch}
.home-row-2{display:grid;grid-template-columns:1.25fr 1fr;gap:24px;align-items:start}
.home-row-3{display:grid;grid-template-columns:.85fr 1.25fr .95fr;gap:24px;align-items:stretch}

.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-soft);overflow:hidden}
.card-body{padding:20px}.card h3{margin:0 0 7px;color:var(--blue);font-size:1.13rem;line-height:1.2}.card p{margin:0;color:#34415a}.muted{color:var(--muted)}

.mission-box{text-align:center;padding:4px 0}.mission-box p{font-weight:600;color:#25324a;margin:10px 0 16px}
.icon-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.icon-card{text-align:center;padding:20px 12px;border-radius:14px;box-shadow:none}.icon-card .icon{font-size:2.05rem;line-height:1;display:block;margin-bottom:8px}.icon-blue{color:var(--blue)}.icon-teal{color:var(--teal)}.icon-orange{color:var(--orange)}
.icon-card strong{font-size:.92rem;color:var(--navy)}

.events-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.event-card{box-shadow:none}.event-card img,.news-thumb{height:110px;width:100%;object-fit:cover}.event-card .card-body{padding:13px 14px}.meta{display:flex;flex-wrap:wrap;gap:10px;font-size:.87rem;color:#4d5c75;margin-top:5px}
.volunteer-box{background:linear-gradient(135deg,#f1fffe 0%,#e6fbf9 100%);border:1px solid #beece9;border-radius:var(--radius);padding:24px;position:relative;overflow:hidden}.volunteer-box h2{color:var(--teal-dark);font-size:1.6rem;margin-bottom:8px}.volunteer-box p{font-weight:600;color:#314056}.volunteer-box .heart{position:absolute;right:24px;top:16px;font-size:3.5rem;color:var(--orange);line-height:1;font-weight:100}.volunteer-box .btn{width:100%;margin-top:14px}
.news-inline{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.news-mini{display:grid;grid-template-columns:96px 1fr;gap:12px;align-items:start}.news-mini img{width:96px;height:76px;object-fit:cover;border-radius:10px}.news-mini h3{font-size:.96rem;margin-bottom:3px}.news-mini p{font-size:.88rem}.date{display:block;color:var(--orange);font-weight:900;font-size:.82rem;margin:1px 0 3px}
.partners{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}.partner-logo{min-height:76px;border:1px solid var(--line);border-radius:12px;background:#fff;display:grid;place-items:center;text-align:center;padding:9px;font-weight:950;color:var(--navy);line-height:1.05}.partner-logo small{display:block;font-weight:800;color:var(--teal);font-size:.75rem;margin-top:4px}.partner-logo:nth-child(3n){color:var(--orange)}.partner-logo:nth-child(4n){color:#8b36d9}.partner-logo:nth-child(5n){color:var(--green)}.partner-logo:nth-child(6n){color:var(--blue)}
.contact-list{list-style:none;margin:10px 0 0;padding:0}.contact-list li{margin:11px 0;color:#24334e;font-weight:600}.contact-list .ico{color:var(--blue);font-weight:950;margin-right:6px}
.form-row{display:grid;grid-template-columns:1fr 1fr .75fr;gap:12px}.field,select,textarea{width:100%;border:1px solid var(--line);border-radius:9px;background:#fff;padding:13px 14px;font:inherit;color:var(--text)}textarea{min-height:90px;margin-top:12px;resize:vertical}.form-submit{width:100%;margin-top:12px}
.info-box{background:linear-gradient(135deg,#f0fffd,#f8fffe);border:1px solid #cdf3ef;border-radius:var(--radius);padding:22px;position:relative;overflow:hidden}.info-box h3{color:var(--teal-dark);font-size:1.25rem}.info-box .big-heart{position:absolute;right:24px;top:30px;color:var(--teal);font-size:4rem;line-height:1;opacity:.55}.info-box p{max-width:82%}.info-box .btn{margin-top:12px;width:100%}

/* Page templates */
.page-hero{position:relative;overflow:hidden;min-height:260px;display:flex;align-items:center;background:linear-gradient(90deg,rgba(22,36,61,.72),rgba(22,36,61,.18)), url('https://images.unsplash.com/photo-1529156069898-49953e39b3ac?auto=format&fit=crop&w=1600&q=80') center/cover;color:#fff}.page-hero h1{font-size:clamp(2.1rem,4vw,3.6rem);margin:0 0 8px;font-weight:950}.page-hero p{font-size:1.15rem;max-width:620px}.page-hero .container{position:relative;z-index:2}.page-hero.comite{background:linear-gradient(90deg,rgba(22,36,61,.76),rgba(22,36,61,.12)), url('https://images.unsplash.com/photo-1492684223066-81342ee5ff30?auto=format&fit=crop&w=1600&q=80') center/cover}.page-hero.partners-hero{background:linear-gradient(90deg,rgba(22,36,61,.78),rgba(22,36,61,.16)), url('https://images.unsplash.com/photo-1517048676732-d65bc937f952?auto=format&fit=crop&w=1600&q=80') center/cover}
.page-grid-2{display:grid;grid-template-columns:1fr 1.45fr;gap:28px}.value-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:15px}.role-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.role{padding:18px;text-align:center}.avatar{width:74px;height:74px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--blue));margin:0 auto 12px}.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.stat{background:var(--blue-soft);padding:18px;border-radius:14px;text-align:center}.stat strong{font-size:2.2rem;color:var(--blue);display:block}
.action-list{display:grid;gap:12px}.action{display:grid;grid-template-columns:46px 1fr;gap:12px;align-items:start}.action .badge{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:var(--teal-soft);color:var(--teal-dark);font-weight:950}.volunteer-roles{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}.gallery-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}.gallery-strip img{height:88px;object-fit:cover;border-radius:12px;width:100%}
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.tier{padding:22px}.tier .price{font-size:2rem;font-weight:950;color:var(--navy);margin:6px 0}.tier ul{padding-left:18px}.tier li{margin:8px 0}.tier.gold{border-color:var(--orange);box-shadow:0 14px 28px rgba(255,90,31,.09)}.tier.platine{border-color:var(--blue);border-width:2px}.map-box{min-height:160px;border-radius:16px;background:linear-gradient(135deg,#eaf4ff,#fff 55%,#e9fbfa);position:relative;overflow:hidden}.map-pin{position:absolute;left:50%;top:48%;font-size:2.5rem;color:var(--blue)}

/* Footer */
.site-footer{background:#fff;border-top:1px solid var(--line);position:relative;overflow:hidden}.footer-top{padding:20px 0}.footer-grid{display:grid;grid-template-columns:1.25fr 1.1fr .8fr 1.1fr;gap:28px;align-items:center}.footer-brand{display:flex;align-items:center;gap:14px}.footer-brand img{width:78px}.footer-brand strong{font-size:1.35rem;color:var(--navy);font-weight:950}.footer-brand span{display:block;color:var(--teal);font-weight:900;font-size:.86rem}.footer h4{margin:0 0 10px;color:var(--blue)}.socials{display:flex;gap:12px}.socials a{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:var(--blue);color:#fff;font-weight:950}.socials a:nth-child(2){background:var(--magenta)}.socials a:nth-child(3){background:#fff;color:var(--blue);border:1px solid var(--blue)}.footer-script{font-size:1.2rem;color:var(--blue);font-weight:800}.footer-script .heart{color:var(--orange);font-size:2.3rem;margin-left:12px}.footer-bottom{border-top:1px solid var(--line);padding:12px 0;font-size:.86rem;color:#5d6a80;display:flex;justify-content:space-between;gap:18px}.footer-bottom a{margin-left:20px}.footer-bottom a:hover{color:var(--orange)}

@media(max-width:1050px){.header-inner{min-height:auto;padding:15px 0;align-items:flex-start}.nav{display:none}.mobile-menu-note{display:block}.hero-grid,.home-row-1,.home-row-2,.home-row-3,.page-grid-2,.footer-grid{grid-template-columns:1fr}.hero-image{min-height:250px;order:-1}.events-grid,.news-inline,.partners{grid-template-columns:repeat(2,1fr)}.value-grid,.role-grid,.volunteer-roles,.tiers{grid-template-columns:repeat(2,1fr)}.gallery-strip{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.brand img{width:64px}.brand-title{font-size:1.1rem}.hero h1{font-size:2rem}.icon-grid,.events-grid,.news-inline,.partners,.form-row,.value-grid,.role-grid,.stat-grid,.volunteer-roles,.tiers,.gallery-strip{grid-template-columns:1fr}.news-mini{grid-template-columns:84px 1fr}.footer-bottom{flex-direction:column}.section.pad{padding:34px 0}}


/* Version modifiable : contenu stocké dans les pages WordPress */
.entry-content{width:100%;}
.entry-content > *{margin-block-start:0;margin-block-end:0;}
.page-editable{padding:60px 0;}
.page-editable .container{max-width:1180px;margin:0 auto;padding:0 24px;}
.wp-block-post-title{display:none;}
