/*
Theme Name: SCMC Modern
Theme URI: https://scmc-natation.fr/
Author: SCMC
Description: Thème moderne, responsive et accessible pour SCMC (test2)
Version: 0.1.0
Text Domain: scmc-modern
*/

/* Dark is default; light is opt-in via .theme-light on <html> */
:root{
  /* dark theme */
  --brand:#004a8f;
  --brand-dark:#00396e;
  --bg:#071422;
  --panel:#0c1c2d;
  --text:#e6f0ff;
  --button-text: #ffffff;
  --muted:#9fb3c8;
  --accent:#00c9d2;
  --border:#1f2937;
}
.theme-light{
  --brand:#0b63c7;
  --brand-dark:#084e9c;
  --bg:#f8fafc;
  --panel:#ffffff;
  --text:#0b1220;
  --button-text: #ffffff;
  --muted:#5b708b;
  --accent:#0ea5e9;
  --border:#e5e7eb;
}
@media (prefers-color-scheme: light){
  :root:not(.theme-dark):not(.theme-light){
    /* if no explicit choice and system is light */
    --brand:#0b63c7;
    --brand-dark:#084e9c;
    --bg:#f8fafc;
    --panel:#ffffff;
    --text:#0b1220;
    --muted:#5b708b;
    --accent:#0ea5e9;
    --border:#e5e7eb;
  }
}

html{scroll-behavior:smooth}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;background:var(--bg);color:var(--text);line-height:1.6}
/* Smooth theme transitions */
*{transition: color .14s ease, background-color .14s ease}

/* links & buttons */
a{color:var(--accent)}
a:focus-visible, button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.button, .wp-block-button__link{display:inline-block;background:var(--brand);color:var(--button-text) !important;text-decoration:none;border:0;border-radius:10px;padding:10px 14px;cursor:pointer;transition:.15s background-color}
.button:hover, .wp-block-button__link:hover{background:var(--brand-dark)}
.button:focus-visible, .wp-block-button__link:focus-visible{outline:3px solid var(--accent);outline-offset:2px}

.container{max-width:1200px;margin:0 auto;padding:0 16px}

header.site-header{position:sticky;top:0;z-index:40;background:color-mix(in oklab, var(--panel) 90%, transparent);backdrop-filter:saturate(120%) blur(8px);border-bottom:1px solid var(--border)}
/* Offset sticky header when admin bar is visible */
body.admin-bar header.site-header{top:32px}
@media (max-width:782px){body.admin-bar header.site-header{top:46px}}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--text);text-decoration:none}
.brand .logo{width:40px;height:40px;border-radius:8px;object-fit:cover;box-shadow:0 2px 8px rgba(0,0,0,.25)}
.brand span{color:var(--text)}

/* Stronger rule to ensure header/menu text follows theme variables and override plugin styles */
header.site-header, header.site-header .header-inner, header.site-header .brand, header.site-header .brand span, header.site-header .menu-toggle, nav.primary a {
  color: var(--text) !important;
}

nav.primary{display:flex;gap:12px}
/* Hide mobile menu by default (desktop); it will be managed in the mobile MQ */
.mobile-menu{display:none}
.primary .menu:empty::before{content:'Aucun menu assigné';color:var(--muted);font-size:12px}
/* Desktop primary menu */
nav.primary .menu{list-style:none;margin:0;padding:0;display:flex;gap:8px;align-items:center}
/* Position all li as context for absolutely-positioned nested submenus */
nav.primary .menu li{position:relative}
nav.primary a{color:var(--text);text-decoration:none;padding:8px 10px;border-radius:8px;display:block}
nav.primary a:hover, nav.primary a:focus{outline:none;background:rgba(0,74,143,.18)}
/* Active menu state */
nav.primary .menu .current-menu-item > a,
nav.primary .menu .current-menu-ancestor > a{background:rgba(0,74,143,.28);color:var(--text)}
/* Dropdowns */
nav.primary .sub-menu{list-style:none;margin:0;padding:6px;position:absolute;left:0;top:100%;background:var(--panel);border:1px solid rgba(0,74,143,.35);border-radius:10px;min-width:220px;box-shadow:0 10px 30px rgba(0,0,0,.35);display:none;z-index:60}
/* Prevent overflow off the right edge on last items */
nav.primary .menu > li:last-child > .sub-menu{left:auto;right:0}
nav.primary .sub-menu > li:last-child > .sub-menu{left:auto;right:calc(100% - 1px)}
nav.primary .sub-menu li a{padding:8px 10px;border-radius:8px;white-space:nowrap}
nav.primary li:hover> .sub-menu, nav.primary li:focus-within> .sub-menu{display:block}
/* Also keep it open when hovering the submenu itself */
nav.primary li > .sub-menu:hover{display:block}
/* Nested submenu flush to the right, overlapping 1px to avoid hover gap */
nav.primary .sub-menu .sub-menu{left:calc(100% - 1px);top:0;margin-left:0;z-index:70}
nav.primary .menu > li.menu-item-has-children > a::after{content:' \25BE';font-size:.85em;color:var(--muted)}
nav.primary .sub-menu .menu-item-has-children > a::after{content:'\25B8';float:right;color:var(--muted)}

/* Hover bridges: keep dropdowns open while moving the mouse into nested submenus */
nav.primary .menu > li.menu-item-has-children:hover::after,
nav.primary .menu > li.menu-item-has-children:focus-within::after{
  content:"";position:absolute;top:0;right:-10px;width:10px;height:100%;
}
nav.primary .sub-menu > li.menu-item-has-children:hover::after,
nav.primary .sub-menu > li.menu-item-has-children:focus-within::after{
  content:"";position:absolute;top:0;right:-14px;width:14px;height:100%;
}

.menu-toggle{display:none;background:transparent;border:0;color:var(--text);font-size:26px}

@media (max-width: 900px){
  nav.primary{display:none}
  .menu-toggle{display:block}
  /* Overlay menu handled in mobile-menu.css */
  .mobile-menu{display:none}
  .mobile-menu .menu{list-style:none;margin:0;padding:0}
  .mobile-menu a{display:block;padding:12px;border-radius:6px;color:#e5e7eb;text-decoration:none}
  .mobile-menu a:hover{background:rgba(0,74,143,.18)}
  .mobile-menu .sub-menu{list-style:none;margin:4px 0 8px 10px;padding-left:12px;border-left:1px solid #1f2937}
}

/* Mobile: add breathing room between logo and screen edge */
@media (max-width: 767px) {
  /* Target common logo/header selectors used by the theme */
  .site-header .site-branding,
  .site-header .site-logo,
  .site-header .custom-logo-link,
  .site-header .brand,
  .site-branding,
  .site-logo,
  .brand,
  .custom-logo-link {
    padding-left: 12px; /* small left padding so logo is not flush to the edge */
  }

  /* Ensure logo image doesn't get unexpected inline shift */
  .site-header .site-branding img,
  .site-header .custom-logo-link img,
  .site-header .brand img,
  .site-branding img,
  .custom-logo-link img,
  .brand img {
    display: block;
    max-width: 100%;
    height: auto;
  }
}

/* Tablet: keep breathing room between logo and screen edge */
@media (min-width: 768px) and (max-width: 1024px) {
  .site-header .site-branding,
  .site-header .site-logo,
  .site-header .custom-logo-link,
  .site-header .brand,
  .site-branding,
  .site-logo,
  .brand,
  .custom-logo-link {
    padding-left: 12px; /* same small left padding on tablets */
  }
}

main{min-height:60vh}
.hero{padding:60px 0;background:radial-gradient(1250px 360px at 50% -40%, color-mix(in oklab, var(--accent) 36%, transparent 0%), transparent 60%)}
.theme-light .hero{background:radial-gradient(1250px 360px at 50% -40%, color-mix(in oklab, var(--accent) 28%, transparent 0%), transparent 60%)}
.hero h1{font-size:clamp(28px,4vw,48px);margin:0 0 12px}
.hero p{color:var(--muted);max-width:60ch;margin:0}

/* Stronger site background gradients for dark and light themes */
/* Layer gradients above the base --bg so panels and text still use the variables */
body{
  /* keep existing var as fallback */
  background:
    radial-gradient(1200px 600px at 8% 6%, color-mix(in oklab, var(--accent) 18%, transparent), transparent 40%),
    linear-gradient(180deg, color-mix(in oklab, var(--brand) 6%, transparent), transparent 55%),
    var(--bg);
  background-attachment: fixed;
  background-repeat: no-repeat;
}

/* Slightly softer but visible for light theme */
.theme-light body{
  background:
    radial-gradient(1200px 600px at 8% 6%, color-mix(in oklab, var(--accent) 12%, transparent), transparent 46%),
    linear-gradient(180deg, color-mix(in oklab, var(--brand) 4%, transparent), transparent 65%),
    var(--bg);
  background-attachment: fixed;
  background-repeat: no-repeat;
}

/* Front-page sections */
.quick-info{padding:24px 0}
.latest-posts{padding:24px 0}
.latest-posts h2{font-size:clamp(22px,2.5vw,28px)}

/* Infos pratiques: stacked on small screens, inline on large screens */
.infos-pratiques .items{display:flex;flex-direction:column;gap:14px}
.infos-pratiques .item{display:flex;gap:12px;align-items:flex-start;background:transparent;padding:6px 0}
.infos-pratiques .item .icon{font-size:22px;line-height:1.1}
.infos-pratiques .item strong{display:block;margin-bottom:4px}

@media (min-width:900px){
  .infos-pratiques .items{flex-direction:row;align-items:center;justify-content:space-between}
  .infos-pratiques .item{flex:1;min-width:0;padding:0}
  .infos-pratiques .item div{min-width:0}
}

.grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.card{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:16px}
.card h3{margin-top:0}
.card a{color:var(--accent)}
/* Links inside cards and plain links that previously forced white */
.card-link, .plain-link{color:var(--text);text-decoration:none}
.card-link:hover, .plain-link:hover{color:var(--accent)}

footer.site-footer{border-top:1px solid var(--border);margin-top:40px}
.footer-inner{padding:24px 0;color:var(--muted)}

/* Footer layout */
.footer-grid{display:grid;grid-template-columns:1fr auto 260px;gap:18px;align-items:start}
.footer-brand p{color:var(--text)}
.footer-contact h4,.footer-dev h4{margin:0;color:var(--text)}
.footer-link{color:var(--accent);text-decoration:none}
.footer-link:hover{color:var(--brand)}

.footer-dev{border:1px solid rgba(255,255,255,0.04);background:color-mix(in oklab,var(--panel) 88%, transparent);padding:12px;border-radius:8px}
.footer-dev p{margin:4px 0}

@media (max-width:900px){
  .footer-grid{grid-template-columns:1fr;gap:12px}
  .footer-dev{order:3}
}

/* Small circular badges for social links */
.footer-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;overflow:hidden;background:transparent}
.footer-icon svg{width:20px;height:20px;display:block;color:#fff}
.footer-icon.facebook{background:#1877F2}
.footer-icon.instagram{background:linear-gradient(45deg,#feda75 0,#d62976 50%,#515bd4 100%)}
.footer-icon.linkedin{background:#0A66C2}
.footer-icon.github{background:#111827}

/* screen-reader only */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Home contact card: fixed but responsive */
.home-contact .card{
  max-width:640px; /* upper bound on very wide screens */
  display:flex;gap:12px;padding:12px;
}
.home-contact .card strong{font-size:1rem}
.home-contact .card .plain-link{font-weight:600}
@media (min-width:1100px){
  .home-contact .card{max-width:520px}
}
@media (max-width:520px){
  .home-contact .card{flex-direction:row;gap:10px;padding:10px}
  .home-contact .card div{font-size:0.95rem}
}

/* A11y helpers */
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:8px;top:8px;background:var(--panel);color:var(--text);padding:8px;border-radius:6px;z-index:50;border:1px solid var(--border)}

img{max-width:100%;height:auto}
figure{margin:0}

/* WP basics */
.alignwide{max-width:min(1200px,100%)}
.alignfull{width:100vw;margin-left:calc(50% - 50vw);}

/* Typography and layout for pages/posts */
.page-header, .archive-header, .search-header{padding:16px 0}
.page-header h1, .archive-header h1, .search-header h1{margin:6px 0 10px}
.page-content, .entry-content{padding:8px 0}
.post .meta{color:var(--muted)}
.featured-image img{border-radius:8px}

/* Breadcrumbs */
.breadcrumbs{font-size:14px;color:var(--muted)}
.breadcrumbs ol{list-style:none;margin:0;padding:0;display:flex;gap:6px;flex-wrap:wrap}
.breadcrumbs li{display:flex;gap:6px;align-items:center}
.breadcrumbs li+li::before{content:'›';opacity:.6}
.breadcrumbs a{color:var(--muted);text-decoration:none}
.breadcrumbs a:hover{color:var(--text)}

/* Pagination */
.pagination a{color:#e6f0ff;text-decoration:none}
.pagination a:hover{text-decoration:underline}

/* Content typography */
.entry-content p, .page-content p{max-width:75ch}
.entry-content h2, .page-content h2{margin-top:22px}
.entry-content h3, .page-content h3{margin-top:18px}

/* Article & page typography: headings, lists, blockquote, code, tables, images */
.entry-content h1,
.page-content h1,
.archive-header h1,
.search-header h1{
  font-size: clamp(28px, 4vw, 40px);
  line-height: 1.08;
  margin: 0 0 0.6em;
  color: var(--text);
  font-weight: 700;
  letter-spacing: -0.01em;
}
.entry-content h2,
.page-content h2,
.hero h2,
.latest-posts h2{
  font-size: clamp(22px, 3vw, 30px);
  line-height: 1.12;
  margin: 0 0 0.6em;
  color: var(--text);
  font-weight: 700;
}
.entry-content h3,
.page-content h3{
  font-size: clamp(18px, 2.3vw, 22px);
  margin: 0 0 0.5em;
  color: var(--text);
  font-weight: 600;
}
.entry-content h4, .entry-content h5, .entry-content h6,
.page-content h4, .page-content h5, .page-content h6{
  color: var(--text);
  margin: 0 0 0.5em;
  font-weight: 600;
}

/* Paragraphs inside content */
.entry-content p, .page-content p{font-size:16px;color:var(--text);margin:0 0 1em;line-height:1.7}
.entry-content p.lead{font-size:18px;color:var(--muted);font-weight:600}

/* Links in content */
.entry-content a, .page-content a{color:var(--accent);text-decoration:underline}
.entry-content a:hover, .page-content a:hover{color:color-mix(in oklab,var(--accent) 85%, var(--text))}

/* Lists */
.entry-content ul, .entry-content ol, .page-content ul, .page-content ol{
  margin:0 0 1em 1.25rem;
  padding:0;
}
.entry-content li, .page-content li{margin:0 0 .55em;color:var(--text)}
/* Color bullets/numbers using ::marker when supported */
.entry-content ul li::marker, .page-content ul li::marker{color:var(--accent)}
.entry-content ol li::marker, .page-content ol li::marker{color:var(--accent)}
/* Nested lists spacing */
.entry-content ul ul, .entry-content ol ol, .page-content ul ul, .page-content ol ol{margin-left:1rem}

/* Blockquotes */
.entry-content blockquote, .page-content blockquote{
  border-left:4px solid var(--accent);
  padding:12px 16px;margin:0 0 1em;background:color-mix(in oklab,var(--panel) 75%, transparent);
  color:var(--text);font-style:italic;border-radius:6px;
}
.entry-content blockquote cite{display:block;margin-top:8px;font-style:normal;color:var(--muted);font-size:14px}

/* Inline code */
.entry-content code, .page-content code{background:color-mix(in oklab,var(--panel) 70%, transparent);padding:2px 6px;border-radius:6px;font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, 'Roboto Mono', 'Noto Mono', monospace;font-size:.95em;color:var(--text)}

/* Preformatted blocks */
.entry-content pre, .page-content pre{background:var(--panel);color:var(--text);padding:12px;border-radius:8px;overflow:auto;border:1px solid var(--border);font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, 'Roboto Mono', 'Noto Mono', monospace;font-size:13px}

/* Figures & images inside content */
.entry-content figure, .page-content figure{margin:0 0 1em}
.entry-content img, .page-content img{max-width:100%;height:auto;display:block;margin:0 auto}
.entry-content figcaption, .page-content figcaption{font-size:13px;color:var(--muted);margin-top:6px}

/* Tables (light enhancements -- existing responsive rules also apply) */
.entry-content table, .page-content table{width:100%;border-collapse:collapse;margin:0 0 1em;border:1px solid var(--border);background:transparent}
.entry-content th, .page-content th{background:color-mix(in oklab,var(--panel) 85%, transparent);padding:8px;text-align:left;border-bottom:1px solid var(--border)}
.entry-content td, .page-content td{padding:8px;border-bottom:1px solid var(--border)}

/* Accessibility helpers: focus states for links inside content */
.entry-content a:focus-visible, .page-content a:focus-visible{outline:3px solid color-mix(in oklab,var(--accent) 75%, transparent);outline-offset:2px}

/* Small screens tweaks */
@media (max-width:600px){
  .entry-content h1,.page-content h1{font-size:clamp(24px,7vw,34px)}
  .entry-content h2,.page-content h2{font-size:clamp(18px,5.5vw,24px)}
  .entry-content p,.page-content p{font-size:15px}
}

/* Utility: improve readability for long articles */
.entry-content .drop-cap:first-letter{float:left;font-size:3.2rem;line-height:1;margin-right:.2rem;font-weight:700}

/* Templates: images gallery */
.page-template-images .page-hero{margin-bottom:16px}
.page-template-images .page-hero .hero-image{width:100%;height:auto;border-radius:10px}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-top:16px}
.gallery-item img{width:100%;height:120px;object-fit:cover;border-radius:8px;border:1px solid var(--border)}

/* Templates: people grid */
.people-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:18px}
.person{background:var(--panel);border:1px solid var(--border);padding:12px;border-radius:10px}
.person a{color:inherit;text-decoration:none}
.person-media img{width:100%;height:180px;object-fit:cover;border-radius:8px}
.person h3{margin:8px 0 6px}
.person-role{color:var(--muted);font-weight:600;margin-bottom:6px}
.person-excerpt{color:var(--text);font-size:14px}
.avatar-placeholder{width:100%;height:160px;background:linear-gradient(135deg,color-mix(in oklab,var(--brand) 12%,transparent), color-mix(in oklab,var(--accent) 8%,transparent));border-radius:8px}

/* Template: inscription form */
/* inscription template styles removed */

/* small screens form adjustments */
@media (max-width:600px){
  .person-media img{height:140px}
  .gallery-item img{height:100px}
}
