/*
Theme Name: FC8 Association
Theme URI: https://blog.firstclass8.fr
Author: Association Nationale de Classe First Class 8
Description: Thème officiel de l'Association Nationale de Classe First Class 8.
Version: 1.0.0
License: GNU General Public License v2 or later
Text Domain: fc8
*/

/* ── VARIABLES ── */
:root {
  --blue:    #002f6c;
  --blue2:   #0051a8;
  --blue-lt: #e8eef7;
  --red:     #c8001b;
  --red-lt:  #fceced;
  --white:   #ffffff;
  --gray-bg: #f4f5f7;
  --gray-1:  #e8e9ec;
  --gray-2:  #c4c6cc;
  --gray-3:  #8a8c94;
  --ink:     #1a1c22;
  --ink-mid: #3a3d48;
  --ink-lt:  #6b6e7a;
  --border:  #dddfe5;
  --radius:  6px;
  --sh:      0 2px 8px rgba(0,47,108,.07);
  --sh-md:   0 4px 20px rgba(0,47,108,.11);
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;font-size:15px;}
body{font-family:'Source Sans 3',sans-serif;background:var(--gray-bg);color:var(--ink);line-height:1.6;}
a{color:var(--blue2);text-decoration:none;}
a:hover{text-decoration:underline;}
img{max-width:100%;display:block;}

/* ── TOP BAR ── */
.topbar{background:var(--blue);color:rgba(255,255,255,.75);font-size:.8rem;padding:.35rem 0;}
.topbar-inner{max-width:1180px;margin:0 auto;padding:0 1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;}
.topbar a{color:rgba(255,255,255,.75);font-size:.8rem;}
.topbar a:hover{color:#fff;text-decoration:none;}
.topbar-links{display:flex;gap:1.5rem;align-items:center;}
.btn-topbar{background:var(--red);color:#fff !important;padding:.25rem .8rem;border-radius:3px;font-weight:600;letter-spacing:.03em;transition:background .2s;}
.btn-topbar:hover{background:#a50016;text-decoration:none !important;}

/* ── HEADER ── */
header{background:var(--white);border-bottom:3px solid var(--blue);box-shadow:var(--sh);position:sticky;top:0;z-index:100;}
.header-inner{max-width:1180px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;gap:2rem;}
.logo-wrap{display:flex;align-items:center;gap:.9rem;padding:.8rem 0;text-decoration:none !important;flex-shrink:0;}
.logo-wrap:hover{text-decoration:none;}
.logo-txt .l1{font-family:'Source Serif 4',serif;font-weight:700;font-size:1.25rem;color:var(--blue);line-height:1.1;display:block;}
.logo-txt .l2{font-size:.65rem;color:var(--ink-lt);letter-spacing:.15em;text-transform:uppercase;display:block;}

/* Main nav */
.main-nav{display:flex;align-items:stretch;gap:0;}
.btn-adhesion-nav{flex:1;align-self:stretch;display:flex;align-items:center;justify-content:center;background:var(--red);color:#fff !important;font-weight:700;font-size:.88rem;letter-spacing:.03em;text-decoration:none !important;transition:background .2s;white-space:nowrap;padding:0 1.5rem;}
.btn-adhesion-nav:hover{background:#a50016;text-decoration:none !important;}
.nav-item{position:relative;}
.nav-link{display:flex;align-items:center;gap:.25rem;padding:.8rem 1rem;font-size:.85rem;font-weight:600;color:var(--ink-mid);white-space:nowrap;border-bottom:3px solid transparent;margin-bottom:-3px;transition:color .2s,border-color .2s;cursor:pointer;}
.nav-link:hover,.nav-link.active{color:var(--blue);border-bottom-color:var(--blue);text-decoration:none;}
.nav-link svg{width:10px;height:10px;flex-shrink:0;opacity:.5;}
.dropdown{position:absolute;top:100%;left:0;min-width:200px;background:var(--white);border:1px solid var(--border);border-top:3px solid var(--blue);box-shadow:var(--sh-md);display:none;z-index:200;}
.nav-item:hover .dropdown{display:block;}
.dropdown a{display:block;padding:.6rem 1.1rem;font-size:.85rem;color:var(--ink-mid);border-bottom:1px solid var(--gray-1);transition:background .15s;}
.dropdown a:hover{background:var(--blue-lt);color:var(--blue);text-decoration:none;}
.dropdown a:last-child{border-bottom:none;}

/* ── HERO ── */
.hero{background:var(--blue);color:#fff;position:relative;overflow:hidden;}
.hero::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(45deg,rgba(255,255,255,.015) 0,rgba(255,255,255,.015) 1px,transparent 1px,transparent 40px);}
.hero-inner{max-width:1180px;margin:0 auto;padding:3.5rem 1.5rem 3rem;display:grid;grid-template-columns:1fr 420px;gap:3rem;align-items:center;position:relative;z-index:1;}
.hero-tag{display:inline-block;background:var(--red);color:#fff;font-size:.7rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;padding:.25rem .75rem;border-radius:2px;margin-bottom:1rem;}
.hero h1{font-family:'Source Serif 4',serif;font-size:2.6rem;font-weight:700;line-height:1.1;margin-bottom:1rem;}
.hero h1 em{font-style:italic;color:rgba(255,255,255,.7);}
.hero-desc{font-size:1.05rem;color:rgba(255,255,255,.82);line-height:1.7;margin-bottom:2rem;max-width:480px;}
.hero-actions{display:flex;gap:.8rem;flex-wrap:wrap;}
.btn-white{background:#fff;color:var(--blue);padding:.7rem 1.6rem;font-weight:700;font-size:.88rem;border-radius:var(--radius);transition:all .2s;}
.btn-white:hover{background:var(--blue-lt);text-decoration:none;}
.btn-outline-w{background:transparent;color:#fff;padding:.7rem 1.6rem;font-weight:700;font-size:.88rem;border-radius:var(--radius);border:2px solid rgba(255,255,255,.45);transition:all .2s;}
.btn-outline-w:hover{border-color:#fff;text-decoration:none;}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);overflow:hidden;}
.hstat{padding:1.2rem 1rem;text-align:center;background:rgba(255,255,255,.05);}
.hstat-val{font-family:'Source Serif 4',serif;font-weight:700;font-size:2rem;color:#fff;line-height:1;}
.hstat-lab{font-size:.7rem;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.1em;margin-top:.3rem;}
.triband{height:4px;display:flex;}
.triband div{flex:1;}
.triband div:nth-child(1){background:var(--blue);}
.triband div:nth-child(2){background:#fff;}
.triband div:nth-child(3){background:var(--red);}

/* ── LAYOUT ── */
.page-wrap{max-width:1180px;margin:0 auto;padding:2.5rem 1.5rem;}
.two-col{display:grid;grid-template-columns:1fr 300px;gap:2rem;align-items:start;}
.section-title{font-family:'Source Serif 4',serif;font-size:1.55rem;font-weight:700;color:var(--blue);margin-bottom:1.2rem;padding-bottom:.7rem;border-bottom:2px solid var(--blue-lt);}
.section-title span{font-size:.75rem;font-weight:400;color:var(--ink-lt);font-family:'Source Sans 3',sans-serif;letter-spacing:.1em;text-transform:uppercase;margin-left:.8rem;}

/* ── SECTION HEADER BANNER ── */
.section-banner{background:var(--white);border-bottom:1px solid var(--border);padding:1.2rem 0;}
.section-banner-inner{max-width:1180px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;gap:.8rem;}
.section-banner h2{font-family:'Source Serif 4',serif;font-size:1.4rem;font-weight:700;color:var(--blue);}
.section-banner p{font-size:.88rem;color:var(--ink-lt);}
.breadcrumb{font-size:.78rem;color:var(--ink-lt);}
.breadcrumb a{color:var(--blue2);}

/* ── NEWS CARDS ── */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;}
.news-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--sh);transition:box-shadow .2s,transform .2s;}
.news-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px);}
.news-img{height:150px;background:var(--blue-lt);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.news-img img{width:100%;height:100%;object-fit:cover;}
.news-img svg{opacity:.2;}
.news-body{padding:1rem;}
.news-cat{display:inline-block;font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.15rem .5rem;border-radius:2px;margin-bottom:.5rem;}
.cat-actu{background:var(--blue-lt);color:var(--blue);}
.cat-result{background:#e8f5e9;color:#1b5e20;}
.cat-course{background:var(--red-lt);color:var(--red);}
.cat-classe{background:#fff3e0;color:#e65100;}
.news-date{font-size:.72rem;color:var(--ink-lt);margin-bottom:.3rem;}
.news-title{font-weight:700;font-size:.95rem;color:var(--ink);line-height:1.35;margin-bottom:.5rem;}
.news-title a{color:var(--ink);}
.news-title a:hover{color:var(--blue);text-decoration:none;}
.news-excerpt{font-size:.82rem;color:var(--ink-lt);line-height:1.5;}
.news-more{display:inline-block;margin-top:.7rem;font-size:.8rem;font-weight:600;color:var(--blue2);}
.news-more:hover{text-decoration:underline;}

/* ── ARTICLE CONTENT ── */
.article-featured-img{width:100%;max-height:380px;object-fit:cover;border-radius:var(--radius);margin-bottom:1.5rem;}
.article-meta{display:flex;align-items:center;gap:1rem;margin-bottom:1.2rem;flex-wrap:wrap;}
.article-content{font-size:.95rem;color:var(--ink-mid);line-height:1.8;}
.article-content h2,.article-content h3{font-family:'Source Serif 4',serif;color:var(--blue);margin:1.5rem 0 .6rem;}
.article-content p{margin-bottom:1rem;}
.article-content ul,.article-content ol{margin:.5rem 0 1rem 1.5rem;}
.article-content img{border-radius:var(--radius);margin:1rem 0;}
.article-content a{color:var(--blue2);}
.article-nav{display:flex;justify-content:space-between;gap:1rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border);}
.article-nav a{font-size:.85rem;font-weight:600;color:var(--blue2);}
.article-nav .nav-prev::before{content:'← ';}
.article-nav .nav-next::after{content:' →';}

/* ── CALENDAR ── */
.cal-list{display:flex;flex-direction:column;gap:.8rem;}
.cal-item{background:var(--white);border:1px solid var(--border);border-left:4px solid var(--blue);border-radius:var(--radius);padding:1rem 1.2rem;display:grid;grid-template-columns:70px 1fr auto;gap:1rem;align-items:center;box-shadow:var(--sh);transition:border-left-color .2s;}
.cal-item:hover{border-left-color:var(--red);}
.cal-date{text-align:center;}
.cal-day{font-family:'Source Serif 4',serif;font-size:1.9rem;font-weight:700;color:var(--blue);line-height:1;}
.cal-mon{font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-lt);font-weight:600;}
.cal-name{font-weight:700;font-size:.95rem;color:var(--ink);margin-bottom:.2rem;}
.cal-detail{font-size:.8rem;color:var(--ink-lt);}
.cal-badge{padding:.2rem .65rem;border-radius:2px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;white-space:nowrap;}
.cb-nat{background:var(--blue);color:#fff;}
.cb-reg{background:var(--blue-lt);color:var(--blue);}
.cb-gp{background:var(--red-lt);color:var(--red);}
.cb-form{background:#e8f5e9;color:#1b5e20;}

/* ── SIDEBAR ── */
.sidebar-block{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:1.5rem;box-shadow:var(--sh);}
.sb-head{background:var(--blue);color:#fff;padding:.7rem 1rem;font-weight:700;font-size:.85rem;letter-spacing:.05em;text-transform:uppercase;}
.sb-body{padding:1rem;}
.sb-body p{font-size:.85rem;color:var(--ink-mid);line-height:1.6;margin-bottom:.8rem;}
.sb-body p:last-child{margin-bottom:0;}
.sb-link-list{list-style:none;}
.sb-link-list li{border-bottom:1px solid var(--gray-1);}
.sb-link-list li:last-child{border-bottom:none;}
.sb-link-list a{display:flex;align-items:center;gap:.6rem;padding:.55rem .3rem;font-size:.85rem;color:var(--ink-mid);transition:color .15s;}
.sb-link-list a::before{content:'›';color:var(--blue);font-size:1.1rem;line-height:1;}
.sb-link-list a:hover{color:var(--blue);text-decoration:none;}
.btn-full{display:block;width:auto;text-align:center;padding:.7rem;background:var(--red);color:#fff;font-weight:700;font-size:.88rem;border-radius:var(--radius);transition:background .2s;margin-top:.8rem;}
.btn-full:hover{background:#a50016;text-decoration:none;}
.btn-full-blue{background:var(--blue);}
.btn-full-blue:hover{background:#001d45;}

/* ── LE BATEAU (présentation) ── */
.boat-presentation{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:center;}
.boat-svg-panel{background:var(--blue-lt);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem;}
.specs-mini{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:4px;overflow:hidden;width:100%;}
.sm-cell{background:var(--white);padding:.7rem .8rem;}
.sm-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-lt);font-weight:600;}
.sm-val{font-family:'Source Serif 4',serif;font-size:1.3rem;font-weight:700;color:var(--blue);line-height:1.1;}
.sm-unit{font-size:.72rem;color:var(--ink-lt);font-family:'Source Sans 3',sans-serif;font-weight:400;}
.boat-text h3{font-family:'Source Serif 4',serif;font-size:1.4rem;font-weight:700;color:var(--blue);margin-bottom:.5rem;}
.boat-text .boat-subtitle{font-size:.78rem;text-transform:uppercase;letter-spacing:.15em;color:var(--ink-lt);margin-bottom:1.2rem;font-weight:600;}
.boat-text p{font-size:.9rem;color:var(--ink-mid);line-height:1.7;margin-bottom:1rem;}
.more-link{display:inline-flex;align-items:center;gap:.4rem;font-weight:700;font-size:.85rem;color:var(--blue2);}

/* ── JAUGE ── */
.jauge-box{background:var(--blue);color:#fff;border-radius:var(--radius);padding:2rem;display:grid;grid-template-columns:auto 1fr;gap:2rem;align-items:start;}
.jauge-num{font-family:'Source Serif 4',serif;font-size:5rem;font-weight:700;line-height:1;color:rgba(255,255,255,.15);writing-mode:vertical-lr;text-orientation:upright;letter-spacing:-.2em;}
.jauge-content h3{font-family:'Source Serif 4',serif;font-size:1.3rem;font-weight:700;margin-bottom:.3rem;}
.jauge-content .j-sub{font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:1.2rem;}
.jauge-rules{display:flex;flex-direction:column;gap:.7rem;}
.jrule{display:flex;gap:.8rem;align-items:flex-start;}
.jr-n{font-size:.68rem;font-weight:700;color:var(--red);background:rgba(255,255,255,.1);padding:.15rem .45rem;border-radius:2px;flex-shrink:0;margin-top:.1rem;}
.jr-t{font-size:.85rem;color:rgba(255,255,255,.82);line-height:1.55;}
.jr-t strong{color:#fff;}

/* ── STAFF ── */
.staff-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;}
.staff-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem 1rem;text-align:center;box-shadow:var(--sh);}
.staff-avatar{margin:0 auto .8rem;display:flex;align-items:center;justify-content:center;}
.staff-avatar img{width:105px;height:105px;border-radius:50%;border:5px solid var(--blue);}
.staff-name{font-weight:700;font-size:.9rem;color:var(--ink);margin-bottom:.2rem;}
.staff-role{font-size:.75rem;color:var(--ink-lt);}
.staff-bassin{display:inline-block;margin-top:.4rem;font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.15rem .5rem;border-radius:2px;}
.sb-atl{background:var(--blue-lt);color:var(--blue);}
.sb-med{background:var(--red-lt);color:var(--red);}
.sb-nat{background:#e8f5e9;color:#1b5e20;}

/* ── FOOTER ── */
footer{background:var(--ink);color:rgba(255,255,255,.65);padding:3rem 0 1.5rem;}
.footer-inner{max-width:1180px;margin:0 auto;padding:0 1.5rem;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:3rem;}
.footer-brand .fb-logo{font-family:'Source Serif 4',serif;font-size:1.4rem;font-weight:700;color:#fff;margin-bottom:.4rem;}
.footer-brand .fb-logo em{color:rgba(255,255,255,.45);font-style:italic;}
.footer-brand p{font-size:.82rem;color:rgba(255,255,255,.5);line-height:1.6;}
footer h5{font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:.8rem;}
footer a{display:block;font-size:.85rem;color:rgba(255,255,255,.55);margin-bottom:.35rem;transition:color .2s;}
footer a:hover{color:#fff;text-decoration:none;}
.footer-bottom{max-width:1180px;margin:2rem auto 0;padding:1.2rem 1.5rem 0;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;}
.footer-bottom p{font-size:.75rem;color:rgba(255,255,255,.3);}

/* ── MISC ── */
.page-section{padding:2.5rem 0;border-bottom:1px solid var(--border);}
.page-section:last-child{border-bottom:none;}
.bg-white-section{background:var(--white);padding:2.5rem 0;}
.view-all{display:inline-flex;align-items:center;gap:.4rem;font-size:.83rem;font-weight:700;color:var(--blue2);margin-top:1rem;}
.view-all::after{content:'→';}
.tag{display:inline-block;padding:.15rem .55rem;border-radius:2px;font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;}
.tag-bl{background:var(--blue-lt);color:var(--blue);}
.tag-rd{background:var(--red-lt);color:var(--red);}
.sep{height:1px;background:var(--border);margin:2rem 0;}

/* ── PAGINATION ── */
.posts-pagination{margin-top:2rem;display:flex;justify-content:center;gap:.5rem;}
.posts-pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;width:2.2rem;height:2.2rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.85rem;font-weight:600;color:var(--ink-mid);background:var(--white);transition:all .2s;}
.posts-pagination .page-numbers:hover{background:var(--blue-lt);color:var(--blue);border-color:var(--blue);text-decoration:none;}
.posts-pagination .page-numbers.current{background:var(--blue);color:#fff;border-color:var(--blue);}

/* ── HAMBURGER ── */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:.5rem;margin-left:auto;flex-shrink:0;}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:transform .25s,opacity .25s;}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle.open span:nth-child(2){opacity:0;}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.nav-mobile-adhesion{display:none;background:var(--red);color:#fff;font-weight:700;text-align:center;border-radius:var(--radius);}

/* ── RESPONSIVE : tablet (≤ 900px) ── */
@media(max-width:900px){
  .nav-toggle{display:flex;}
  .btn-adhesion-nav{display:none;}
  .main-nav{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--white);border-bottom:3px solid var(--blue);box-shadow:var(--sh-md);z-index:200;}
  .main-nav.open{display:flex;}
  .nav-item{border-bottom:1px solid var(--gray-1);}
  .nav-link{padding:.9rem 1.5rem;margin-bottom:0;border-bottom:none;}
  .nav-link:hover,.nav-link.active{border-bottom:none;border-left:3px solid var(--blue);padding-left:calc(1.5rem - 3px);color:var(--blue);}
  .nav-mobile-adhesion{display:block;}

  .hero-inner{grid-template-columns:1fr;gap:2rem;}
  .hero h1{font-size:2rem;}

  .two-col{grid-template-columns:1fr;}

  .boat-presentation{grid-template-columns:1fr;}

  .news-grid{grid-template-columns:repeat(2,1fr);}

  .staff-grid{grid-template-columns:repeat(3,1fr);}

  .footer-inner{grid-template-columns:1fr 1fr;gap:2rem;}
}

/* ── RESPONSIVE : mobile (≤ 600px) ── */
@media(max-width:600px){
  .topbar-links{display:none;}

  .hero h1{font-size:1.7rem;}
  .hero-inner{padding:2rem 1.5rem 1.5rem;}
  .hero-stats{grid-template-columns:repeat(2,1fr);}

  .cal-item{grid-template-columns:60px 1fr;}
  .cal-badge{grid-column:2;}

  .news-grid{grid-template-columns:1fr;}

  .staff-grid{grid-template-columns:repeat(2,1fr);}

  .jauge-box{grid-template-columns:1fr;}
  .jauge-num{display:none;}

  .footer-inner{grid-template-columns:1fr;}

  .doc-size{display:none;}
}
