/* Fonts (devono essere importati prima di ogni regola) */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=Montserrat:wght@700;800&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Anton&display=swap');

/* 0) Reset leggero */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
img, svg, video { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { font: inherit; border: 0; background: none; cursor: pointer; }

/* 1) Tokens + Tipografia */
:root {
	/* Colori estratti dalla palette esistente */
	--c-primary: #0b3f91; /* blu brand esistente */
	--c-accent: #ffd21f; /* giallo brand esistente */
	--c-bg: #ffffff;
	--c-text: #0e0e0e;
	--c-muted: #6b7380;
	--c-border: #e5e7eb;

	/* Spaziatura */
	--sp-1: 4px; --sp-2: 8px; --sp-3: 12px; --sp-4: 16px; --sp-5: 24px; --sp-6: 32px;
	/* Raggi */
	--radius: 12px; --radius-sm: 8px; --radius-lg: 18px;
    /* Ombra */
    --shadow: 0 8px 24px rgba(0, 0, 0, 0.08);

    /* Colore oro per il titolo hero in home (Anton) */
    --c-hero-gold: #FDBB30;
}



html { font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif; color: var(--c-text); background: var(--c-bg); }
body { font-size: 16px; line-height: 1.5; }

h1, h2, h3 { font-family: Montserrat, Inter, sans-serif; text-transform: uppercase; letter-spacing: .03em; line-height: 1.2; margin: 0 0 var(--sp-4); }
h1 { font-weight: 800; font-size: clamp(32px, 4vw, 48px); }
h2 { font-weight: 800; font-size: clamp(22px, 3vw, 28px); }
h3 { font-weight: 700; font-size: 18px; }
small, .muted { color: var(--c-muted); }

/* 2) Layout */
.container { width: min(1220px, 92%); margin: 0 auto; }
.section { padding: var(--sp-6) 0; }
.grid { display: grid; gap: var(--sp-5); }

/* 3) Header/Nav */
.header { position: sticky; top: 0; z-index: 100; background: var(--c-primary); color: #fff; backdrop-filter: saturate(120%) blur(0px); box-shadow: 0 2px 10px rgba(0,0,0,.1); }
.header.scrolled { box-shadow: 0 6px 20px rgba(0,0,0,.15); }
.nav { 
  /* Brand fisso a sinistra, menu centrato, burger a destra */
  display: grid; 
  grid-template-columns: auto 1fr auto; 
  align-items: center; 
  padding: var(--sp-4) 0; 
  column-gap: var(--sp-5);
}
.brand { display: flex; align-items: center; gap: var(--sp-3); font-weight: 800; letter-spacing: .04em; white-space: nowrap; }
.brand img { width: 40px; height: 40px; object-fit: contain; }
.menu { display: flex; align-items: center; gap: var(--sp-5); flex-wrap: nowrap; justify-content: center; }
.menu { padding-left: var(--sp-2); }

/* Riduci leggermente il gap su viewport medi per evitare overflow */
@media (min-width: 900px) and (max-width: 1200px) {
  .menu { gap: var(--sp-4); }
}
.menu a { color: #fff; padding: var(--sp-2) var(--sp-3); border-radius: var(--radius-sm); white-space: nowrap; }
.menu a.active, .menu a:hover { background: rgba(255,255,255,.12); }
.burger { display: none; width: 36px; height: 36px; position: relative; }
.burger span, .burger::before, .burger::after { content: ""; position: absolute; left: 6px; right: 6px; height: 2px; background: #fff; transition: .2s; }
.burger span { top: 50%; transform: translateY(-50%); }
.burger::before { top: 11px; }
.burger::after { bottom: 11px; }

.mobile-panel { position: fixed; inset: 0; background: rgba(0,0,0,.72); display: none; z-index: 1200; pointer-events: none; }
.mobile-panel.open { display: block; pointer-events: auto; }
.mobile-panel .mobile-drawer { position: absolute; top: 0; right: 0; width: min(340px, 86%); height: 100vh; background: #0b3f91; color: #fff; padding: var(--sp-6) var(--sp-5); box-shadow: -6px 0 24px rgba(0,0,0,.25); transform: translateX(100%); transition: transform .25s; overflow-y: auto; display: flex; flex-direction: column; }
.mobile-panel.open .mobile-drawer { transform: translateX(0); }
.mobile-panel .mobile-menu { display: flex; flex-direction: column; gap: var(--sp-3); margin-top: var(--sp-3); }
.mobile-panel .mobile-menu a { display: block; padding: var(--sp-3) 0; color: #fff; border-bottom: 1px solid rgba(255,255,255,.18); font-size: 1.05rem; letter-spacing: .01em; }
.mobile-panel .mobile-menu a:last-child { border-bottom: none; }

/* 4) Hero */
.hero { background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.0) 100%), var(--c-primary); color: #fff; padding: calc(var(--sp-6) + 20px) 0 var(--sp-6); position: relative; overflow: hidden; }
.hero::after { content: ""; position: absolute; inset: -40px -20px; background: radial-gradient(600px 320px at 20% -10%, rgba(255,255,255,.08), transparent 60%), radial-gradient(600px 320px at 80% -10%, rgba(255,255,255,.06), transparent 60%); opacity: .35; pointer-events: none; }
.hero .subtitle { margin-top: var(--sp-3); color: rgba(255,255,255,.9); }

/* Stile specifico per il titolo della home */
.hero-home h1 {
  font-family: 'Anton', Montserrat, Inter, sans-serif;
  color: var(--c-hero-gold);
  font-weight: 400; /* Anton è display con peso 400 */
  letter-spacing: 0.5px;
  text-transform: uppercase;
  font-size: 64px;
  line-height: 1;
}

@media (min-width: 1200px) {
  .hero-home h1 { font-size: 84px; }
}

/* 5) Sezioni */
/* News */
.news-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-5); }
.card { background: #fff; border: 1px solid var(--c-border); border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden; transition: transform .16s ease, box-shadow .16s ease; }
.card:hover { transform: translateY(-2px); box-shadow: 0 12px 28px rgba(0,0,0,.12); }
.card .media { aspect-ratio: 16 / 9; background: #f4f6fb; }
.card .media img { width: 100%; height: 100%; object-fit: cover; }
.card .content { padding: var(--sp-4); }
.card .meta { font-size: 13px; color: var(--c-muted); margin-top: var(--sp-2); }

/* Palmarès */
.trophy-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sp-5); }
.trophy { display: flex; gap: var(--sp-4); align-items: flex-start; padding: var(--sp-5); border: 1px solid var(--c-border); border-radius: var(--radius); background: #fff; box-shadow: var(--shadow); }
.trophy img { width: 64px; height: 64px; object-fit: contain; }

/* Sponsor */
.sponsor-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: var(--sp-4); }
.sponsor { background: #fff; border: 1px solid var(--c-border); border-radius: var(--radius-sm); padding: var(--sp-4); display: grid; place-items: center; transition: transform .15s; }
.sponsor:hover { transform: translateY(-2px); }
.sponsor img { width: 100%; height: 60px; object-fit: contain; }

/* Galleria */
.gallery-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-4); }
.gallery-item { position: relative; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--c-border); background: #fff; transition: transform .2s ease; }
.gallery-item .media { position: relative; aspect-ratio: 4 / 3; overflow: hidden; }
.gallery-photo { width: 100%; height: 100%; object-fit: cover; display: block; opacity: 0; background: #f1f5f9; transition: transform .3s ease, opacity .25s ease; cursor: zoom-in; }
.gallery-photo.is-loaded { opacity: 1; }
.gallery-item:hover .gallery-photo { transform: scale(1.03); }
.gallery-item.is-hidden { display: none; }
.gallery-load-more-wrapper { margin-top: var(--sp-5); display: flex; justify-content: center; }
.gallery-load-more { background: var(--c-primary); color: #fff; border: none; border-radius: var(--radius); padding: 12px 24px; font-weight: 600; box-shadow: var(--shadow); cursor: pointer; transition: transform .16s ease, box-shadow .16s ease, filter .16s ease; }
.gallery-load-more:hover { transform: translateY(-2px); box-shadow: 0 20px 40px rgba(11, 63, 145, .22); }
.gallery-lightbox { position: fixed; inset: 0; display: none; align-items: center; justify-content: center; background: rgba(15, 23, 42, .9); z-index: 3000; padding: var(--sp-5); }
.gallery-lightbox.open { display: flex; }
.gallery-lightbox__backdrop { position: absolute; inset: 0; cursor: zoom-out; }
.gallery-lightbox__content { position: relative; z-index: 1; display: grid; grid-template-columns: auto minmax(0, 1fr) auto; align-items: center; gap: var(--sp-4); max-width: min(1200px, 100%); width: 100%; }
.gallery-lightbox__figure { margin: 0; grid-column: 2; text-align: center; }
.gallery-lightbox__img { max-height: 80vh; max-width: 100%; width: auto; border-radius: var(--radius); box-shadow: 0 24px 64px rgba(0, 0, 0, .45); background: #0f172a; }
.gallery-lightbox__caption { margin-top: var(--sp-3); color: #f8fafc; font-size: .95rem; font-weight: 500; text-shadow: 0 0 12px rgba(15, 23, 42, .6); }
.gallery-lightbox__close { position: absolute; top: 12px; right: 12px; background: transparent; border: none; color: #fff; font-size: 38px; line-height: 1; cursor: pointer; padding: 0 6px; }
.gallery-lightbox__nav { border: none; background: rgba(30, 41, 59, .7); color: #fff; width: 54px; height: 54px; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; font-size: 28px; cursor: pointer; transition: background .2s ease, transform .2s ease, opacity .2s ease; }
.gallery-lightbox__nav:hover { background: rgba(59, 130, 246, .85); transform: scale(1.05); }
.gallery-lightbox__nav:disabled { opacity: .4; cursor: default; transform: none; }
.gallery-lightbox__prev { grid-column: 1; }
.gallery-lightbox__next { grid-column: 3; }

.cookie-banner { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%); width: min(960px, calc(100% - 32px)); background: #fff; color: var(--c-text); border-radius: 18px; padding: clamp(20px, 3vw, 28px); box-shadow: 0 24px 48px rgba(15, 23, 42, .18); border: 1px solid var(--c-border); z-index: 2500; animation: cookieSlideUp .35s ease-out both; }
.cookie-banner__inner { display: flex; flex-direction: column; gap: var(--sp-4); }
.cookie-banner__text h2 { font-size: 1.35rem; margin: 0 0 var(--sp-2); color: var(--c-primary); }
.cookie-banner__text p { margin: 0 0 var(--sp-2); font-size: .95rem; color: var(--c-muted); }
.cookie-banner__text a { color: var(--c-primary); text-decoration: underline; }
.cookie-banner__actions { display: flex; flex-wrap: wrap; gap: var(--sp-3); align-items: center; }
.cookie-btn { border: 1px solid var(--c-border); background: #fff; color: var(--c-text); padding: 10px 18px; border-radius: 999px; font-weight: 600; cursor: pointer; transition: transform .16s ease, box-shadow .16s ease, background .16s ease; }
.cookie-btn:hover { transform: translateY(-1px); box-shadow: 0 12px 28px rgba(15, 23, 42, .12); }
.cookie-btn--ghost { background: rgba(11, 63, 145, .08); border-color: rgba(11, 63, 145, .12); color: var(--c-primary); }
.cookie-btn--primary { background: var(--c-primary); color: #fff; border-color: var(--c-primary); box-shadow: 0 16px 36px rgba(11, 63, 145, .28); }
.cookie-btn--primary:hover { box-shadow: 0 20px 48px rgba(11, 63, 145, .32); }

.cookie-modal { position: fixed; inset: 0; display: none; align-items: center; justify-content: center; padding: var(--sp-5); background: rgba(15, 23, 42, .72); z-index: 2600; }
.cookie-modal.open { display: flex; }
.cookie-modal__overlay { position: absolute; inset: 0; background: transparent; }
.cookie-modal__dialog { position: relative; z-index: 1; max-width: 560px; width: 100%; background: #fff; color: var(--c-text); border-radius: 18px; padding: clamp(24px, 5vw, 36px); box-shadow: 0 32px 68px rgba(15, 23, 42, .22); outline: none; }
.cookie-modal__title { margin: 0 0 var(--sp-2); font-size: 1.5rem; color: var(--c-primary); }
.cookie-modal__intro { margin: 0 0 var(--sp-4); color: var(--c-muted); font-size: .95rem; }
.cookie-modal__close { position: absolute; top: 16px; right: 16px; border: none; background: rgba(15,23,42,.08); color: var(--c-text); font-size: 28px; width: 36px; height: 36px; border-radius: 50%; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; transition: background .16s ease, transform .16s ease; }
.cookie-modal__close:hover { background: rgba(11, 63, 145, .12); transform: rotate(-5deg); }
.cookie-modal__option { display: flex; justify-content: space-between; gap: var(--sp-4); padding: var(--sp-3) 0; border-bottom: 1px solid var(--c-border); }
.cookie-modal__option:last-of-type { border-bottom: none; padding-bottom: 0; }
.cookie-modal__option h3 { margin: 0 0 6px; font-size: 1.05rem; }
.cookie-modal__option p { margin: 0; color: var(--c-muted); font-size: .95rem; }
.cookie-modal__option--essential { align-items: center; }
.cookie-badge { display: inline-flex; align-items: center; justify-content: center; padding: 4px 12px; border-radius: 999px; font-size: .8rem; font-weight: 600; background: rgba(15, 118, 110, .12); color: #0f766e; text-transform: uppercase; letter-spacing: .05em; }
.cookie-switch { display: inline-flex; align-items: center; gap: 10px; cursor: pointer; user-select: none; }
.cookie-switch input { position: absolute; opacity: 0; pointer-events: none; }
.cookie-switch__slider { position: relative; width: 48px; height: 26px; border-radius: 999px; background: #cbd5f5; transition: background .2s ease; }
.cookie-switch__slider::after { content: ''; position: absolute; top: 3px; left: 3px; width: 20px; height: 20px; border-radius: 50%; background: #fff; box-shadow: 0 2px 6px rgba(15, 23, 42, .2); transition: transform .2s ease; }
.cookie-switch input:checked + .cookie-switch__slider { background: var(--c-primary); }
.cookie-switch input:checked + .cookie-switch__slider::after { transform: translateX(22px); }
.cookie-switch__label { font-size: .85rem; color: var(--c-muted); }
.cookie-modal__actions { margin-top: var(--sp-4); display: flex; justify-content: flex-end; gap: var(--sp-3); }

.policy { background: #fff; border: 1px solid var(--c-border); border-radius: var(--radius); box-shadow: var(--shadow); padding: clamp(24px, 4vw, 36px); line-height: 1.7; color: var(--c-text); }
.policy h2 { margin-top: var(--sp-5); font-size: 1.4rem; color: var(--c-primary); }
.policy h2:first-of-type { margin-top: var(--sp-3); }
.policy p { margin: 0 0 var(--sp-3); font-size: 1rem; color: var(--c-text); }
.policy-list { padding-left: 1.25rem; margin: 0 0 var(--sp-3); color: var(--c-text); }
.policy-list li { margin-bottom: var(--sp-2); }
.cookie-settings-link-inline { border: none; background: none; color: var(--c-primary); text-decoration: underline; cursor: pointer; font: inherit; padding: 0; }
.cookie-settings-link-inline:hover { color: #0b3281; }

.footer .legal-links { margin-top: var(--sp-4); display: flex; gap: var(--sp-4); flex-wrap: wrap; font-size: .9rem; align-items: center; }
.footer .legal-links a { color: #fff; opacity: .85; text-decoration: underline; }
.footer .legal-links a:hover { opacity: 1; }
.footer .legal-links .cookie-settings-link { border: none; background: none; color: #fff; opacity: .85; text-decoration: underline; cursor: pointer; padding: 0; font: inherit; }
.footer .legal-links .cookie-settings-link:hover { opacity: 1; }

@keyframes cookieSlideUp {
	from { transform: translate(-50%, 20px); opacity: 0; }
	to { transform: translate(-50%, 0); opacity: 1; }
}

.players-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1.5rem; }
.players-grid .player-card { height: 100%; }


/* 6) Footer */
.footer { background: var(--c-primary); color: #fff; padding: var(--sp-6) 0; margin-top: var(--sp-6); }
.footer .links { display: grid; grid-template-columns: repeat(4, max-content); justify-content: space-between; gap: var(--sp-5); align-items: center; }
.footer .links a { color: #fff; opacity: .9; display: inline-flex; align-items: center; gap: 8px; }
.footer .links a img.link-logo { height: 18px; width: auto; display: inline-block; filter: none; opacity: .95; }
.footer .links a:hover { text-decoration: underline; opacity: 1; }
.footer .social { display: flex; gap: var(--sp-4); justify-content: flex-end; }
.footer .copyright { margin-top: var(--sp-5); font-size: 14px; opacity: .9; }

/* Buttons */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2); padding: 10px 16px; border-radius: var(--radius); font-weight: 600; transition: filter .16s, transform .16s, box-shadow .16s; }
.btn:hover { transform: translateY(-1px); box-shadow: var(--shadow); }
.btn-primary { background: var(--c-accent); color: var(--c-primary); border: 1px solid var(--c-accent); }
.btn-secondary { background: transparent; color: var(--c-primary); border: 1px solid var(--c-primary); }

/* 7) Utilities */
.visually-hidden { position: absolute; width: 1px; height: 1px; margin: -1px; clip: rect(0 0 0 0); overflow: hidden; }
.badge-data { display: inline-block; padding: 2px 8px; border-radius: 999px; font-size: 12px; color: #fff; background: var(--c-primary); }
.chip { display: inline-flex; align-items: center; gap: 6px; padding: 4px 8px; border: 1px solid var(--c-border); border-radius: 999px; background: #fff; }

/* 9) Responsive */
@media (max-width: 1200px) {
	.sponsor-grid { grid-template-columns: repeat(5, 1fr); }
	.gallery-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 900px) {
	.news-grid { grid-template-columns: repeat(2, 1fr); }
	.trophy-grid { grid-template-columns: 1fr; }
	.sponsor-grid { grid-template-columns: repeat(4, 1fr); }
	.gallery-grid { grid-template-columns: repeat(2, 1fr); }
	.menu { display: none; }
	.burger { display: inline-block; }
  .footer .links { grid-template-columns: repeat(2, 1fr); justify-content: initial; row-gap: var(--sp-3); }
  .footer .legal-links { justify-content: flex-start; }
}
@media (max-width: 640px) {
	.news-grid { grid-template-columns: 1fr; }
	.sponsor-grid { grid-template-columns: repeat(2, 1fr); }
	.gallery-grid { grid-template-columns: 1fr; }
  .footer .links { grid-template-columns: 1fr; }
  .cookie-banner { width: calc(100% - 24px); bottom: 16px; padding: var(--sp-4); }
  .cookie-banner__actions { flex-direction: column; align-items: stretch; }
  .cookie-btn, .cookie-btn--primary { width: 100%; text-align: center; }
  .cookie-modal { padding: var(--sp-4); }
  .cookie-modal__dialog { padding: var(--sp-4); }
  .cookie-modal__option { flex-direction: column; align-items: flex-start; }
  .footer .legal-links { flex-direction: column; align-items: flex-start; gap: var(--sp-2); }
}

body.menu-open { overflow: hidden; }

/* Mobile refinements */
@media (max-width: 600px) {
  .hero { text-align: center; padding: var(--sp-6) 0 var(--sp-5); }
  .hero-home h1 { font-size: 48px; }
  .hero .subtitle { font-size: 1rem; }
  .hero .btn { width: 100%; justify-content: center; margin-bottom: var(--sp-3); }
  .hero .btn-secondary { margin-left: 0 !important; }
  .home-widgets { gap: var(--sp-4); }
  .card .content { padding: var(--sp-3); }
  .news-grid { gap: var(--sp-4); }
  .players-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--sp-3); }
  .players-grid .player-card { padding: var(--sp-3) !important; }
  .footer .links { grid-template-columns: 1fr; justify-items: center; text-align: center; gap: var(--sp-3); }
  .footer .links a { justify-content: center; }
  .footer .social { justify-content: center; }
  .footer .copyright { text-align: center; }
  .footer .legal-links { justify-content: center; align-items: center; text-align: center; }

  .gallery-lightbox { padding: var(--sp-4); }
  .gallery-lightbox__content { grid-template-columns: 1fr; }
  .gallery-lightbox__prev,
  .gallery-lightbox__next { position: absolute; top: 50%; transform: translateY(-50%); width: 46px; height: 46px; }
  .gallery-lightbox__prev { left: 12px; }
  .gallery-lightbox__next { right: 12px; }
  .gallery-lightbox__caption { font-size: .9rem; }
}

body.lightbox-open { overflow: hidden; }
body.cookie-modal-open { overflow: hidden; }

/* Home: sezione widget (mappa + risultati + classifica) */
.home-widgets { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-5); align-items: start; --homeWidgetH: 360px; }
.home-widgets .card .media { height: var(--homeWidgetH); position: relative; overflow: hidden; }
.home-widgets .card .media iframe { width: 100%; height: 100%; border: 0; display: block; }
/* Leaflet map inside media */
.home-widgets .card .media #home-map { position: absolute; inset: 0; }
.leaflet-container { border-radius: var(--radius-sm); box-shadow: inset 0 0 0 1px var(--c-border); }
.leaflet-control-zoom a { background: #fff; color: var(--c-primary); }
.leaflet-control-zoom a:hover { filter: brightness(0.95); }

/* Home: contenitore embed semplice (risultati/classifica) */
.home-embed { height: var(--homeWidgetH); border: 1px solid var(--c-border); border-radius: 12px; overflow: hidden; background: #fff; position: relative; }
.home-embed iframe { width: 100%; height: 100%; border: 0; display: block; }

/* Collapsible embed widgets (toggle button) */
.embed-collapsible { position: relative; }
.embed-toggle { position: absolute; left: 50%; transform: translateX(-50%); bottom: 10px; background: #1e40af; color: #fff; border: none; border-radius: 999px; padding: 6px 12px; font-weight: 600; cursor: pointer; box-shadow: 0 2px 12px rgba(0,0,0,.12); }
.embed-toggle:focus { outline: 2px solid var(--c-accent); outline-offset: 2px; }

/* Small-screen refinements */
@media (max-width: 560px) {
  .nav { padding: var(--sp-3) 0; }
  .brand img { width: 32px; height: 32px; }
  .brand span { font-size: 16px; letter-spacing: .02em; }
  .card .content { padding: var(--sp-3); }
  .hero { padding-top: calc(var(--sp-6) + 6px); padding-bottom: var(--sp-5); }
}
@media (max-width: 1000px) {
  .home-widgets { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 680px) {
  .home-widgets { grid-template-columns: 1fr; --homeWidgetH: 260px; }
}

/* Home: sezione Social */
.social-grid { display: grid; grid-template-columns: 2fr 1fr; gap: var(--sp-5); align-items: start; }
.social-grid .card .media { height: var(--homeWidgetH); }
.social-grid .card .media iframe { width: 100%; height: 100%; border: 0; display: block; border-radius: 12px; }
.ig-embed { display: grid; place-items: center; height: var(--homeWidgetH); background: #fff; border: 1px solid var(--c-border); border-radius: 12px; overflow: hidden; }
.ig-fallback { text-align: center; color: var(--c-muted); padding: 1rem; }
@media (max-width: 1000px) { .social-grid { grid-template-columns: 1fr; } }

/* Facebook static renderer */
.fb-static { height: var(--homeWidgetH); border: 1px solid var(--c-border); border-radius: 12px; overflow: hidden; background: #fff; position: relative; }
.fb-static a { display:block; width:100%; height:100%; color:inherit; }
.fb-static img { width:100%; height:100%; object-fit: cover; display:block; }
.fb-static .caption { position:absolute; left:0; right:0; bottom:0; padding:10px 12px; color:#fff; font-size:13px; background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.65) 80%); }
.fb-static .caption .meta { opacity:.9; font-size:12px; }
