/*
Theme Name:  Grand Lodge of Jerusalem 2026
Theme URI:   https://www.grandlodgeofjerusalem.com
Author:      Grand Lodge of Jerusalem N°1966
Author URI:  https://www.grandlodgeofjerusalem.com
Description: Tema WordPress istituzionale elegante per Grand Lodge of Jerusalem, con home page rivista, palette massonica rosso/oro e contenitori più sobri.
Version:     2.7.1
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License:     GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: grandlodge
Tags:        custom-menu, featured-images, full-width-template, theme-options, blog, responsive-layout
*/

:root {
  --glj-red: #B51F1F;
  --glj-red-dark: #6B1A1A;
  --glj-purple: #24161F;
  --glj-blue: #27378C;
  --glj-gold: #C9A045;
  --glj-gold-soft: #F2DB96;
  --glj-cream: #F6F0E2;
  --glj-paper: #FFFCF6;
  --glj-ink: #241D1D;
  --glj-muted: #6A5F5A;
  --glj-border: rgba(107,26,26,.14);
  --glj-shadow: 0 18px 44px rgba(22,10,10,.12);
  --font-heading: 'Cinzel', Georgia, serif;
  --font-display: 'Cinzel Decorative', Georgia, serif;
  --font-body: 'Cormorant Garamond', Georgia, serif;
  --font-ui: 'EB Garamond', Georgia, serif;
  --max-w: 1180px;
  --section-pad: clamp(4rem, 8vw, 7rem) 1.35rem;
  --transition: .28s ease;

  /* Compatibility tokens from the original base theme */
  --gold: var(--glj-gold);
  --gold-light: var(--glj-gold-soft);
  --gold-dim: #9A762B;
  --gold-pale: rgba(201,160,69,.15);
  --crimson: var(--glj-red-dark);
  --crimson-dim: #581010;
  --black: #080808;
  --deep: var(--glj-cream);
  --dark: #F8F0DE;
  --mid: #F2E6CC;
  --surface: var(--glj-paper);
  --parchment: var(--glj-purple);
  --cream: var(--glj-cream);
  --text-body: var(--glj-ink);
  --text-muted: var(--glj-muted);
  --white: #FFFFFF;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; font-size: 17px; }
body { margin: 0; background: var(--glj-cream); color: var(--glj-ink); font-family: var(--font-body); line-height: 1.78; overflow-x: hidden; -webkit-font-smoothing: antialiased; }
img { max-width: 100%; display: block; height: auto; }
a { color: inherit; text-decoration: none; }
ul { margin: 0; padding: 0; list-style: none; }
button, input, textarea { font: inherit; }
button { cursor: pointer; border: 0; background: transparent; }

body::before { content: ''; position: fixed; inset: 0; pointer-events: none; z-index: -1; background: radial-gradient(circle at top left, rgba(201,160,69,.22), transparent 34rem), radial-gradient(circle at top right, rgba(233,30,30,.09), transparent 26rem); }

.container { width: min(var(--max-w), calc(100% - 2.2rem)); margin: 0 auto; }
.section { padding: var(--section-pad); }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4rem); align-items: center; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.4rem; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.2rem; }

h1, h2, h3, h4, h5 { font-family: var(--font-heading); color: var(--glj-purple); line-height: 1.22; margin: 0 0 1rem; font-weight: 700; }
h1 { font-family: var(--font-display); font-size: clamp(2.2rem, 5.5vw, 4.9rem); font-weight: 400; letter-spacing: .01em; }
h2 { font-size: clamp(1.7rem, 3.2vw, 2.8rem); }
h3 { font-size: clamp(1.1rem, 2vw, 1.5rem); }
h4 { font-size: .82rem; letter-spacing: .18em; text-transform: uppercase; }
p { margin: 0 0 1.2em; }
p:last-child { margin-bottom: 0; }

.eyebrow { display: inline-flex; align-items: center; gap: .65rem; font-family: var(--font-heading); font-size: .72rem; letter-spacing: .26em; text-transform: uppercase; color: var(--glj-red-dark); font-weight: 700; margin-bottom: 1rem; }
.eyebrow::before { content: ''; width: 34px; height: 1px; background: var(--glj-gold); }
.lead { color: var(--glj-muted); font-size: 1.18rem; max-width: 720px; }
.title-bar { width: 74px; height: 3px; background: linear-gradient(90deg, var(--glj-red), var(--glj-gold)); border-radius: 50px; margin: .8rem 0 1.8rem; }
.title-bar--center { margin-left: auto; margin-right: auto; }
.rule { height: 1px; background: linear-gradient(90deg, transparent, rgba(48,26,69,.18), transparent); }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: .55rem; padding: .85rem 1.35rem; border-radius: 999px; font-family: var(--font-heading); font-size: .72rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; transition: transform var(--transition), box-shadow var(--transition), background var(--transition), color var(--transition), border-color var(--transition); }
.btn:hover { transform: translateY(-2px); }
.btn--gold { background: linear-gradient(135deg, var(--glj-gold), var(--glj-gold-soft)); color: var(--glj-purple); box-shadow: 0 12px 28px rgba(201,160,69,.25); }
.btn--outline { border: 1px solid rgba(140,21,21,.35); color: var(--glj-red-dark); background: rgba(255,255,255,.55); }
.btn--outline:hover { border-color: var(--glj-red); background: var(--glj-red); color: white; }

#site-header { position: fixed; top: 0; left: 0; right: 0; z-index: 500; transition: background var(--transition), box-shadow var(--transition), border-color var(--transition); border-bottom: 1px solid transparent; }
#site-header.scrolled { background: rgba(255,248,234,.94); backdrop-filter: blur(12px); border-bottom-color: var(--glj-border); box-shadow: 0 10px 35px rgba(48,26,69,.08); }
.header-inner { width: min(1240px, calc(100% - 2rem)); margin: 0 auto; padding: .7rem 0; display: flex; align-items: center; justify-content: space-between; gap: 1.1rem; }
.header-logo { display: flex; align-items: center; gap: .85rem; min-width: 0; }
.header-logo img { width: 58px; height: 58px; object-fit: contain; border-radius: 50%; box-shadow: 0 8px 24px rgba(48,26,69,.15); background: white; }
.header-logo-text { font-family: var(--font-heading); text-transform: uppercase; color: var(--glj-purple); font-weight: 700; letter-spacing: .08em; font-size: .78rem; line-height: 1.18; }
.header-logo-text small { display: block; color: var(--glj-red-dark); font-size: .58rem; letter-spacing: .18em; margin-top: .1rem; }
.primary-nav { flex: 1; display: flex; justify-content: flex-end; }
.primary-nav ul { display: flex; align-items: center; gap: .35rem; }
.primary-nav a { display: inline-flex; padding: .55rem .78rem; border-radius: 999px; color: var(--glj-purple); font-family: var(--font-heading); font-size: .68rem; letter-spacing: .09em; text-transform: uppercase; font-weight: 700; transition: background var(--transition), color var(--transition); }
.primary-nav a:hover, .primary-nav .current-menu-item > a { background: var(--glj-red); color: #fff; }
.menu-toggle { display: none; width: 44px; height: 44px; border-radius: 50%; background: var(--glj-paper); box-shadow: 0 8px 24px rgba(48,26,69,.12); align-items: center; justify-content: center; flex-direction: column; gap: 4px; }
.menu-toggle span { width: 18px; height: 2px; background: var(--glj-purple); display: block; }

.hero { min-height: 100vh; display: grid; align-items: center; padding: 7.8rem 1.35rem 4rem; position: relative; overflow: hidden; background: linear-gradient(135deg, rgba(255,248,234,.95), rgba(255,255,255,.86)), url('https://www.grandlodgeofjerusalem.com/wp-content/uploads/2024/10/castello-dei-baroni-23394167-1-1.jpeg') center/cover no-repeat; }
.hero::after { content: ''; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(255,248,234,.96) 0%, rgba(255,248,234,.88) 45%, rgba(255,248,234,.48) 100%); }
.hero__inner { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0,1.1fr) minmax(300px,.9fr); gap: clamp(2rem, 6vw, 5rem); align-items: center; width: min(var(--max-w), calc(100% - 1rem)); margin: 0 auto; }
.hero__content { max-width: 690px; }
.hero__subtitle { font-family: var(--font-heading); color: var(--glj-red-dark); text-transform: uppercase; letter-spacing: .28em; font-size: .72rem; font-weight: 700; margin-bottom: 1rem; }
.hero__content h1 { color: var(--glj-purple); text-shadow: 0 3px 0 rgba(201,160,69,.08); }
.hero__content .lead { font-size: 1.22rem; color: #423342; }
.hero__actions { display: flex; gap: .85rem; flex-wrap: wrap; margin-top: 2rem; }
.hero__seal-wrap { position: relative; display: grid; place-items: center; }
.hero-seal { width: min(430px, 82vw); border-radius: 50%; background: rgba(255,255,255,.72); box-shadow: var(--glj-shadow); padding: 1rem; }
.hero__seal-wrap::before { content: ''; position: absolute; width: 78%; aspect-ratio: 1; border-radius: 50%; border: 1px solid rgba(201,160,69,.45); transform: translate(1rem, 1rem); z-index: -1; }

.stats { background: var(--glj-paper); box-shadow: var(--glj-shadow); border-radius: 26px; border: 1px solid var(--glj-border); margin: -3.4rem auto 0; position: relative; z-index: 5; width: min(1000px, calc(100% - 2rem)); display: grid; grid-template-columns: repeat(3, 1fr); overflow: hidden; }
.stat { padding: 1.6rem; text-align: center; border-right: 1px solid var(--glj-border); }
.stat:last-child { border-right: 0; }
.stat__number { display: block; color: var(--glj-red); font-family: var(--font-heading); font-size: clamp(1.8rem, 4vw, 3rem); font-weight: 700; }
.stat__label { display: block; font-family: var(--font-heading); text-transform: uppercase; letter-spacing: .14em; font-size: .68rem; color: var(--glj-muted); }

.card, .value-card, .lodge-card, .relation-card, .event-card, .notice-card, .contact-card { background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(252,247,238,.92)); border: 1px solid var(--glj-border); border-radius: 18px; box-shadow: 0 14px 32px rgba(22,10,10,.08); overflow: hidden; }
.value-card { padding: 1.5rem; }
.value-card__icon { width: 44px; height: 44px; border-radius: 50%; background: rgba(233,30,30,.08); display: grid; place-items: center; color: var(--glj-red); margin-bottom: 1rem; }
.value-card__name { display: block; font-family: var(--font-heading); color: var(--glj-purple); font-weight: 700; text-transform: uppercase; letter-spacing: .08em; }
.value-card__text { color: var(--glj-muted); font-size: 1rem; margin-top: .45rem; }
.values__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; margin-top: 2.2rem; }

.logo-strip { display: grid; grid-template-columns: repeat(6, 1fr); gap: 1rem; margin-top: 2.5rem; }
.logo-strip__item { min-height: 128px; display: grid; place-items: center; background: #fff; border: 1px solid var(--glj-border); border-radius: 22px; padding: 1rem; box-shadow: 0 12px 35px rgba(48,26,69,.06); }
.logo-strip__item img { max-height: 98px; object-fit: contain; }

.quote-panel { background: linear-gradient(135deg, var(--glj-purple), #17122A); color: var(--glj-cream); border-radius: 30px; padding: clamp(2rem, 4vw, 3rem); box-shadow: var(--glj-shadow); }
.quote-panel h2, .quote-panel h3 { color: #fff; }
.quote-panel .eyebrow { color: var(--glj-gold-soft); }
.quote-panel .eyebrow::before { background: var(--glj-gold-soft); }
.quote-panel p { color: rgba(255,248,234,.84); }

.image-card { position: relative; border-radius: 30px; overflow: hidden; min-height: 360px; box-shadow: var(--glj-shadow); background: var(--glj-purple); }
.image-card img { width: 100%; height: 100%; object-fit: cover; position: absolute; inset: 0; }
.image-card__caption { position: absolute; inset: auto 1rem 1rem 1rem; background: rgba(255,255,255,.9); backdrop-filter: blur(8px); padding: 1rem; border-radius: 18px; color: var(--glj-purple); }

.page-hero { padding: 9.2rem 1.35rem 3.6rem; background: linear-gradient(135deg, var(--glj-purple), #17122A); color: #fff; position: relative; overflow: hidden; }
.page-hero::after { content: ''; position: absolute; right: -140px; top: -140px; width: 420px; aspect-ratio: 1; border-radius: 50%; background: radial-gradient(circle, rgba(233,30,30,.25), transparent 70%); }
.page-hero .container { position: relative; z-index: 1; }
.page-hero h1 { color: #fff; }
.page-hero .lead { color: rgba(255,248,234,.8); }
.page-hero .eyebrow { color: var(--glj-gold-soft); }
.page-hero .eyebrow::before { background: var(--glj-gold-soft); }

.content-section { background: var(--glj-paper); }
.text-block { max-width: 920px; }
.text-block h2, .text-block h3 { margin-top: 2rem; }
.text-block h2:first-child, .text-block h3:first-child { margin-top: 0; }
.text-block p, .entry-content p { color: #3c3438; font-size: 1.08rem; }
.text-block blockquote, .entry-content blockquote { border-left: 4px solid var(--glj-gold); padding-left: 1.4rem; color: var(--glj-red-dark); font-style: italic; margin: 1.6rem 0; }

.lodge-grid, .relations-grid, .events-grid, .messages-grid { display: grid; gap: 1.25rem; }
.lodge-grid { grid-template-columns: repeat(3, 1fr); }
.relations-grid { grid-template-columns: repeat(4, 1fr); }
.events-grid { grid-template-columns: repeat(3, 1fr); }
.messages-grid { grid-template-columns: repeat(2, 1fr); }
.lodge-card, .relation-card { padding: 1.25rem; display: flex; flex-direction: column; min-height: 100%; }
.lodge-card__image, .relation-card__image { background: #fff; border-radius: 20px; border: 1px solid var(--glj-border); aspect-ratio: 1; display: grid; place-items: center; padding: 1rem; margin-bottom: 1rem; }
.lodge-card__image img, .relation-card__image img { max-height: 100%; object-fit: contain; }
.relation-card__image { aspect-ratio: 1.15; }
.lodge-card h3, .relation-card h3 { font-size: 1.08rem; }
.meta-list { color: var(--glj-muted); font-size: .98rem; }
.meta-list strong { color: var(--glj-purple); }

.event-card { padding: 1.4rem; }
.event-card__date { display: inline-flex; background: rgba(233,30,30,.08); color: var(--glj-red-dark); font-family: var(--font-heading); text-transform: uppercase; letter-spacing: .1em; font-size: .72rem; border-radius: 999px; padding: .35rem .75rem; margin-bottom: 1rem; }
.notice-card { padding: 1.6rem; }
.notice-card__date { color: var(--glj-muted); font-size: .96rem; }

.contact-grid { display: grid; grid-template-columns: .85fr 1.15fr; gap: 1.5rem; align-items: start; }
.contact-card { padding: 1.6rem; }
.contact-form { display: grid; gap: .9rem; }
.contact-form label { display: grid; gap: .35rem; color: var(--glj-purple); font-family: var(--font-heading); font-size: .78rem; text-transform: uppercase; letter-spacing: .08em; font-weight: 700; }
.contact-form input, .contact-form textarea { width: 100%; border: 1px solid var(--glj-border); border-radius: 16px; padding: .85rem 1rem; background: #fff; color: var(--glj-ink); }
.contact-form textarea { min-height: 150px; resize: vertical; }
.form-status { font-family: var(--font-heading); color: var(--glj-red-dark); }

#site-footer { background: #130C1E; color: rgba(255,248,234,.78); }
.footer-main { width: min(var(--max-w), calc(100% - 2.2rem)); margin: 0 auto; padding: 4rem 0 2.6rem; display: grid; grid-template-columns: 1.35fr .7fr .8fr .9fr; gap: 2rem; }
.footer-brand img { width: 80px; height: 80px; border-radius: 50%; background: #fff; margin-bottom: 1rem; }
.footer-brand p { max-width: 340px; }
.footer-col h4 { color: var(--glj-gold-soft); margin-bottom: 1rem; }
.footer-col ul { display: grid; gap: .55rem; }
.footer-col a { color: rgba(255,248,234,.82); transition: color var(--transition); }
.footer-col a:hover { color: var(--glj-gold-soft); }
.social-links { display: flex; gap: .8rem; margin-top: 1rem; }
.social-links a { border: 1px solid rgba(255,248,234,.22); border-radius: 999px; padding: .35rem .65rem; font-family: var(--font-heading); font-size: .72rem; letter-spacing: .08em; }
.footer-bottom { border-top: 1px solid rgba(255,248,234,.12); padding: 1rem 1.35rem; display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; width: min(var(--max-w), calc(100% - 2.2rem)); margin: 0 auto; color: rgba(255,248,234,.58); font-size: .9rem; }

.entry-content { font-size: 1.08rem; color: var(--glj-ink); }
.entry-content h2, .entry-content h3 { color: var(--glj-purple); margin: 2rem 0 1rem; }
.entry-content a { color: var(--glj-red-dark); text-decoration: underline; }
.entry-content ul, .entry-content ol { padding-left: 1.35rem; margin: 1rem 0; }
.entry-content ul { list-style: disc; }
.entry-content ol { list-style: decimal; }

.reveal, .reveal-left, .reveal-right { opacity: 0; transform: translateY(22px); transition: opacity .7s ease, transform .7s ease; }
.reveal-left { transform: translateX(-22px); }
.reveal-right { transform: translateX(22px); }
.reveal.visible, .reveal-left.visible, .reveal-right.visible { opacity: 1; transform: none; }

@media (max-width: 1050px) {
  .primary-nav { position: fixed; inset: 80px 1rem auto 1rem; background: rgba(255,255,255,.97); border: 1px solid var(--glj-border); border-radius: 24px; box-shadow: var(--glj-shadow); padding: 1rem; display: none; }
  .primary-nav.open { display: block; }
  .primary-nav ul { flex-direction: column; align-items: stretch; }
  .primary-nav a { justify-content: center; }
  .menu-toggle { display: inline-flex; }
  .hero__inner, .grid-2, .contact-grid { grid-template-columns: 1fr; }
  .hero { min-height: auto; }
  .hero__seal-wrap { order: -1; margin-top: 1rem; }
  .hero-seal { width: min(280px, 72vw); }
  .relations-grid { grid-template-columns: repeat(3, 1fr); }
  .values__grid, .logo-strip { grid-template-columns: repeat(2, 1fr); }
  .footer-main { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 760px) {
  html { font-size: 16px; }
  .header-logo-text { display: none; }
  .stats, .lodge-grid, .relations-grid, .events-grid, .messages-grid { grid-template-columns: 1fr; }
  .stat { border-right: 0; border-bottom: 1px solid var(--glj-border); }
  .stat:last-child { border-bottom: 0; }
  .grid-3, .grid-4, .values__grid, .logo-strip { grid-template-columns: 1fr; }
  .footer-main { grid-template-columns: 1fr; }
  .footer-bottom { display: block; }
  .hero__actions { align-items: stretch; flex-direction: column; }
  .btn { width: 100%; }
}


/* ============================================================
   HOME PAGE ELEGANT REFINEMENT
   ============================================================ */
body.home::before {
  background:
    radial-gradient(circle at 50% 0%, rgba(181,31,31,.18), transparent 32rem),
    radial-gradient(circle at 20% 10%, rgba(201,160,69,.18), transparent 24rem),
    linear-gradient(180deg, #120C0C 0, #140E0E 26rem, transparent 26rem);
  z-index: 0;
}
body.home #site-header:not(.scrolled) .header-logo-text,
body.home #site-header:not(.scrolled) .primary-nav a { color: var(--glj-cream); }
body.home #site-header:not(.scrolled) .primary-nav a:hover,
body.home #site-header:not(.scrolled) .primary-nav .current-menu-item > a { background: rgba(255,255,255,.12); color: #fff; }
body.home #site-header:not(.scrolled) .menu-toggle { background: rgba(255,255,255,.12); }
body.home #site-header:not(.scrolled) .menu-toggle span { background: var(--glj-cream); }
body.home #site-header:not(.scrolled) .header-logo img { background: rgba(255,255,255,.96); }

.home-hero {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 8rem 1.5rem 6rem;
  overflow: hidden;
  position: relative;
  background: radial-gradient(ellipse at 50% 25%, rgba(84,18,18,.88) 0%, rgba(21,13,13,.98) 60%, #0B0909 100%);
}
.home-hero .hero-bg { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.home-hero .hero-bg__rays {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 150vmax; height: 150vmax;
  opacity: .06;
  animation: rays-rotate 160s linear infinite;
}
.home-hero .hero-bg__vignette {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at center, transparent 24%, rgba(11,9,9,.82) 82%);
}
@keyframes rays-rotate {
  to { transform: translate(-50%, -50%) rotate(360deg); }
}
.home-hero .hero-seals {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 3rem;
  margin-bottom: 2rem;
  position: relative;
  z-index: 1;
}
.home-hero .hero-seals--single { margin-bottom: 2.2rem; }
.home-hero .hero-seal {
  width: clamp(160px, 19vw, 240px);
  max-width: 240px;
  border-radius: 50%;
  background: rgba(255,255,255,.92);
  padding: .65rem;
  box-shadow: 0 0 0 1px rgba(201,160,69,.25), 0 18px 42px rgba(0,0,0,.28);
  filter: drop-shadow(0 0 24px rgba(201,160,69,.16));
}
.home-hero .hero-content { position: relative; z-index: 1; max-width: 900px; }
.home-hero .hero-eyebrow,
.home-hero .hero-subtitle,
.home-hero .scroll-indicator__text { color: var(--glj-gold-soft); }
.home-hero .hero-eyebrow::before { background: var(--glj-gold-soft); }
.home-hero .hero-title {
  font-family: var(--font-display);
  font-size: clamp(2.3rem, 5.8vw, 5.2rem);
  font-weight: 400;
  line-height: 1.1;
  margin-bottom: .8rem;
  color: #FFF6E5;
}
.home-hero .hero-title span { color: var(--glj-gold-soft); }
.home-hero .hero-subtitle {
  font-family: var(--font-heading);
  font-size: clamp(.72rem, 1.4vw, .92rem);
  letter-spacing: .28em;
  text-transform: uppercase;
  margin-bottom: 1.55rem;
}
.home-hero .hero-divider {
  width: 220px; height: 1px;
  margin: 0 auto 1.5rem;
  background: linear-gradient(90deg, transparent, var(--glj-gold), transparent);
}
.home-hero .hero-motto {
  max-width: 760px;
  margin: 0 auto 2.3rem;
  color: rgba(255,246,229,.86);
  font-size: clamp(1rem, 2vw, 1.22rem);
}
.home-hero .hero-ctas {
  display: flex;
  justify-content: center;
  gap: 1rem;
  flex-wrap: wrap;
}
.home-hero .btn--outline { background: rgba(255,255,255,.06); border-color: rgba(201,160,69,.4); color: var(--glj-gold-soft); }
.home-hero .btn--outline:hover { background: var(--glj-gold); color: var(--glj-purple); border-color: var(--glj-gold); }
.home-hero .scroll-indicator {
  position: absolute;
  bottom: 2.2rem; left: 50%;
  transform: translateX(-50%);
  z-index: 1;
  display: flex; flex-direction: column; align-items: center; gap: .5rem;
  opacity: .45;
}
.home-hero .scroll-indicator__line {
  width: 1px; height: 50px;
  background: linear-gradient(to bottom, var(--glj-gold), transparent);
}

.stats-bar {
  background: linear-gradient(180deg, #1A1111, #120C0C);
  border-top: 1px solid rgba(201,160,69,.18);
  border-bottom: 1px solid rgba(201,160,69,.18);
  padding: 2.2rem 1.5rem;
}
.stats-bar__inner {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  text-align: center;
}
.stats-bar .stat { padding: 0 1rem; border-right: 1px solid rgba(201,160,69,.14); }
.stats-bar .stat:last-child { border-right: 0; }
.stats-bar .stat__number { color: var(--glj-gold-soft); font-family: var(--font-heading); font-size: clamp(1.9rem, 4vw, 2.8rem); display: block; line-height: 1; margin-bottom: .45rem; }
.stats-bar .stat__label { color: rgba(255,246,229,.68); font-family: var(--font-heading); font-size: .68rem; letter-spacing: .2em; text-transform: uppercase; }

.home-intro,
.home-navigation { background: transparent; }
.home-intro .text-block,
.home-navigation .container,
.values.content-section .container { position: relative; z-index: 1; }
.home-values-grid { grid-template-columns: repeat(4, 1fr); }
.home-link-card {
  display: block;
  padding: 1.45rem 1.4rem;
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(252,247,238,.92));
  border: 1px solid var(--glj-border);
  border-radius: 18px;
  box-shadow: 0 14px 32px rgba(22,10,10,.08);
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.home-link-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 38px rgba(22,10,10,.12);
  border-color: rgba(201,160,69,.45);
}
.home-link-card h3 {
  margin-bottom: .65rem;
  color: var(--glj-purple);
  font-size: 1.18rem;
}
.home-link-card p { color: #4D4340; margin: 0; }
.home-links-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
.values.content-section {
  background: linear-gradient(180deg, rgba(255,255,255,.82), rgba(246,240,226,.92));
}
.quote-panel {
  background: linear-gradient(145deg, #27161A, #4A1717);
  border: 1px solid rgba(201,160,69,.18);
  border-radius: 22px;
}
.quote-panel p { color: rgba(255,246,229,.82); }
.text-block blockquote, .entry-content blockquote {
  border-left-color: var(--glj-gold);
  color: var(--glj-red-dark);
}
.image-card,
.logo-strip__item,
.lodge-card__image,
.relation-card__image,
.contact-form input,
.contact-form textarea { border-radius: 18px; }

@media (max-width: 1050px) {
  .home-values-grid { grid-template-columns: repeat(2, 1fr); }
  .home-links-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 760px) {
  body.home::before { background: radial-gradient(circle at 50% 0%, rgba(181,31,31,.18), transparent 26rem), linear-gradient(180deg, #120C0C 0, #140E0E 24rem, transparent 24rem); }
  .home-hero { padding: 7.5rem 1.2rem 5rem; }
  .home-hero .hero-ctas { flex-direction: column; align-items: stretch; }
  .home-hero .btn { width: 100%; }
  .stats-bar__inner, .home-values-grid, .home-links-grid { grid-template-columns: 1fr; }
  .stats-bar .stat { border-right: 0; border-bottom: 1px solid rgba(201,160,69,.14); padding: 0 0 1rem; margin-bottom: 1rem; }
  .stats-bar .stat:last-child { border-bottom: 0; margin-bottom: 0; padding-bottom: 0; }
}

/* ============================================================
   SECOND REFINEMENT — ORIGINAL TOP / MALTA ONLY / DYNAMIC UI
   ============================================================ */
.home-hero--original {
  display: grid;
  align-items: center;
  text-align: left;
  padding: 8.2rem 1.35rem 5.5rem;
  background:
    radial-gradient(circle at 78% 42%, rgba(201,160,69,.18), transparent 22rem),
    radial-gradient(circle at 22% 20%, rgba(181,31,31,.28), transparent 26rem),
    linear-gradient(135deg, #100B0B 0%, #1B0E10 46%, #0A0808 100%);
}
.home-hero--original::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(201,160,69,.05) 1px, transparent 1px),
    linear-gradient(0deg, rgba(201,160,69,.035) 1px, transparent 1px);
  background-size: 74px 74px;
  mask-image: radial-gradient(circle at 50% 45%, black 0%, transparent 72%);
  opacity: .42;
  pointer-events: none;
}
.home-hero--original .hero__inner--original {
  position: relative;
  z-index: 2;
  width: min(1180px, calc(100% - 1rem));
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(300px, .9fr);
  gap: clamp(2.2rem, 6vw, 5.5rem);
  align-items: center;
}
.home-hero--original .hero-content {
  max-width: 760px;
  text-align: left;
}
.home-hero--original .hero-title {
  color: #FFF6E5;
  font-size: clamp(2.4rem, 5.4vw, 5.45rem);
  letter-spacing: .015em;
}
.home-hero--original .hero-title span {
  color: var(--glj-gold-soft);
}
.home-hero--original .hero-eyebrow {
  display: inline-flex;
  color: var(--glj-gold-soft);
  letter-spacing: .32em;
}
.home-hero--original .hero-eyebrow::before { background: var(--glj-gold); }
.home-hero--original .hero-subtitle {
  color: rgba(255,246,229,.72);
  letter-spacing: .26em;
}
.home-hero--original .hero-divider {
  margin-left: 0;
  margin-right: 0;
  width: 260px;
}
.home-hero--original .hero-motto {
  margin-left: 0;
  color: rgba(255,246,229,.84);
  max-width: 690px;
}
.home-hero--original .hero-ctas { justify-content: flex-start; }
.hero-visual--original {
  position: relative;
  min-height: min(560px, 72vw);
  display: grid;
  place-items: center;
  isolation: isolate;
}
.hero-seal--original {
  width: min(500px, 82vw);
  max-width: 500px;
  padding: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  filter: drop-shadow(0 22px 34px rgba(0,0,0,.34));
  position: relative;
  z-index: 2;
}
.hero-orbit {
  position: absolute;
  inset: 8%;
  border: 1px solid rgba(201,160,69,.18);
  border-radius: 50%;
  animation: orbitSpin 28s linear infinite;
  z-index: 1;
}
.hero-orbit::before,
.hero-orbit::after {
  content: '';
  position: absolute;
  inset: 9%;
  border: 1px solid rgba(201,160,69,.11);
  border-radius: 50%;
}
.hero-orbit::after { inset: 18%; opacity: .7; }
.hero-orbit span {
  position: absolute;
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--glj-gold);
  box-shadow: 0 0 22px rgba(201,160,69,.65);
}
.hero-orbit span:nth-child(1) { top: -5px; left: 50%; }
.hero-orbit span:nth-child(2) { right: 10%; bottom: 13%; }
.hero-orbit span:nth-child(3) { left: 10%; bottom: 13%; }
@keyframes orbitSpin { to { transform: rotate(360deg); } }
.hero-visual__caption {
  position: absolute;
  left: 50%; bottom: 1.2rem;
  transform: translateX(-50%);
  width: min(360px, 88%);
  padding: .85rem 1rem;
  text-align: center;
  border: 1px solid rgba(201,160,69,.22);
  background: rgba(14,9,9,.62);
  color: var(--glj-cream);
  backdrop-filter: blur(12px);
  box-shadow: 0 18px 44px rgba(0,0,0,.18);
}
.hero-visual__caption strong,
.hero-visual__caption span { display: block; }
.hero-visual__caption strong {
  color: var(--glj-gold-soft);
  font-family: var(--font-heading);
  text-transform: uppercase;
  letter-spacing: .13em;
  font-size: .72rem;
}
.hero-visual__caption span { color: rgba(255,246,229,.76); font-size: .95rem; }

.section-dynamic { position: relative; overflow: hidden; }
.section-dynamic::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(circle at var(--mx, 50%) var(--my, 20%), rgba(201,160,69,.13), transparent 24rem);
  opacity: .65;
  transition: opacity .3s ease;
}
.interactive-card {
  position: relative;
  transform-style: preserve-3d;
  will-change: transform;
}
.interactive-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at var(--card-x, 50%) var(--card-y, 0%), rgba(201,160,69,.18), transparent 16rem);
  opacity: 0;
  transition: opacity .28s ease;
  pointer-events: none;
}
.interactive-card:hover::after { opacity: 1; }
.value-card__icon {
  box-shadow: inset 0 0 0 1px rgba(201,160,69,.25), 0 10px 22px rgba(107,26,26,.08);
}
.home-link-card {
  border-radius: 14px;
  border-top: 2px solid rgba(201,160,69,.42);
}
.home-link-card h3::after {
  content: '';
  display: block;
  width: 38px; height: 1px;
  margin-top: .7rem;
  background: var(--glj-gold);
  transition: width .3s ease;
}
.home-link-card:hover h3::after { width: 76px; }
.stats-bar .stat__number[data-count] { min-width: 4ch; }

@media (prefers-reduced-motion: reduce) {
  .hero-orbit, .home-hero .hero-bg__rays { animation: none !important; }
  .interactive-card, [data-parallax] { transform: none !important; }
}
@media (max-width: 1050px) {
  .home-hero--original { text-align: center; }
  .home-hero--original .hero__inner--original { grid-template-columns: 1fr; }
  .home-hero--original .hero-content { text-align: center; margin: 0 auto; }
  .home-hero--original .hero-divider { margin-left: auto; margin-right: auto; }
  .home-hero--original .hero-motto { margin-left: auto; margin-right: auto; }
  .home-hero--original .hero-ctas { justify-content: center; }
  .hero-visual--original { order: -1; min-height: auto; padding: 1rem 0 2rem; }
  .hero-seal--original { width: min(330px, 72vw); }
  .hero-orbit { inset: 2%; }
  .hero-visual__caption { position: relative; margin-top: 1rem; left: auto; bottom: auto; transform: none; }
}
@media (max-width: 760px) {
  .home-hero--original { padding-top: 7.5rem; }
  .home-hero--original .hero-eyebrow { letter-spacing: .2em; font-size: .62rem; }
  .hero-visual__caption { width: min(320px, 94%); }
}

.home-hero--original .hero-seal--original {
  width: min(500px, 82vw);
  max-width: 500px;
  padding: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  filter: drop-shadow(0 22px 34px rgba(0,0,0,.34));
}
@media (max-width: 1050px) {
  .home-hero--original .hero-seal--original { width: min(330px, 72vw); }
}


/* ============================================================
   THIRD REFINEMENT — CINEMATIC MASONIC EXPERIENCE
   ============================================================ */
#site-header {
  background: rgba(10, 7, 8, .72);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(201,160,69,.16);
}
#site-header.scrolled {
  background: rgba(10, 7, 8, .92);
  border-bottom-color: rgba(201,160,69,.28);
  box-shadow: 0 12px 36px rgba(0,0,0,.24);
}
.header-logo-text,
.primary-nav a { color: var(--glj-gold-soft); text-shadow: 0 1px 10px rgba(0,0,0,.28); }
.header-logo-text small { color: rgba(255,244,214,.82); }
.primary-nav a { border: 1px solid transparent; }
.primary-nav a:hover,
.primary-nav .current-menu-item > a {
  background: linear-gradient(135deg, rgba(181,31,31,.92), rgba(107,26,26,.96));
  color: #fff;
  border-color: rgba(201,160,69,.28);
  box-shadow: 0 10px 24px rgba(107,26,26,.22);
}
.menu-toggle { background: rgba(255,255,255,.12); }
.menu-toggle span { background: var(--glj-gold-soft); }

body.home #site-header:not(.scrolled) { background: rgba(10, 7, 8, .48); }
body.home #site-header:not(.scrolled) .header-logo-text,
body.home #site-header:not(.scrolled) .primary-nav a,
body.home #site-header:not(.scrolled) .header-logo-text small { color: var(--glj-gold-soft); }

.page-hero {
  background:
    radial-gradient(circle at 50% 10%, rgba(201,160,69,.16), transparent 28rem),
    linear-gradient(135deg, #140C0C, #24161F 60%, #401616);
}
.page-hero::before {
  content:'';
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(255,255,255,.03), transparent 25%),
              repeating-linear-gradient(90deg, rgba(201,160,69,.03), rgba(201,160,69,.03) 1px, transparent 1px, transparent 48px);
  opacity:.7;
}
.page-hero .container { z-index:2; }

.section-dynamic { position: relative; overflow: hidden; }
.section-dynamic::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background: radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(201,160,69,.10), transparent 28rem);
  opacity:.75;
}
.interactive-card { position: relative; transform-style: preserve-3d; }
.interactive-card::after {
  content:''; position:absolute; inset:0; border-radius: inherit; pointer-events:none;
  background: radial-gradient(circle at var(--card-x,50%) var(--card-y,50%), rgba(255,255,255,.22), transparent 35%);
  opacity: 0; transition: opacity var(--transition);
}
.interactive-card:hover::after { opacity: 1; }

.lodge-card, .relation-card {
  border-radius: 20px;
  padding: 1.35rem;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(250,244,232,.96));
}
.lodge-card__image, .relation-card__image {
  min-height: 210px;
  border-radius: 18px;
  padding: 1.35rem;
  background:
    radial-gradient(circle at top, rgba(201,160,69,.18), transparent 65%),
    linear-gradient(180deg, #ffffff, #fbf5ea);
  box-shadow: inset 0 0 0 1px rgba(201,160,69,.22), 0 12px 28px rgba(20,8,8,.06);
}
.lodge-card__image img, .relation-card__image img {
  max-width: 100%;
  max-height: 150px;
  width: auto;
  height: auto;
  object-fit: contain;
  margin: 0 auto;
  filter: drop-shadow(0 8px 18px rgba(0,0,0,.14));
}
.relation-card__image { aspect-ratio: 1; }
.relations-grid { grid-template-columns: repeat(4, 1fr); }

.supreme-emblem-card {
  position: relative;
  min-height: 100%;
  background: radial-gradient(circle at top, rgba(201,160,69,.16), transparent 38%), linear-gradient(145deg, #120C0C, #221217 55%, #381212);
  border-radius: 28px;
  border: 1px solid rgba(201,160,69,.18);
  box-shadow: 0 24px 55px rgba(0,0,0,.24);
  padding: 2rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.supreme-emblem-card__glow {
  position:absolute; inset:auto; width:70%; aspect-ratio:1; border-radius:50%;
  background: radial-gradient(circle, rgba(201,160,69,.20), transparent 65%);
  filter: blur(12px);
}
.supreme-emblem-card__image {
  position: relative; z-index:1;
  width: min(420px, 100%);
  filter: drop-shadow(0 20px 28px rgba(0,0,0,.36));
}
.supreme-emblem-card__caption {
  position: relative; z-index:1;
  margin-top: 1.4rem;
  display:grid; gap:.3rem;
  text-align:center;
  color: rgba(255,246,229,.88);
  font-family: var(--font-heading);
  letter-spacing: .06em;
}
.supreme-emblem-card__caption strong { color: var(--glj-gold-soft); font-size: .95rem; }
.supreme-emblem-card__caption span { font-size: .7rem; text-transform: uppercase; letter-spacing: .22em; }

.contact-form-shell {
  display: grid;
  grid-template-columns: .85fr 1.15fr;
  gap: 1.4rem;
  align-items: start;
}
.contact-intro-card {
  padding: 1.75rem;
  border-radius: 22px;
  background: linear-gradient(145deg, #221215, #421717);
  color: rgba(255,246,229,.88);
  border: 1px solid rgba(201,160,69,.16);
  box-shadow: 0 20px 46px rgba(0,0,0,.18);
}
.contact-intro-card h2 { color: #fff; }
.contact-intro-card .eyebrow { color: var(--glj-gold-soft); }
.contact-intro-card .eyebrow::before { background: var(--glj-gold-soft); }
.contact-intro-card p { color: rgba(255,246,229,.82); }
.contact-socials a { color: var(--glj-gold-soft); }
.contact-card { padding: 1.7rem; border-radius: 22px; }
.contact-form input, .contact-form textarea {
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(107,26,26,.18);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.62);
}
.contact-form input:focus, .contact-form textarea:focus {
  outline: none;
  border-color: rgba(201,160,69,.65);
  box-shadow: 0 0 0 3px rgba(201,160,69,.16);
}
.form-status { margin-top: .4rem; }

.footer-scene {
  position: relative;
  min-height: 320px;
  background-position: center;
  background-size: cover;
  overflow: hidden;
}
.footer-scene__overlay {
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(8,8,8,.14), rgba(8,8,8,.74)), radial-gradient(circle at 50% 12%, rgba(201,160,69,.16), transparent 24rem);
}
.footer-scene__inner {
  position:relative; z-index:1;
  width: min(var(--max-w), calc(100% - 2.2rem));
  margin: 0 auto;
  min-height: 320px;
  display:flex; flex-direction:column; justify-content:flex-end;
  padding: 2.2rem 0;
}
.footer-scene__inner .eyebrow { color: var(--glj-gold-soft); }
.footer-scene__inner .eyebrow::before { background: var(--glj-gold-soft); }
.footer-scene__inner h2 { color: #fff; margin-bottom: .55rem; }
.footer-scene__inner p { color: rgba(255,246,229,.88); font-size: 1.08rem; }
#site-footer { background: #120C0C; color: rgba(255,248,234,.78); }
.footer-main {
  padding-top: 3rem;
  grid-template-columns: 1.2fr .75fr .8fr .85fr;
}
.footer-col li, .footer-brand p { color: rgba(255,248,234,.78); }
.footer-col a, .social-links a { color: rgba(255,248,234,.86); }
.footer-col a:hover, .social-links a:hover { color: var(--glj-gold-soft); }

@media (max-width: 1050px) {
  .relations-grid { grid-template-columns: repeat(3, 1fr); }
  .contact-form-shell { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .relations-grid, .lodge-grid { grid-template-columns: 1fr; }
  .lodge-card__image, .relation-card__image { min-height: 180px; }
  .footer-scene, .footer-scene__inner { min-height: 250px; }
}


/* ============================================================
   THIRD REFINEMENT — CINEMATIC / MASONIC OVERRIDES
   ============================================================ */
#site-header {
  background: rgba(9, 8, 10, .74);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(201,160,69,.16);
  box-shadow: 0 10px 30px rgba(0,0,0,.18);
}
#site-header.scrolled {
  background: rgba(9, 8, 10, .90);
  border-bottom-color: rgba(201,160,69,.24);
}
.header-logo-text,
.primary-nav a,
body.home #site-header:not(.scrolled) .header-logo-text,
body.home #site-header:not(.scrolled) .primary-nav a {
  color: #F6E7BE;
}
.header-logo-text small { color: rgba(246,231,190,.72); }
.primary-nav a:hover,
.primary-nav .current-menu-item > a,
body.home #site-header:not(.scrolled) .primary-nav a:hover,
body.home #site-header:not(.scrolled) .primary-nav .current-menu-item > a {
  background: linear-gradient(135deg, rgba(181,31,31,.96), rgba(107,26,26,.96));
  color: #fff;
}
.menu-toggle,
body.home #site-header:not(.scrolled) .menu-toggle {
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(201,160,69,.18);
}
.menu-toggle span,
body.home #site-header:not(.scrolled) .menu-toggle span { background: #F6E7BE; }

.home-hero--cinematic {
  background: radial-gradient(ellipse at 50% 20%, rgba(83,17,17,.60), rgba(12,9,9,.97) 65%);
  min-height: 100vh;
}
.home-hero--cinematic .hero-bg__cover {
  position: absolute; inset: 0;
  background-size: cover; background-position: center center;
  opacity: .22; transform: scale(1.04);
  filter: saturate(.92) contrast(1.05) brightness(.64);
}
.home-hero--cinematic::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 50% 26%, rgba(201,160,69,.10), transparent 17rem),
    linear-gradient(180deg, rgba(8,6,6,.52), rgba(8,6,6,.88));
  z-index: 0;
}
.home-hero--cinematic .hero-content { position: relative; z-index: 2; max-width: 980px; }
.home-hero--cinematic .hero-crest {
  width: min(620px, 88vw);
  margin: 0 auto 1.2rem;
  display: block;
  filter: drop-shadow(0 12px 45px rgba(0,0,0,.38)) drop-shadow(0 0 16px rgba(201,160,69,.14));
  background: transparent;
  padding: 0;
  box-shadow: none;
}
.home-hero--cinematic .hero-title {
  color: #FFF6E5;
  text-shadow: 0 6px 24px rgba(0,0,0,.38);
}
.home-hero--cinematic .hero-subtitle,
.home-hero--cinematic .hero-eyebrow,
.home-hero--cinematic .scroll-indicator__text { color: #F6D984; }
.home-hero--cinematic .hero-eyebrow::before { background: #F6D984; }
.home-hero--cinematic .hero-motto { color: rgba(255,246,229,.90); max-width: 800px; }
.home-hero--cinematic .btn--gold { box-shadow: 0 14px 30px rgba(181,31,31,.26), 0 0 0 1px rgba(201,160,69,.14); }
.home-hero--cinematic .btn--outline { background: rgba(255,255,255,.08); border-color: rgba(246,217,132,.36); }

.page-hero--cinematic,
.page-hero {
  background:
    radial-gradient(circle at top right, rgba(181,31,31,.26), transparent 22rem),
    linear-gradient(135deg, #100B0E, #1C0F16 44%, #3A1515 100%);
}
.page-hero .lead { color: rgba(255,248,234,.85); }

.value-card,
.home-link-card,
.lodge-card,
.relation-card,
.notice-card,
.event-card,
.contact-card {
  position: relative;
  overflow: hidden;
}
.interactive-card::after {
  content: '';
  position: absolute; inset: -1px;
  background: radial-gradient(circle at var(--card-x, 50%) var(--card-y, 50%), rgba(201,160,69,.16), transparent 26%);
  pointer-events: none;
  opacity: 0;
  transition: opacity .28s ease;
}
.interactive-card:hover::after { opacity: 1; }

.lodge-grid--cinematic,
.relations-grid--cinematic { align-items: stretch; }
.lodge-card__image,
.relation-card__image {
  height: 190px;
  min-height: 190px;
  aspect-ratio: auto;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(246,240,226,.98));
  border: 1px solid rgba(201,160,69,.22);
  padding: 1.15rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.lodge-card__image img,
.relation-card__image img {
  width: auto;
  max-width: 100%;
  max-height: 150px;
  object-fit: contain;
  object-position: center;
  display: block;
}
.relations-grid { grid-template-columns: repeat(4, 1fr); }

.supreme-council-visual {
  min-height: 460px;
  padding: 1.8rem;
  background: radial-gradient(circle at top, rgba(201,160,69,.18), rgba(255,252,246,.98) 42%, rgba(246,240,226,.98) 100%);
  border: 1px solid rgba(201,160,69,.26);
  border-radius: 28px;
  box-shadow: 0 20px 45px rgba(0,0,0,.10), inset 0 1px 0 rgba(255,255,255,.6);
  display: flex;
  align-items: center;
  justify-content: center;
}
.supreme-council-visual img {
  max-width: min(420px, 100%);
  max-height: 520px;
  object-fit: contain;
  filter: drop-shadow(0 14px 30px rgba(0,0,0,.16));
}

.contact-grid--single-focus { grid-template-columns: .9fr 1.1fr; }
.contact-card h3 { color: var(--glj-red-dark); margin-top: 1.2rem; }
.contact-card h3:first-of-type { margin-top: 0; }
.form-status { margin-top: .85rem; color: var(--glj-red-dark); font-weight: 700; }

#site-footer {
  background: linear-gradient(180deg, #110B0E, #0A0709 100%);
  color: rgba(255,248,234,.78);
}
.footer-visual {
  position: relative;
  min-height: 280px;
  background-size: cover;
  background-position: center center;
  overflow: hidden;
}
.footer-visual__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(8,7,9,.20), rgba(8,7,9,.78));
}
.footer-visual__content {
  position: relative; z-index: 1;
  width: min(var(--max-w), calc(100% - 2.2rem));
  margin: 0 auto;
  padding: 5rem 0 3rem;
}
.footer-visual h3 {
  color: #fff;
  font-size: clamp(1.8rem, 3.4vw, 3rem);
  margin-bottom: .6rem;
}
.footer-visual p { color: rgba(255,248,234,.84); max-width: 640px; }
.footer-contact-note { color: rgba(255,248,234,.72); margin-top: .9rem; }
.footer-main { padding-top: 2.4rem; }
.footer-col ul { gap: .7rem; }
.footer-col a:hover { color: var(--glj-gold-soft); }

@media (max-width: 1050px) {
  .relations-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 760px) {
  .home-hero--cinematic .hero-crest { width: min(440px, 92vw); }
  .contact-grid--single-focus,
  .relations-grid,
  .lodge-grid,
  .home-links-grid,
  .home-values-grid { grid-template-columns: 1fr; }
  .footer-visual { min-height: 220px; }
  .footer-visual__content { padding: 4rem 0 2.2rem; }
}


/* ============================================================
   FINAL WOW REFINEMENT — GRAND CINEMATIC MASONIC EXPERIENCE
   ============================================================ */
:root {
  --cinema-black: #070507;
  --temple-black: #0D0809;
  --temple-red: #4E0E12;
  --temple-red-2: #7A1417;
  --royal-gold: #D8B75C;
  --royal-gold-light: #FFE7A1;
  --royal-gold-deep: #8F6C25;
  --smoke: rgba(255, 248, 234, .78);
}

body {
  background:
    radial-gradient(circle at 50% -10%, rgba(216,183,92,.14), transparent 28rem),
    radial-gradient(circle at 8% 10%, rgba(122,20,23,.24), transparent 24rem),
    linear-gradient(180deg, #110B0C 0, #F6F0E2 32rem);
}

/* Premium readable cinematic menu */
#site-header {
  background:
    linear-gradient(90deg, rgba(7,5,7,.92), rgba(28,10,12,.86), rgba(7,5,7,.92));
  border-bottom: 1px solid rgba(216,183,92,.32);
  box-shadow: 0 18px 50px rgba(0,0,0,.28);
}
#site-header::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -1px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,231,161,.7), transparent);
}
#site-header.scrolled {
  background:
    linear-gradient(90deg, rgba(7,5,7,.97), rgba(28,10,12,.94), rgba(7,5,7,.97));
}
.header-logo img {
  box-shadow: 0 0 0 1px rgba(216,183,92,.35), 0 8px 24px rgba(0,0,0,.35), 0 0 28px rgba(216,183,92,.15);
}
.header-logo-text,
.primary-nav a {
  color: var(--royal-gold-light) !important;
  text-shadow: 0 1px 1px rgba(0,0,0,.55);
}
.primary-nav a {
  border: 1px solid transparent;
}
.primary-nav a:hover,
.primary-nav .current-menu-item > a {
  background: linear-gradient(135deg, rgba(216,183,92,.18), rgba(122,20,23,.72));
  border-color: rgba(216,183,92,.34);
  color: #fff !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.05), 0 10px 22px rgba(0,0,0,.18);
}

/* Hero: temple, aura, cinematic reveal */
.home-hero--cinematic {
  min-height: 108vh;
  isolation: isolate;
  background:
    radial-gradient(circle at 50% 24%, rgba(216,183,92,.12), transparent 16rem),
    radial-gradient(circle at 50% 18%, rgba(122,20,23,.72), transparent 28rem),
    linear-gradient(180deg, #080607 0%, #11080A 58%, #090708 100%);
}
.home-hero--cinematic::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(0,0,0,.72) 0%, transparent 18%, transparent 82%, rgba(0,0,0,.72) 100%),
    linear-gradient(180deg, rgba(0,0,0,.26), transparent 44%, rgba(0,0,0,.54));
}
.home-hero--cinematic .hero-bg__cover {
  opacity: .16;
  filter: grayscale(.08) saturate(1.05) contrast(1.15) brightness(.54);
  transform: scale(1.08);
  animation: heroSlowZoom 22s ease-in-out infinite alternate;
}
@keyframes heroSlowZoom {
  from { transform: scale(1.05); }
  to { transform: scale(1.13); }
}
.home-hero--cinematic .hero-bg__rays {
  z-index: 1;
  opacity: .09;
  mix-blend-mode: screen;
}
.home-hero--cinematic .hero-bg__vignette {
  z-index: 1;
  background:
    radial-gradient(ellipse at 50% 26%, transparent 0, rgba(7,5,7,.22) 32%, rgba(7,5,7,.9) 86%);
}

/* Masonic architectural side pillars */
.home-hero--cinematic .hero-content::before,
.home-hero--cinematic .hero-content::after {
  content: '';
  position: absolute;
  top: 4%;
  bottom: 5%;
  width: min(9vw, 92px);
  opacity: .32;
  pointer-events: none;
  background:
    linear-gradient(180deg, transparent, rgba(216,183,92,.68) 8%, rgba(216,183,92,.25) 11%, transparent 14%),
    linear-gradient(180deg, transparent, rgba(216,183,92,.18), transparent),
    repeating-linear-gradient(180deg, rgba(255,231,161,.24) 0 1px, transparent 1px 22px);
  border-left: 1px solid rgba(216,183,92,.35);
  border-right: 1px solid rgba(216,183,92,.18);
}
.home-hero--cinematic .hero-content::before { left: max(-9vw, -105px); }
.home-hero--cinematic .hero-content::after { right: max(-9vw, -105px); }

.home-hero--cinematic .hero-crest {
  width: min(700px, 92vw);
  margin-bottom: .65rem;
  transform-origin: center;
  animation: crestEntrance 1.35s ease both, crestFloat 7s ease-in-out 1.35s infinite;
  filter:
    drop-shadow(0 24px 65px rgba(0,0,0,.55))
    drop-shadow(0 0 18px rgba(216,183,92,.20))
    drop-shadow(0 0 50px rgba(122,20,23,.18));
}
@keyframes crestEntrance {
  from { opacity: 0; transform: translateY(26px) scale(.96); filter: blur(3px) drop-shadow(0 0 0 rgba(0,0,0,0)); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes crestFloat {
  0%, 100% { transform: translateY(0) scale(1); }
  50% { transform: translateY(-10px) scale(1.01); }
}
.home-hero--cinematic .hero-title {
  letter-spacing: .015em;
  text-transform: none;
  text-shadow:
    0 4px 0 rgba(0,0,0,.18),
    0 16px 45px rgba(0,0,0,.50),
    0 0 26px rgba(216,183,92,.08);
}
.home-hero--cinematic .hero-title span {
  display: inline-block;
  color: var(--royal-gold-light);
  text-shadow: 0 0 24px rgba(216,183,92,.26);
}
.home-hero--cinematic .hero-subtitle {
  color: var(--royal-gold-light);
  text-shadow: 0 0 18px rgba(216,183,92,.20);
}
.home-hero--cinematic .hero-divider {
  height: 2px;
  width: min(340px, 62vw);
  background: linear-gradient(90deg, transparent, rgba(255,231,161,.95), rgba(122,20,23,.95), rgba(255,231,161,.95), transparent);
  box-shadow: 0 0 18px rgba(216,183,92,.22);
}
.home-hero--cinematic .hero-motto {
  font-size: clamp(1.03rem, 2.1vw, 1.32rem);
  color: rgba(255,248,234,.92);
}
.home-hero--cinematic .btn {
  border-radius: 0;
  clip-path: polygon(10px 0, 100% 0, calc(100% - 10px) 100%, 0 100%);
  position: relative;
  overflow: hidden;
}
.home-hero--cinematic .btn::after,
.btn--gold::after,
.btn--outline::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(115deg, transparent 0%, rgba(255,255,255,.36) 45%, transparent 62%);
  transform: translateX(-130%);
  transition: transform .65s ease;
}
.home-hero--cinematic .btn:hover::after,
.btn--gold:hover::after,
.btn--outline:hover::after { transform: translateX(130%); }

.masonic-stars {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
}
.masonic-star {
  position: absolute;
  width: 3px;
  height: 3px;
  border-radius: 999px;
  background: rgba(255,231,161,.78);
  box-shadow: 0 0 10px rgba(216,183,92,.65);
  animation: starPulse 3.5s ease-in-out infinite;
}
@keyframes starPulse {
  0%, 100% { opacity: .18; transform: scale(.75); }
  50% { opacity: .88; transform: scale(1.15); }
}

/* Section cinematography */
.section-dynamic {
  position: relative;
}
.section-dynamic::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at var(--mx, 50%) var(--my, 12%), rgba(216,183,92,.13), transparent 22rem),
    linear-gradient(180deg, transparent, rgba(255,255,255,.20));
  opacity: .85;
}
.content-section {
  background:
    radial-gradient(circle at 50% 0, rgba(216,183,92,.12), transparent 30rem),
    linear-gradient(180deg, #FFFDF7, #F6F0E2);
}
h2 {
  text-shadow: 0 1px 0 rgba(255,255,255,.65);
}
.title-bar {
  background: linear-gradient(90deg, var(--temple-red-2), var(--royal-gold-light), var(--royal-gold-deep));
  box-shadow: 0 0 18px rgba(216,183,92,.16);
}

/* Cards: luxury, normalized, more dramatic */
.value-card,
.home-link-card,
.lodge-card,
.relation-card,
.notice-card,
.event-card,
.contact-card {
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(250,244,232,.94));
  border: 1px solid rgba(143,108,37,.24);
  border-bottom-color: rgba(122,20,23,.18);
  border-radius: 20px;
  box-shadow:
    0 18px 36px rgba(25,10,10,.08),
    inset 0 1px 0 rgba(255,255,255,.8);
}
.value-card::before,
.home-link-card::before,
.lodge-card::before,
.relation-card::before,
.contact-card::before {
  content: '';
  position: absolute;
  top: 0; left: 1rem; right: 1rem;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(216,183,92,.65), transparent);
}
.value-card:hover,
.home-link-card:hover,
.lodge-card:hover,
.relation-card:hover {
  box-shadow:
    0 22px 52px rgba(25,10,10,.14),
    0 0 0 1px rgba(216,183,92,.22),
    inset 0 1px 0 rgba(255,255,255,.9);
}
.value-card__icon {
  background:
    radial-gradient(circle at 35% 25%, #fff, rgba(255,231,161,.78) 30%, rgba(143,108,37,.86) 100%);
  color: #3A1515;
  box-shadow: inset 0 1px 1px rgba(255,255,255,.62), 0 8px 18px rgba(143,108,37,.18);
}
.lodge-card__image,
.relation-card__image {
  height: 210px;
  min-height: 210px;
  background:
    radial-gradient(circle at center, #fff 0%, #fffaf0 54%, #efe3c8 100%);
}
.lodge-card__image img,
.relation-card__image img {
  max-height: 165px;
  max-width: 88%;
  filter: drop-shadow(0 8px 14px rgba(0,0,0,.10));
}
.lodge-card h3,
.relation-card h3 {
  min-height: 2.8em;
}
.meta-list {
  color: #5E514C;
}

/* Supreme Council: ceremonial panel */
.supreme-council-visual {
  min-height: 540px;
  border-radius: 32px;
  background:
    radial-gradient(circle at 50% 35%, rgba(255,231,161,.32), transparent 38%),
    radial-gradient(circle at 50% 50%, rgba(122,20,23,.10), transparent 62%),
    linear-gradient(180deg, #FFFDF7, #F2E4C6);
  border: 1px solid rgba(216,183,92,.36);
  box-shadow:
    0 24px 70px rgba(25,10,10,.16),
    inset 0 0 0 1px rgba(255,255,255,.55);
}
.supreme-council-visual::before {
  content: '';
  position: absolute;
  inset: 1rem;
  border: 1px solid rgba(143,108,37,.18);
  border-radius: 24px;
  pointer-events: none;
}
.supreme-council-visual img {
  max-width: min(480px, 100%);
  filter: drop-shadow(0 18px 42px rgba(0,0,0,.24));
}

/* Contact: keep form sovereign, no visible email */
.contact-grid--single-focus {
  align-items: stretch;
}
.contact-form input,
.contact-form textarea {
  background: rgba(255,255,255,.86);
  border-color: rgba(143,108,37,.26);
}
.contact-form input:focus,
.contact-form textarea:focus {
  outline: 2px solid rgba(216,183,92,.38);
  border-color: rgba(122,20,23,.32);
}

/* Footer: final cinematic scene */
.footer-visual {
  min-height: 380px;
  background-attachment: fixed;
  border-top: 1px solid rgba(216,183,92,.25);
  border-bottom: 1px solid rgba(216,183,92,.22);
}
.footer-visual__overlay {
  background:
    radial-gradient(circle at 50% 28%, rgba(216,183,92,.10), transparent 22rem),
    linear-gradient(180deg, rgba(7,5,7,.05), rgba(7,5,7,.86));
}
.footer-visual__content {
  padding-top: 7rem;
}
.footer-visual h3 {
  text-shadow: 0 14px 42px rgba(0,0,0,.55);
}
.footer-main {
  background:
    radial-gradient(circle at top, rgba(216,183,92,.08), transparent 34rem),
    linear-gradient(180deg, #110B0E, #080607);
}
.social-links a {
  border-color: rgba(216,183,92,.28);
  background: rgba(255,255,255,.04);
}
.social-links a:hover {
  background: rgba(216,183,92,.12);
  border-color: rgba(216,183,92,.55);
}

/* Mobile polish */
@media (max-width: 1050px) {
  .primary-nav {
    background: rgba(9,8,10,.97);
    border-color: rgba(216,183,92,.28);
  }
  .primary-nav ul { gap: .45rem; }
  .primary-nav a { justify-content: center; border-radius: 10px; }
}
@media (max-width: 760px) {
  .home-hero--cinematic {
    min-height: 100vh;
  }
  .home-hero--cinematic .hero-content::before,
  .home-hero--cinematic .hero-content::after { display: none; }
  .home-hero--cinematic .hero-crest {
    width: min(500px, 96vw);
  }
  .lodge-card__image,
  .relation-card__image {
    height: 190px;
    min-height: 190px;
  }
  .footer-visual {
    min-height: 280px;
    background-attachment: scroll;
  }
}


/* ============================================================
   VERSION 2.5 — ITALY PAGE / TRILINGUAL / LOGO CLEANUP
   ============================================================ */
.header-inner { gap: 1rem; }
.primary-nav { gap: .9rem; align-items: center; }
.primary-nav ul { flex-wrap: wrap; justify-content: flex-end; }
.lang-switcher { display:flex; align-items:center; gap:.3rem; margin-left:1rem; }
.lang-switcher a { display:inline-flex; align-items:center; justify-content:center; min-width:48px; padding:.42rem .58rem; border-radius:999px; border:1px solid rgba(216,183,92,.28); color:#F6E7BE; font-family:var(--font-heading); font-size:.6rem; letter-spacing:.18em; text-transform:uppercase; }
.lang-switcher a.is-active, .lang-switcher a:hover { background:rgba(216,183,92,.14); color:#fff; border-color:rgba(255,231,161,.42); }
.social-links { display:flex; flex-wrap:wrap; gap:.65rem; }
.social-links a { display:inline-flex; align-items:center; justify-content:center; padding:.65rem .95rem; border:1px solid rgba(216,183,92,.22); border-radius:999px; }

.lodge-card__image,
.relation-card__image {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: .8rem 1rem !important;
}
.lodge-card__image img,
.relation-card__image img {
  mix-blend-mode: multiply;
  isolation: isolate;
  background: transparent;
}

.italy-visual-card { min-height: 420px; }
.italy-highlights { margin:1rem 0 0 1.1rem; padding:0; }
.italy-highlights li { margin:0 0 .6rem 0; color:#4D4340; }

@media (max-width: 1050px) {
  .lang-switcher { width:100%; justify-content:center; margin: .5rem 0 0; }
}
@media (max-width: 760px) {
  .lang-switcher { gap:.4rem; }
  .lang-switcher a { min-width: 46px; }
}


/* ============================================================
   VERSION 2.6 — ULTRA PREMIUM FINAL REFINEMENT
   ============================================================ */
.lang-switcher a:first-child { box-shadow: 0 0 18px rgba(216,183,92,.08); }
.italy-page { background: linear-gradient(180deg, #0B0708 0, #F6F0E2 38rem); }
.italy-hero-premium {
  min-height: 86vh;
  display: grid;
  align-items: center;
  background:
    radial-gradient(circle at 78% 18%, rgba(216,183,92,.20), transparent 18rem),
    radial-gradient(circle at 18% 20%, rgba(122,20,23,.38), transparent 20rem),
    linear-gradient(135deg, #080607 0%, #1B0D10 52%, #3A1515 100%);
  overflow: hidden;
}
.italy-hero-premium::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(0,0,0,.62), transparent 30%, transparent 70%, rgba(0,0,0,.62)),
    repeating-linear-gradient(90deg, rgba(216,183,92,.035) 0 1px, transparent 1px 90px);
}
.italy-hero-grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(320px, 1.05fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}
.italy-hero-text h1 { color: #fff; text-shadow: 0 18px 45px rgba(0,0,0,.42); }
.italy-hero-text .lead { color: rgba(255,248,234,.86); }
.italy-motto {
  font-family: var(--font-heading);
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--royal-gold-light, #FFE7A1);
  font-size: .78rem;
  margin-top: 1rem;
}
.italy-divider { width: min(360px, 70vw); height: 1px; background: linear-gradient(90deg, transparent, #FFE7A1, #7A1417, #FFE7A1, transparent); margin: 1.4rem 0 0; }
.italy-hero-seals {
  position: relative;
  min-height: 520px;
  display: grid;
  place-items: center;
}
.italy-hero-seals::before {
  content: '';
  position: absolute;
  width: min(520px, 80vw);
  aspect-ratio: 1;
  border-radius: 50%;
  border: 1px solid rgba(216,183,92,.28);
  box-shadow: 0 0 80px rgba(216,183,92,.08), inset 0 0 70px rgba(216,183,92,.06);
}
.italy-hero-seals img {
  position: absolute;
  object-fit: contain;
  filter: drop-shadow(0 20px 45px rgba(0,0,0,.42));
}
.italy-hero-seals img:first-child { width: min(420px, 68vw); transform: translate(-12%, -2%); z-index: 2; }
.italy-hero-seals img:nth-child(2) { width: min(360px, 58vw); transform: translate(28%, 18%); opacity: .96; z-index: 1; }
.italy-section-premium { position: relative; }
.italy-section-premium::after {
  content: '';
  position: absolute;
  inset: auto 0 0 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(216,183,92,.55), transparent);
}
.italy-council-band {
  background:
    radial-gradient(circle at 18% 20%, rgba(122,20,23,.13), transparent 22rem),
    linear-gradient(180deg, #F6F0E2, #FFFDF7);
}
.italy-emblem-card {
  position: relative;
  min-height: 520px;
  display: grid;
  place-items: center;
  padding: 2rem;
  background:
    radial-gradient(circle at center, rgba(255,231,161,.25), transparent 34%),
    linear-gradient(145deg, rgba(255,255,255,.96), rgba(239,228,201,.94));
  border: 1px solid rgba(216,183,92,.34);
  border-radius: 32px;
  box-shadow: 0 26px 76px rgba(25,10,10,.16), inset 0 1px 0 rgba(255,255,255,.72);
  overflow: hidden;
}
.italy-emblem-card::before {
  content: '';
  position: absolute;
  inset: 1rem;
  border: 1px solid rgba(143,108,37,.20);
  border-radius: 24px;
  pointer-events: none;
}
.italy-emblem-card::after {
  content: '';
  position: absolute;
  width: 70%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(216,183,92,.16), transparent 68%);
  pointer-events: none;
}
.italy-emblem-card img {
  position: relative;
  z-index: 1;
  max-width: min(500px, 100%);
  max-height: 500px;
  object-fit: contain;
  filter: drop-shadow(0 18px 42px rgba(0,0,0,.18));
}
.italy-emblem-card--council img { max-width: min(560px, 100%); max-height: 560px; }
.italy-highlights {
  list-style: none;
  margin: 1.6rem 0 0;
  padding: 0;
  display: grid;
  gap: .8rem;
}
.italy-highlights li {
  position: relative;
  padding-left: 1.6rem;
  color: #4D4340;
  font-size: 1.05rem;
}
.italy-highlights li::before {
  content: '✦';
  position: absolute;
  left: 0;
  color: #8F6C25;
}
.italy-values-final .value-card { min-height: 100%; }

/* force transparent-looking logo areas after previous refinements */
.lodge-card__image,
.relation-card__image {
  background: radial-gradient(circle at center, rgba(255,255,255,.38), transparent 66%) !important;
  border: 0 !important;
  box-shadow: none !important;
}
.lodge-card__image img,
.relation-card__image img {
  mix-blend-mode: multiply;
  filter: drop-shadow(0 10px 20px rgba(0,0,0,.10));
}

@media (max-width: 1050px) {
  .italy-hero-grid { grid-template-columns: 1fr; text-align: center; }
  .italy-divider { margin-left:auto; margin-right:auto; }
  .italy-hero-seals { min-height: 460px; }
  .italy-hero-seals img:first-child { transform: translate(-8%, -4%); }
  .italy-hero-seals img:nth-child(2) { transform: translate(22%, 22%); }
}
@media (max-width: 760px) {
  .italy-hero-premium { min-height: auto; padding-top: 9rem; }
  .italy-hero-seals { min-height: 390px; }
  .italy-hero-seals img:first-child { width: min(330px, 84vw); }
  .italy-hero-seals img:nth-child(2) { width: min(280px, 72vw); }
  .italy-emblem-card { min-height: 360px; padding: 1.2rem; }
  .italy-emblem-card img { max-height: 360px; }
}


/* ============================================================
   VERSION 2.6 — STAINED GLASS HOME / ONE-LINE MENU / PREMIUM CONTENT
   ============================================================ */
@media (min-width: 1181px) {
  .header-inner {
    width: min(1680px, calc(100% - 1.2rem));
    gap: .55rem;
    padding: .46rem 0;
  }
  .header-logo { gap: .48rem; flex: 0 0 auto; }
  .header-logo img { width: 44px; height: 44px; }
  .header-logo-text { font-size: .58rem; max-width: 180px; letter-spacing: .06em; }
  .header-logo-text small { font-size: .46rem; letter-spacing: .12em; }
  .primary-nav {
    min-width: 0;
    flex: 1 1 auto;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: .45rem;
    overflow: visible;
  }
  .primary-nav ul {
    flex-wrap: nowrap !important;
    white-space: nowrap;
    gap: .12rem;
  }
  .primary-nav a {
    padding: .42rem .46rem;
    font-size: .54rem;
    letter-spacing: .06em;
    line-height: 1;
  }
  .lang-switcher {
    flex: 0 0 auto;
    display: flex;
    gap: .18rem;
    margin-left: .22rem;
    white-space: nowrap;
  }
  .lang-switcher a {
    min-width: 40px;
    padding: .38rem .42rem;
    font-size: .52rem;
    letter-spacing: .08em;
  }
}
@media (min-width: 1440px) {
  .primary-nav a { padding: .48rem .62rem; font-size: .58rem; letter-spacing: .08em; }
  .lang-switcher a { min-width: 45px; font-size: .55rem; }
  .header-logo-text { max-width: none; font-size: .64rem; }
}

.home-hero--cinematic .hero-bg__cover {
  background-position: center top !important;
  opacity: .42 !important;
  filter: saturate(1.16) contrast(1.18) brightness(.50) !important;
  transform: scale(1.06);
}
.home-hero--cinematic::before {
  background:
    radial-gradient(circle at 50% 18%, rgba(216,183,92,.16), transparent 16rem),
    linear-gradient(180deg, rgba(6,5,7,.34), rgba(7,5,7,.88) 78%) !important;
}
.home-hero--cinematic .hero-content {
  backdrop-filter: none;
}
.home-hero--cinematic .hero-crest {
  width: min(620px, 86vw);
}
.home-hero--cinematic .hero-title {
  text-shadow: 0 4px 0 rgba(0,0,0,.25), 0 20px 60px rgba(0,0,0,.72), 0 0 24px rgba(216,183,92,.12);
}
.home-hero--cinematic .hero-motto {
  background: linear-gradient(90deg, transparent, rgba(0,0,0,.32), transparent);
  padding: .45rem 1rem;
  border-top: 1px solid rgba(216,183,92,.14);
  border-bottom: 1px solid rgba(216,183,92,.14);
}

.about-premium .quote-panel,
.supreme-premium .quote-panel {
  border: 1px solid rgba(216,183,92,.25);
}
.about-intro-grid { align-items: stretch; }
.about-intro-grid .quote-panel,
.about-intro-grid .text-block {
  min-height: 100%;
}
.about-longform {
  max-width: 1040px;
}
.about-section {
  position: relative;
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(250,244,232,.94));
  border: 1px solid rgba(143,108,37,.20);
  border-left: 4px solid var(--glj-gold);
  border-radius: 22px;
  padding: clamp(1.5rem, 3vw, 2.35rem);
  margin-bottom: 1.2rem;
  box-shadow: 0 18px 36px rgba(25,10,10,.07), inset 0 1px 0 rgba(255,255,255,.84);
  overflow: hidden;
}
.about-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 0 0, rgba(216,183,92,.16), transparent 18rem);
  pointer-events: none;
}
.about-section h2 {
  color: var(--glj-red-dark);
  margin-bottom: .8rem;
}
.about-section p { position: relative; z-index: 1; }

.supreme-premium .text-block {
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(250,244,232,.94));
  border: 1px solid rgba(143,108,37,.20);
  border-radius: 24px;
  padding: clamp(1.4rem, 3vw, 2.2rem);
  box-shadow: 0 18px 36px rgba(25,10,10,.07);
}
.supreme-premium blockquote {
  background: linear-gradient(135deg, rgba(107,26,26,.08), rgba(216,183,92,.15));
  border-left: 4px solid var(--glj-gold);
  border-radius: 16px;
  padding: 1.2rem 1.35rem;
  color: var(--glj-red-dark);
  font-weight: 700;
}

@media (max-width: 1180px) {
  .primary-nav.open { overflow-y: auto; max-height: calc(100vh - 100px); }
}


/* ============================================================
   VERSION 2.6.1 — MOBILE MENU & LANGUAGE SWITCHER FIX
   ============================================================ */
.header-lang-switcher {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  gap: .24rem;
  margin-left: .35rem;
  white-space: nowrap;
  z-index: 720;
}
.header-lang-switcher a {
  min-width: 42px;
  padding: .38rem .48rem;
  line-height: 1;
}

@media (min-width: 1181px) {
  .primary-nav .lang-switcher { display: none !important; }
  .header-lang-switcher { margin-left: .25rem !important; }
}

@media (max-width: 1180px) {
  #site-header {
    background: linear-gradient(90deg, rgba(7,5,7,.97), rgba(32,10,13,.94), rgba(7,5,7,.97)) !important;
  }
  .header-inner {
    width: min(100%, calc(100% - 1rem)) !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto auto !important;
    align-items: center !important;
    gap: .55rem !important;
    padding: .55rem 0 !important;
  }
  .header-logo {
    min-width: 0 !important;
    overflow: hidden !important;
  }
  .header-logo img {
    width: 46px !important;
    height: 46px !important;
    flex: 0 0 auto !important;
  }
  .header-logo-text {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    font-size: .62rem !important;
    line-height: 1.12 !important;
  }
  .header-logo-text span {
    display: block !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }
  .header-logo-text small {
    font-size: .48rem !important;
  }

  .header-lang-switcher {
    grid-column: 2 !important;
    grid-row: 1 !important;
    display: inline-flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: .22rem !important;
    margin: 0 !important;
    width: auto !important;
    padding: .18rem !important;
    border: 1px solid rgba(216,183,92,.22) !important;
    border-radius: 999px !important;
    background: rgba(255,255,255,.06) !important;
    box-shadow: 0 8px 20px rgba(0,0,0,.18) !important;
  }
  .header-lang-switcher a {
    min-width: 38px !important;
    padding: .42rem .42rem !important;
    border-radius: 999px !important;
    font-size: .55rem !important;
    letter-spacing: .08em !important;
    color: #F6E7BE !important;
    border: 0 !important;
  }
  .header-lang-switcher a.is-active {
    background: linear-gradient(135deg, rgba(216,183,92,.30), rgba(107,26,26,.42)) !important;
    color: #fff !important;
  }

  .menu-toggle {
    grid-column: 3 !important;
    grid-row: 1 !important;
    display: inline-flex !important;
    width: 46px !important;
    height: 46px !important;
    border: 1px solid rgba(216,183,92,.28) !important;
    background: rgba(255,255,255,.08) !important;
    box-shadow: 0 8px 24px rgba(0,0,0,.22) !important;
    z-index: 730 !important;
  }
  .menu-toggle span { background: #F6E7BE !important; }

  .primary-nav {
    position: fixed !important;
    top: 72px !important;
    left: .75rem !important;
    right: .75rem !important;
    inset: 72px .75rem auto .75rem !important;
    display: none !important;
    max-height: calc(100vh - 92px) !important;
    overflow-y: auto !important;
    padding: .85rem !important;
    border-radius: 22px !important;
    background:
      radial-gradient(circle at top, rgba(216,183,92,.12), transparent 16rem),
      linear-gradient(180deg, rgba(12,8,9,.98), rgba(25,10,12,.98)) !important;
    border: 1px solid rgba(216,183,92,.30) !important;
    box-shadow: 0 28px 70px rgba(0,0,0,.42), inset 0 1px 0 rgba(255,255,255,.06) !important;
    z-index: 680 !important;
    backdrop-filter: blur(16px) !important;
  }
  .primary-nav.open {
    display: block !important;
  }
  .primary-nav ul {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: .42rem !important;
    align-items: stretch !important;
    justify-content: stretch !important;
    flex-direction: initial !important;
    flex-wrap: initial !important;
    white-space: normal !important;
    padding: 0 !important;
    margin: 0 !important;
  }
  .primary-nav li { width: 100% !important; }
  .primary-nav a {
    width: 100% !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: .86rem .95rem !important;
    border-radius: 14px !important;
    border: 1px solid rgba(216,183,92,.16) !important;
    background: rgba(255,255,255,.055) !important;
    color: #F6E7BE !important;
    font-size: .78rem !important;
    letter-spacing: .13em !important;
    line-height: 1.15 !important;
    text-align: left !important;
    text-shadow: none !important;
  }
  .primary-nav a::after {
    content: '›' !important;
    position: static !important;
    width: auto !important;
    height: auto !important;
    background: transparent !important;
    color: rgba(255,231,161,.75) !important;
    font-size: 1.1rem !important;
    transform: none !important;
  }
  .primary-nav a:hover,
  .primary-nav .current-menu-item > a {
    background: linear-gradient(135deg, rgba(216,183,92,.18), rgba(107,26,26,.62)) !important;
    border-color: rgba(216,183,92,.35) !important;
    color: #fff !important;
  }
}

@media (max-width: 560px) {
  .header-inner {
    width: min(100%, calc(100% - .75rem)) !important;
    grid-template-columns: minmax(0, 1fr) auto auto !important;
    gap: .38rem !important;
  }
  .header-logo img { width: 42px !important; height: 42px !important; }
  .header-logo-text { display: none !important; }
  .header-lang-switcher { gap: .1rem !important; padding: .14rem !important; }
  .header-lang-switcher a {
    min-width: 34px !important;
    padding: .39rem .34rem !important;
    font-size: .50rem !important;
    letter-spacing: .05em !important;
  }
  .menu-toggle { width: 42px !important; height: 42px !important; }
  .primary-nav {
    top: 64px !important;
    inset: 64px .55rem auto .55rem !important;
    padding: .7rem !important;
    border-radius: 18px !important;
  }
  .primary-nav a {
    padding: .78rem .82rem !important;
    font-size: .70rem !important;
    letter-spacing: .10em !important;
  }
}


/* ============================================================
   VERSION 2.7.0 — REAL FR LANGUAGE + MOBILE CSS HARD FIX
   ============================================================ */
@media (min-width: 1181px) {
  .header-inner {
    width: min(1480px, calc(100% - 1.4rem)) !important;
    display: flex !important;
    align-items: center !important;
    gap: .55rem !important;
  }
  .header-logo { max-width: 260px !important; flex: 0 1 260px !important; }
  .header-logo img { width: 50px !important; height: 50px !important; }
  .header-logo-text { font-size: .62rem !important; }
  .primary-nav { flex: 1 1 auto !important; min-width: 0 !important; display: flex !important; justify-content: center !important; position: static !important; background: transparent !important; border: 0 !important; box-shadow: none !important; padding: 0 !important; }
  .primary-nav ul { display: flex !important; flex-wrap: nowrap !important; align-items: center !important; justify-content: center !important; gap: .12rem !important; white-space: nowrap !important; }
  .primary-nav a { padding: .46rem .48rem !important; font-size: .56rem !important; letter-spacing: .055em !important; white-space: nowrap !important; }
  .header-lang-switcher { flex: 0 0 auto !important; display: inline-flex !important; margin-left: .2rem !important; }
  .header-lang-switcher a { min-width: 40px !important; padding: .36rem .42rem !important; font-size: .52rem !important; }
  .menu-toggle { display: none !important; }
}

@media (max-width: 1180px) {
  html, body { overflow-x: hidden !important; }
  #site-header {
    min-height: 64px !important;
    background: linear-gradient(90deg, rgba(7,5,7,.98), rgba(38,10,14,.96), rgba(7,5,7,.98)) !important;
    border-bottom: 1px solid rgba(216,183,92,.32) !important;
  }
  .header-inner {
    width: calc(100% - .8rem) !important;
    margin: 0 auto !important;
    padding: .45rem 0 !important;
    display: grid !important;
    grid-template-columns: minmax(42px, 1fr) auto auto !important;
    grid-template-areas: "brand lang toggle" !important;
    align-items: center !important;
    gap: .42rem !important;
  }
  .header-logo { grid-area: brand !important; min-width: 0 !important; max-width: 100% !important; overflow: hidden !important; display: flex !important; }
  .header-logo img { width: 44px !important; height: 44px !important; flex: 0 0 44px !important; }
  .header-logo-text { min-width: 0 !important; font-size: .58rem !important; line-height: 1.1 !important; overflow: hidden !important; }
  .header-logo-text span, .header-logo-text small { display: block !important; white-space: nowrap !important; overflow: hidden !important; text-overflow: ellipsis !important; }

  .header-lang-switcher {
    grid-area: lang !important;
    position: static !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: .18rem !important;
    width: auto !important;
    margin: 0 !important;
    padding: .15rem !important;
    border-radius: 999px !important;
    border: 1px solid rgba(216,183,92,.35) !important;
    background: rgba(255,255,255,.075) !important;
    z-index: 1002 !important;
    white-space: nowrap !important;
  }
  .header-lang-switcher a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 38px !important;
    width: 38px !important;
    height: 32px !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    border-radius: 999px !important;
    color: #F6E7BE !important;
    font-size: .52rem !important;
    font-weight: 700 !important;
    letter-spacing: .04em !important;
    line-height: 1 !important;
    text-align: center !important;
  }
  .header-lang-switcher a.is-active,
  .header-lang-switcher a:hover {
    background: linear-gradient(135deg, rgba(216,183,92,.32), rgba(107,26,26,.58)) !important;
    color: #fff !important;
  }

  .menu-toggle {
    grid-area: toggle !important;
    position: static !important;
    display: inline-flex !important;
    width: 44px !important;
    height: 44px !important;
    align-items: center !important;
    justify-content: center !important;
    flex-direction: column !important;
    gap: 5px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(216,183,92,.35) !important;
    background: rgba(255,255,255,.075) !important;
    box-shadow: 0 10px 24px rgba(0,0,0,.26) !important;
    z-index: 1002 !important;
  }
  .menu-toggle span { width: 18px !important; height: 2px !important; background: #F6E7BE !important; display: block !important; }

  .primary-nav {
    position: fixed !important;
    top: 66px !important;
    left: .65rem !important;
    right: .65rem !important;
    bottom: auto !important;
    width: auto !important;
    max-height: calc(100svh - 82px) !important;
    overflow: auto !important;
    display: none !important;
    padding: .72rem !important;
    border-radius: 20px !important;
    background: linear-gradient(180deg, rgba(10,7,8,.99), rgba(36,11,14,.99)) !important;
    border: 1px solid rgba(216,183,92,.36) !important;
    box-shadow: 0 28px 70px rgba(0,0,0,.48), inset 0 1px 0 rgba(255,255,255,.07) !important;
    backdrop-filter: blur(18px) !important;
    z-index: 999 !important;
  }
  .primary-nav.open { display: block !important; }
  .primary-nav ul {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: .42rem !important;
    padding: 0 !important;
    margin: 0 !important;
    list-style: none !important;
    white-space: normal !important;
  }
  .primary-nav li { width: 100% !important; margin: 0 !important; padding: 0 !important; }
  .primary-nav a {
    width: 100% !important;
    min-height: 46px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: .78rem .86rem !important;
    border-radius: 14px !important;
    border: 1px solid rgba(216,183,92,.18) !important;
    background: rgba(255,255,255,.06) !important;
    color: #F6E7BE !important;
    font-size: .72rem !important;
    letter-spacing: .10em !important;
    line-height: 1.18 !important;
    text-align: left !important;
    text-shadow: none !important;
    box-shadow: none !important;
  }
  .primary-nav a::after {
    content: '›' !important;
    position: static !important;
    display: inline-block !important;
    width: auto !important;
    height: auto !important;
    background: transparent !important;
    color: rgba(255,231,161,.78) !important;
    font-size: 1.15rem !important;
    line-height: 1 !important;
    transform: none !important;
  }
  .primary-nav a:hover,
  .primary-nav .current-menu-item > a {
    background: linear-gradient(135deg, rgba(216,183,92,.18), rgba(107,26,26,.70)) !important;
    border-color: rgba(216,183,92,.42) !important;
    color: #fff !important;
  }
}

@media (max-width: 520px) {
  .header-inner { width: calc(100% - .55rem) !important; gap: .25rem !important; grid-template-columns: minmax(34px, 1fr) auto auto !important; }
  .header-logo img { width: 40px !important; height: 40px !important; flex-basis: 40px !important; }
  .header-logo-text { display: none !important; }
  .header-lang-switcher { gap: .08rem !important; padding: .12rem !important; }
  .header-lang-switcher a { min-width: 34px !important; width: 34px !important; height: 30px !important; font-size: .48rem !important; }
  .menu-toggle { width: 40px !important; height: 40px !important; }
  .primary-nav { top: 60px !important; left: .45rem !important; right: .45rem !important; max-height: calc(100svh - 74px) !important; padding: .6rem !important; border-radius: 18px !important; }
  .primary-nav a { min-height: 44px !important; padding: .72rem .78rem !important; font-size: .68rem !important; letter-spacing: .085em !important; }
}


/* ============================================================
   VERSION 2.7.1 — MOBILE FOOTER HARD FIX
   ============================================================ */
@media (max-width: 900px) {
  #site-footer,
  #site-footer * {
    box-sizing: border-box !important;
  }
  #site-footer {
    width: 100% !important;
    max-width: 100vw !important;
    overflow-x: hidden !important;
  }
  .footer-visual {
    width: 100% !important;
    min-height: 260px !important;
    background-attachment: scroll !important;
    background-size: cover !important;
    background-position: center center !important;
    display: flex !important;
    align-items: flex-end !important;
    overflow: hidden !important;
  }
  .footer-visual__overlay {
    position: absolute !important;
    inset: 0 !important;
    background:
      radial-gradient(circle at 50% 18%, rgba(216,183,92,.16), transparent 16rem),
      linear-gradient(180deg, rgba(7,5,7,.18), rgba(7,5,7,.92)) !important;
  }
  .footer-visual__content {
    position: relative !important;
    z-index: 2 !important;
    width: calc(100% - 2rem) !important;
    max-width: none !important;
    margin: 0 auto !important;
    padding: 4.2rem 0 2rem !important;
    text-align: left !important;
  }
  .footer-visual__content .eyebrow {
    display: flex !important;
    align-items: center !important;
    gap: .55rem !important;
    max-width: 100% !important;
    overflow-wrap: anywhere !important;
  }
  .footer-visual h3 {
    font-size: clamp(1.55rem, 8vw, 2.3rem) !important;
    line-height: 1.05 !important;
    margin: .55rem 0 .65rem !important;
    max-width: 100% !important;
    overflow-wrap: anywhere !important;
  }
  .footer-visual p {
    max-width: 100% !important;
    font-size: 1rem !important;
    line-height: 1.55 !important;
    margin: 0 !important;
  }
  .footer-main {
    width: calc(100% - 1.6rem) !important;
    max-width: none !important;
    margin: 0 auto !important;
    padding: 2rem 0 1.6rem !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 1rem !important;
    background: transparent !important;
  }
  .footer-brand,
  .footer-col {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    padding: 1.05rem !important;
    border: 1px solid rgba(216,183,92,.16) !important;
    border-radius: 18px !important;
    background: rgba(255,255,255,.045) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.05) !important;
  }
  .footer-brand {
    display: grid !important;
    grid-template-columns: 56px 1fr !important;
    column-gap: .9rem !important;
    row-gap: .7rem !important;
    align-items: start !important;
  }
  .footer-brand img {
    width: 56px !important;
    height: 56px !important;
    grid-row: span 2 !important;
  }
  .footer-brand p {
    margin: 0 !important;
    font-size: .96rem !important;
    line-height: 1.45 !important;
    min-width: 0 !important;
    overflow-wrap: anywhere !important;
  }
  .footer-contact-note {
    grid-column: 1 / -1 !important;
    margin-top: .25rem !important;
  }
  .footer-brand .social-links {
    grid-column: 1 / -1 !important;
  }
  .footer-col h4 {
    margin: 0 0 .75rem !important;
    color: #FFE7A1 !important;
    font-size: .82rem !important;
    letter-spacing: .16em !important;
  }
  .footer-col ul {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: .45rem !important;
  }
  .footer-col li {
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1.45 !important;
    overflow-wrap: anywhere !important;
  }
  .footer-col a,
  .footer-col li,
  .footer-brand p,
  .footer-contact-note {
    font-size: .96rem !important;
  }
  .footer-col a {
    width: 100% !important;
    min-height: 42px !important;
    display: flex !important;
    align-items: center !important;
    padding: .68rem .78rem !important;
    border-radius: 12px !important;
    background: rgba(255,255,255,.055) !important;
    border: 1px solid rgba(216,183,92,.12) !important;
    color: #F6E7BE !important;
    text-decoration: none !important;
  }
  .social-links {
    width: 100% !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: .55rem !important;
  }
  .social-links a {
    width: 100% !important;
    min-height: 44px !important;
    border-radius: 12px !important;
    padding: .72rem .9rem !important;
    justify-content: center !important;
    text-align: center !important;
    color: #F6E7BE !important;
  }
  .footer-bottom {
    width: calc(100% - 1.6rem) !important;
    max-width: none !important;
    margin: 0 auto !important;
    padding: 1rem 0 1.25rem !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: .45rem !important;
    text-align: center !important;
    border-top: 1px solid rgba(216,183,92,.14) !important;
  }
  .footer-bottom p {
    margin: 0 !important;
    font-size: .78rem !important;
    line-height: 1.45 !important;
    overflow-wrap: anywhere !important;
  }
}

@media (max-width: 420px) {
  .footer-visual { min-height: 230px !important; }
  .footer-visual__content { width: calc(100% - 1.35rem) !important; padding: 3.4rem 0 1.6rem !important; }
  .footer-main, .footer-bottom { width: calc(100% - 1rem) !important; }
  .footer-brand, .footer-col { padding: .9rem !important; border-radius: 16px !important; }
  .footer-brand { grid-template-columns: 48px 1fr !important; column-gap: .75rem !important; }
  .footer-brand img { width: 48px !important; height: 48px !important; }
  .footer-col a { min-height: 40px !important; padding: .62rem .7rem !important; }
}
