/* ═══════════════════════════════════════════════════════
   RENSEI KARATE AUSTRALIA
   Design System: Bushido Modernism
   Cinematic · Editorial · Disciplined
═══════════════════════════════════════════════════════ */

/* ─── Reset ───────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* Surface scale */
  --black:       #0e0e0e;
  --dark:        #131313;
  --surface:     #1c1b1b;
  --surface2:    #201f1f;
  --surface3:    #2a2a2a;
  --border:      #5d3f3d;
  --border2:     #2a2929;

  /* Brand colours */
  --red:         #d90429;
  --red-h:       #f0002e;
  --red-dim:     rgba(217,4,41,.18);
  --gold:        #e9c176;
  --gold-h:      #f5d78e;
  --gold-dim:    rgba(233,193,118,.18);

  /* Text */
  --white:       #e5e2e1;
  --gray:        #ae8885;
  --gray-warm:   #e7bcba;

  /* Fonts */
  --font-h: 'Oswald', sans-serif;
  --font-b: 'Open Sans', sans-serif;

  /* Layout */
  --nav-h:       76px;
  --max-w:       1280px;
  --pad:         clamp(20px, 5vw, 64px);
  --section-pad: clamp(72px, 10vw, 128px);
  --radius:      0px;
  --ease:        0.25s ease;
}

html { scroll-behavior: smooth; }

body {
  background: var(--dark);
  color: var(--white);
  font-family: var(--font-b);
  font-size: 16px;
  line-height: 1.65;
  overflow-x: hidden;
  animation: pg-in 0.2s ease both;
}
@keyframes pg-in { from { opacity: 0; } to { opacity: 1; } }

img { max-width: 100%; height: auto; display: block; }
a   { color: inherit; text-decoration: none; }

/* ─── Scroll reveal ───────────────────────────────────── */
.reveal       { opacity: 0; transform: translateY(28px); transition: opacity 0.65s ease, transform 0.65s ease; }
.reveal.in    { opacity: 1; transform: translateY(0); }
.reveal-left  { opacity: 0; transform: translateX(-28px); transition: opacity 0.65s ease, transform 0.65s ease; }
.reveal-left.in  { opacity: 1; transform: translateX(0); }
.reveal-right { opacity: 0; transform: translateX(28px);  transition: opacity 0.65s ease, transform 0.65s ease; }
.reveal-right.in { opacity: 1; transform: translateX(0); }
.reveal-d1 { transition-delay: 0.1s; }
.reveal-d2 { transition-delay: 0.2s; }
.reveal-d3 { transition-delay: 0.3s; }
.reveal-d4 { transition-delay: 0.4s; }
@media (prefers-reduced-motion: reduce) {
  .reveal,.reveal-left,.reveal-right { opacity:1; transform:none; transition:none; }
}

/* ─── Typography ──────────────────────────────────────── */
h1,h2,h3,h4 {
  font-family: var(--font-h);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  line-height: 1.1;
}
h1 { font-size: clamp(2.6rem,7vw,5.25rem); letter-spacing: -0.01em; }
h2 { font-size: clamp(1.9rem,4vw,3rem); }
h3 { font-size: 1.45rem; }
h4 { font-size: 1.1rem; }

.eyebrow {
  display: block; font-family: var(--font-h); font-size: 0.72rem;
  letter-spacing: 0.3em; text-transform: uppercase; color: var(--gold); margin-bottom: 12px;
}
.eyebrow.center { text-align: center; }
.text-center    { text-align: center; }

/* Notched accent divider */
.accent-line { display: flex; align-items: center; margin: 16px 0; }
.accent-line::before { content:''; display:block; width:48px; height:3px; background:var(--red); }
.accent-line::after  { content:''; display:block; width:8px;  height:3px; background:var(--gold); margin-left:4px; }
.accent-line.center  { justify-content: center; margin: 16px auto; }

.ic { width:16px; height:16px; flex-shrink:0; vertical-align:middle; margin-top:1px; }

/* ─── Layout ──────────────────────────────────────────── */
.wrap { max-width: var(--max-w); margin: 0 auto; padding: 0 var(--pad); }
section { padding: var(--section-pad) var(--pad); }
.bg-dark    { background: var(--black); }
.bg-surface { background: var(--surface); }

.about-grid   { display:grid; grid-template-columns:1fr 1fr;   gap:64px; align-items:center; }
.two-col      { display:grid; grid-template-columns:1fr 1fr;   gap:52px; align-items:start; }
.bio-grid     { display:grid; grid-template-columns:1fr 1.4fr; gap:64px; align-items:start; }
.contact-grid { display:grid; grid-template-columns:1fr 1fr;   gap:56px; align-items:start; }
.form-row     { display:grid; grid-template-columns:1fr 1fr;   gap:16px; }
.grid-2       { display:grid; grid-template-columns:repeat(2,1fr); gap:28px; }
.grid-3       { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.about-img    { height:520px; overflow:hidden; background:var(--surface); position:relative; }

/* ─── Clip-path shapes ────────────────────────────────── */
.clip-diagonal     { clip-path: polygon(0 0,100% 0,100% 88%,0 100%); padding-bottom:calc(8vw + 80px) !important; }
.clip-diagonal-rev { clip-path: polygon(0 12%,100% 0,100% 100%,0 100%); padding-top:calc(8vw + 80px) !important; }
.clip-corner       { clip-path: polygon(0 0,calc(100% - 15px) 0,100% 15px,100% 100%,0 100%); }

/* ─── Buttons ─────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:14px 32px; font-family:var(--font-h); font-size:0.82rem; font-weight:600;
  text-transform:uppercase; letter-spacing:0.12em;
  border:2px solid transparent; cursor:pointer; white-space:nowrap;
  transition:all var(--ease); border-radius:var(--radius);
}
.btn-red   { background:var(--red);  color:#fff; border-color:var(--red); }
.btn-red:hover   { background:var(--red-h); border-color:var(--red-h); transform:translateY(-2px); box-shadow:0 8px 24px rgba(217,4,41,.4); }
.btn-gold  { background:transparent; color:var(--gold); border-color:var(--gold); }
.btn-gold:hover  { background:var(--gold); color:var(--black); transform:translateY(-2px); }
.btn-white { background:transparent; color:var(--white); border-color:rgba(255,255,255,.5); }
.btn-white:hover { background:var(--white); color:var(--black); }

/* ─── Header / Nav ────────────────────────────────────── */
header {
  position:fixed; inset:0 0 auto; height:var(--nav-h); z-index:900;
  transition:background var(--ease),box-shadow var(--ease);
}
header.at-top   { background:linear-gradient(180deg,rgba(0,0,0,.8) 0%,transparent 100%); }
header.scrolled { background:rgba(13,13,13,.97); backdrop-filter:blur(16px); box-shadow:0 1px 0 var(--border); }

.nav-wrap {
  max-width:var(--max-w); margin:0 auto; padding:0 var(--pad);
  height:100%; display:flex; align-items:center; justify-content:space-between; gap:16px;
}
.nav-logo    { display:flex; align-items:center; gap:12px; line-height:1; }
.nav-logo .l1 { font-family:var(--font-h); font-size:1rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; line-height:1.2; }
.nav-logo .l1 em { color:var(--red); font-style:italic; }
.nav-logo .l1-sub { font-family:var(--font-h); font-size:.6rem; letter-spacing:.3em; text-transform:uppercase; color:var(--gold); display:block; }

.nav-links { display:flex; align-items:center; list-style:none; gap:2px; }
.nav-links a {
  display:block; padding:8px 14px;
  font-family:var(--font-h); font-size:0.78rem; letter-spacing:0.1em; text-transform:uppercase;
  color:rgba(255,255,255,.72); transition:color var(--ease); position:relative;
}
.nav-links a::after {
  content:''; position:absolute; bottom:4px; left:14px; right:14px;
  height:2px; background:var(--red);
  transform:scaleX(0); transition:transform var(--ease); transform-origin:left;
}
.nav-links a:hover,.nav-links a.active          { color:var(--white); }
.nav-links a:hover::after,.nav-links a.active::after { transform:scaleX(1); }

.nav-cta { font-family:var(--font-h); font-size:0.78rem; letter-spacing:0.12em; }

.hamburger {
  display:none; flex-direction:column; justify-content:center;
  gap:5px; width:36px; height:36px; cursor:pointer; background:none; border:none; padding:4px;
}
.hamburger span { display:block; height:2px; background:var(--white); transition:all var(--ease); }
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

.mobile-nav {
  display:none; position:fixed; top:var(--nav-h); left:0; right:0;
  background:rgba(13,13,13,.98); backdrop-filter:blur(16px);
  padding:20px var(--pad) 32px; z-index:899; flex-direction:column; border-top:1px solid var(--border);
}
.mobile-nav.open { display:flex; }
.mobile-nav a {
  display:block; padding:13px 0;
  font-family:var(--font-h); font-size:1.05rem; text-transform:uppercase; letter-spacing:0.08em;
  border-bottom:1px solid var(--border2);
}
.mobile-nav .nav-tel { border-bottom:none; color:var(--gold); margin-top:8px; display:flex; align-items:center; gap:8px; }

/* ─── Mobile CTA Bar ──────────────────────────────────── */
.mobile-cta-bar {
  display:none; position:fixed; bottom:0; left:0; right:0; z-index:850;
  background:rgba(13,13,13,.97); backdrop-filter:blur(12px);
  border-top:1px solid var(--border); padding:10px 16px; gap:10px;
  transition:transform 0.3s ease;
}
.mobile-cta-bar.hidden { transform:translateY(100%); }
.mobile-cta-bar .btn   { flex:1; justify-content:center; padding:11px 16px; font-size:.82rem; }

/* ─── Hero ────────────────────────────────────────────── */
.hero {
  min-height:100vh; display:flex; align-items:center;
  position:relative; overflow:hidden;
}
.hero-bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center top;
  filter:grayscale(1) contrast(1.2) brightness(0.42);
}
.hero-gradient {
  position:absolute; inset:0;
  background:linear-gradient(to right, rgba(13,13,13,.92) 0%, rgba(13,13,13,.55) 55%, rgba(13,13,13,.78) 100%);
}
.hero-glow {
  position:absolute; top:0; left:0; width:40%; height:50%;
  background:radial-gradient(ellipse at top left, rgba(217,4,41,.12) 0%, transparent 70%);
  pointer-events:none;
}
.hero-content {
  position:relative; z-index:2;
  padding:calc(var(--nav-h) + 60px) var(--pad) 80px;
  max-width:var(--max-w); margin:0 auto; width:100%;
}
.hero-content-inner { max-width:680px; }

.hero-badge {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-h); font-size:0.72rem; letter-spacing:0.3em; text-transform:uppercase;
  color:var(--gold); border:1px solid rgba(233,193,118,.35); padding:6px 16px; margin-bottom:28px;
}
.hero-badge::before { content:''; width:6px; height:6px; background:var(--red); flex-shrink:0; }

.hero-content h1         { margin-bottom:6px; line-height:1.0; }
.hero-content h1 .line   { display:block; }
.hero-content h1 .red    { color:var(--red); }
.hero-sub {
  font-size:1.05rem; color:var(--gray-warm); opacity:.88;
  max-width:520px; margin:24px 0 40px; line-height:1.7;
}
.hero-ctas { display:flex; gap:14px; flex-wrap:wrap; }

/* Scroll hint */
.scroll-hint {
  position:absolute; bottom:32px; left:var(--pad); z-index:2;
  display:flex; align-items:center; gap:10px;
  color:rgba(255,255,255,.4); font-family:var(--font-h); font-size:.68rem; letter-spacing:0.2em; text-transform:uppercase;
  animation:hint-bob 2.5s ease-in-out infinite;
}
.scroll-hint::after {
  content:''; display:block; width:40px; height:1px;
  background:linear-gradient(to right,rgba(255,255,255,.4),transparent);
}
@keyframes hint-bob {
  0%,100% { transform:translateY(0); opacity:.5; }
  50%      { transform:translateY(5px); opacity:.9; }
}

/* ─── Stats Bar (parallelogram) ───────────────────────── */
.stats-bar {
  background:var(--red);
  clip-path:polygon(1.5% 0,100% 0,98.5% 100%,0 100%);
  padding:36px 80px; position:relative; z-index:10; margin-top:-2px;
}
.stats-inner {
  max-width:var(--max-w); margin:0 auto;
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:20px; text-align:center;
}
.stat-item { opacity:0; transform:translateY(14px); transition:opacity .5s ease,transform .5s ease; }
.stat-item.in { opacity:1; transform:translateY(0); }
.stat-item:nth-child(2) { transition-delay:.1s; }
.stat-item:nth-child(3) { transition-delay:.2s; }
.stat-item:nth-child(4) { transition-delay:.3s; }
.stat-n { display:block; font-family:var(--font-h); font-size:2.4rem; font-weight:700; line-height:1; margin-bottom:4px; }
.stat-l { font-size:.72rem; letter-spacing:0.15em; text-transform:uppercase; opacity:.88; }

/* ─── Page Hero (inner pages) ─────────────────────────── */
.page-hero {
  height:46vh; min-height:300px; margin-top:var(--nav-h);
  display:flex; align-items:flex-end; justify-content:flex-start;
  position:relative; overflow:hidden; padding-bottom:48px;
}
.page-hero .hero-bg       { filter:grayscale(1) contrast(1.2) brightness(0.28); }
.page-hero .hero-gradient  { background:linear-gradient(to right, rgba(13,13,13,.88) 0%, rgba(13,13,13,.45) 60%, rgba(13,13,13,.7) 100%); }
.page-hero-content { position:relative; z-index:2; padding:0 var(--pad); max-width:var(--max-w); margin:0 auto; width:100%; }
.page-hero-content h1 .red { color:var(--red); }
.breadcrumb { font-family:var(--font-h); font-size:.72rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--gray); margin-bottom:10px; }
.breadcrumb a { color:var(--gold); }
.page-hero-sub { color:var(--gray-warm); font-size:.95rem; margin-top:8px; opacity:.85; }

/* ─── About image — bracket frame ────────────────────── */
.bracket-frame { position:relative; z-index:1; }
.bracket-frame::before {
  content:''; position:absolute; top:-14px; left:-14px; z-index:2;
  width:72px; height:72px; border-top:4px solid var(--red); border-left:4px solid var(--red); pointer-events:none;
}
.bracket-frame::after {
  content:''; position:absolute; bottom:-14px; right:-14px; z-index:2;
  width:72px; height:72px; border-bottom:4px solid var(--gold); border-right:4px solid var(--gold); pointer-events:none;
}
.bracket-frame img { filter:contrast(1.05); }

/* ─── Cards ───────────────────────────────────────────── */
.card {
  background:var(--surface); border:1px solid var(--border);
  overflow:hidden; display:block;
  transition:transform var(--ease),border-color var(--ease);
}
.card:hover { transform:translateY(-4px); border-color:var(--red); }
.card-img { width:100%; aspect-ratio:16/9; background:var(--surface2); overflow:hidden; position:relative; }
.card-img img { width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.card:hover .card-img img { transform:scale(1.06); }
.card-body  { padding:24px; }
.card-tag   { font-family:var(--font-h); font-size:.7rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--red); margin-bottom:8px; }
.card h3    { margin-bottom:10px; }
.card p     { color:var(--gray); font-size:.93rem; }
.card-arrow { margin-top:18px; font-family:var(--font-h); font-size:.8rem; letter-spacing:0.1em; text-transform:uppercase; }

/* ─── Program Cards (tall, full-bleed) ───────────────── */
.program-card {
  position:relative; overflow:hidden; height:500px;
  border:1px solid var(--border); display:block;
  transition:border-color var(--ease);
}
.program-card img {
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  filter:grayscale(.25) contrast(1.1); transition:transform .7s ease;
}
.program-card:hover img { transform:scale(1.06); }
.program-card:hover { border-color:var(--red); }
.program-card-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(13,13,13,.92) 0%, rgba(13,13,13,.35) 55%, transparent 100%);
}
.program-card-hover-overlay {
  position:absolute; inset:0; background:rgba(217,4,41,.15); opacity:0; transition:opacity .5s ease;
}
.program-card:hover .program-card-hover-overlay { opacity:1; }
.program-card-content { position:absolute; bottom:0; left:0; right:0; padding:36px 32px; z-index:2; }
.program-card-content h3 { margin-bottom:8px; font-size:1.6rem; }
.program-card-content p  { color:var(--gray-warm); font-size:.9rem; max-width:300px; margin-bottom:20px; }
.btn-program {
  display:inline-block; background:var(--white); color:var(--black);
  padding:10px 24px; font-family:var(--font-h); font-size:.78rem;
  letter-spacing:0.12em; text-transform:uppercase; border:none; cursor:pointer;
  transition:background var(--ease),color var(--ease);
}
.program-card:hover .btn-program { background:var(--red); color:#fff; }

/* ─── Feature Blocks ──────────────────────────────────── */
.feat {
  display:flex; align-items:flex-start; gap:20px; padding:28px 24px;
  background:var(--surface); border-left:3px solid var(--red);
}
.feat-icon {
  flex-shrink:0; width:44px; height:44px;
  background:var(--red-dim); display:flex; align-items:center; justify-content:center; font-size:1.2rem;
}
.feat h3 { margin-bottom:7px; font-size:1.1rem; }
.feat p  { color:var(--gray); font-size:.92rem; }

/* ─── Quote / Callout ─────────────────────────────────── */
.callout {
  text-align:center; padding:clamp(64px,8vw,96px) var(--pad);
  background:var(--black); position:relative; overflow:hidden;
  border-top:1px solid rgba(233,193,118,.2); border-bottom:1px solid rgba(233,193,118,.2);
}
.callout::before {
  content:''; position:absolute; inset:0;
  background:repeating-linear-gradient(-55deg,transparent,transparent 40px,rgba(217,4,41,.025) 40px,rgba(217,4,41,.025) 41px);
  pointer-events:none;
}
.callout-icon { font-size:2.5rem; color:var(--gold); opacity:.6; margin-bottom:16px; position:relative; z-index:1; }
.callout blockquote {
  font-family:var(--font-h); font-style:italic; font-weight:400;
  font-size:clamp(1.4rem,3vw,2rem); line-height:1.4; color:var(--gold);
  max-width:860px; margin:0 auto 20px; position:relative; z-index:1;
}
.callout cite {
  color:var(--gray); font-family:var(--font-h); font-size:.8rem;
  letter-spacing:0.2em; text-transform:uppercase; font-style:normal; position:relative; z-index:1;
}

/* ─── Testimonials ───────────────────────────────────── */
.testimonials { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.testi {
  padding:32px 28px; background:var(--surface);
  border-left:2px solid rgba(217,4,41,.3);
  border-top:1px solid var(--border2); border-right:1px solid var(--border2); border-bottom:1px solid var(--border2);
  transition:border-left-color var(--ease),transform var(--ease);
}
.testi:hover { border-left-color:var(--red); transform:translateY(-3px); }
.testi-stars { color:var(--red); font-size:.9rem; letter-spacing:3px; margin-bottom:16px; }
.testi p     { color:var(--gray-warm); font-style:italic; font-size:.95rem; line-height:1.75; margin-bottom:20px; }
.testi-name  { font-family:var(--font-h); font-size:.82rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--red); }
.testi-role  { color:var(--gray); font-size:.78rem; margin-top:3px; }

/* ─── Events / News ───────────────────────────────────── */
.events-list { display:flex; flex-direction:column; gap:12px; }
.ev-item {
  display:flex; gap:18px; padding:20px 22px;
  background:var(--surface); border:1px solid var(--border2); transition:border-color var(--ease);
}
.ev-item:hover { border-color:var(--red); }
.ev-date { flex-shrink:0; width:54px; text-align:center; padding:8px 4px; background:var(--red); font-family:var(--font-h); line-height:1; }
.ev-date .d { display:block; font-size:1.6rem; font-weight:700; }
.ev-date .m { display:block; font-size:.62rem; letter-spacing:0.1em; text-transform:uppercase; opacity:.85; }
.ev-info    { flex:1; }
.ev-info h4 { font-family:var(--font-h); font-size:1.05rem; margin-bottom:5px; }
.ev-info p  { color:var(--gray); font-size:.88rem; }
.ev-badge {
  align-self:flex-start; padding:3px 9px;
  font-family:var(--font-h); font-size:.64rem; letter-spacing:0.1em; text-transform:uppercase;
}
.badge-offer { background:var(--gold-dim); color:var(--gold); }
.badge-event { background:var(--red-dim);  color:var(--red); }
.badge-class { background:rgba(255,255,255,.07); color:var(--gray); }

/* ─── Calendar ────────────────────────────────────────── */
.cal-wrap { border:1px solid var(--border); overflow:hidden; }
.cal-wrap iframe {
  display:block; width:100%; height:480px; background:var(--surface);
  filter:invert(.88) hue-rotate(168deg) contrast(.95);
}

/* ─── FAQ Accordion ───────────────────────────────────── */
.faq-item { border-bottom:1px solid var(--border2); }
.faq-toggle {
  display:flex; justify-content:space-between; align-items:center;
  width:100%; padding:20px 0; text-align:left;
  background:none; border:none; cursor:pointer; color:var(--white);
  font-family:var(--font-h); font-size:1rem; text-transform:uppercase; letter-spacing:0.08em;
  transition:color var(--ease);
}
.faq-toggle:hover { color:var(--gold); }
.faq-icon { font-size:1.2rem; color:var(--red); flex-shrink:0; transition:transform var(--ease); }
.faq-item.open .faq-icon { transform:rotate(45deg); }
.faq-body { display:none; padding-bottom:20px; color:var(--gray); line-height:1.75; }
.faq-item.open .faq-body { display:block; }

/* ─── CTA Banner (full red, horizontal) ──────────────── */
.cta-banner {
  background:var(--red); padding:clamp(56px,7vw,80px) var(--pad);
  position:relative; overflow:hidden;
}
.cta-banner::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(0,0,0,.22) 0%,transparent 50%,rgba(0,0,0,.16) 100%);
}
.cta-banner::after {
  content:'力';
  position:absolute; right:5%; top:50%; transform:translateY(-50%);
  font-family:serif; font-size:14rem; color:rgba(255,255,255,.04);
  pointer-events:none; line-height:1;
}
.cta-inner {
  position:relative; z-index:1;
  display:flex; justify-content:space-between; align-items:center; gap:40px;
  max-width:var(--max-w); margin:0 auto;
}
.cta-inner h2  { margin-bottom:10px; }
.cta-inner p   { color:rgba(255,255,255,.82); max-width:540px; }
.cta-inner .btn-white:hover { background:var(--white); color:var(--red); }

/* ─── Info Box ────────────────────────────────────────── */
.info-box { background:var(--surface); border:1px solid var(--border2); overflow:hidden; }
.info-row { display:flex; align-items:flex-start; gap:14px; padding:18px 24px; border-bottom:1px solid var(--border2); }
.info-row:last-child { border-bottom:none; }
.info-icon  { flex-shrink:0; margin-top:2px; }
.info-row h5 { font-family:var(--font-h); font-size:.68rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--gray); margin-bottom:3px; }
.info-row p  { font-size:.95rem; }
.info-row a  { color:var(--gold); }
.info-row a:hover { text-decoration:underline; }

/* ─── Form (minimalist bottom-border style) ───────────── */
.form-group { margin-bottom:24px; }
.form-label {
  display:block; font-family:var(--font-h); font-size:.68rem;
  letter-spacing:0.15em; text-transform:uppercase; color:var(--gray); margin-bottom:8px;
}
.form-ctrl {
  width:100%; padding:10px 0;
  background:transparent; border:none; border-bottom:1px solid var(--border);
  color:var(--white); font-family:var(--font-b); font-size:1rem; transition:border-color var(--ease);
  -webkit-appearance:none;
}
.form-ctrl:focus { outline:none; border-bottom-color:var(--red); }
.form-ctrl::placeholder { color:rgba(255,255,255,.22); }
textarea.form-ctrl { min-height:100px; resize:vertical; padding:12px; border:1px solid var(--border); background:var(--surface); }
textarea.form-ctrl:focus { border-color:var(--red); }
select.form-ctrl { background:var(--surface); padding:10px 12px; border:1px solid var(--border); }
select.form-ctrl:focus { border-color:var(--red); }

/* ─── Gallery ─────────────────────────────────────────── */
.gallery { display:grid; grid-template-columns:repeat(3,1fr); grid-auto-rows:240px; gap:6px; }
.gal-item { overflow:hidden; background:var(--surface); position:relative; }
.gal-item img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; filter:grayscale(.2) contrast(1.05); }
.gal-item:hover img { transform:scale(1.08); filter:grayscale(0) contrast(1.1); }

/* ─── Sensei masters list ─────────────────────────────── */
.master-item { display:flex; align-items:flex-start; gap:14px; padding:14px 18px; background:var(--surface); }
.master-item.red-bar  { border-left:3px solid var(--red); }
.master-item.gold-bar { border-left:3px solid var(--gold); }
.master-item strong { display:block; font-family:var(--font-h); font-size:.95rem; text-transform:uppercase; }
.master-item span   { color:var(--gray); font-size:.82rem; }

/* ─── Footer ──────────────────────────────────────────── */
footer {
  background:var(--black); border-top:4px solid var(--red);
  padding:72px var(--pad) 32px; position:relative;
}
footer::before {
  content:''; position:absolute; top:-4px; left:50%; transform:translateX(-50%);
  width:80px; height:4px; background:var(--gold);
}
.footer-grid {
  max-width:var(--max-w); margin:0 auto;
  display:grid; grid-template-columns:2fr 1fr 1fr; gap:48px; margin-bottom:48px;
}
.footer-brand .l1     { font-family:var(--font-h); font-size:1.2rem; font-weight:700; text-transform:uppercase; letter-spacing:0.12em; display:block; }
.footer-brand .l1 em  { color:var(--red); font-style:italic; }
.footer-brand .l1-sub { font-family:var(--font-h); font-size:.62rem; letter-spacing:0.3em; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:16px; }
.footer-brand p   { color:var(--gray); font-size:.88rem; max-width:280px; line-height:1.75; }
.footer-col h5    { font-family:var(--font-h); font-size:.68rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--red); margin-bottom:18px; }
.footer-links     { list-style:none; display:flex; flex-direction:column; gap:9px; }
.footer-links a   { color:var(--gray); font-size:.88rem; transition:color var(--ease); }
.footer-links a:hover { color:var(--white); }
.footer-contact   { display:flex; flex-direction:column; gap:12px; }
.fc-item          { display:flex; gap:10px; align-items:flex-start; font-size:.88rem; color:var(--gray); }
.fc-item svg      { color:var(--red); margin-top:1px; flex-shrink:0; }
.fc-item a        { color:var(--gold); }
.fc-item a:hover  { text-decoration:underline; }
.footer-bottom {
  max-width:var(--max-w); margin:0 auto;
  display:flex; justify-content:space-between; align-items:center;
  padding-top:28px; border-top:1px solid var(--border2);
  font-family:var(--font-h); font-size:.68rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--gray);
}
.footer-bottom a       { color:var(--gray); transition:color var(--ease); }
.footer-bottom a:hover { color:var(--white); }

/* ─── Responsive ──────────────────────────────────────── */
@media (max-width:1024px) {
  .grid-3       { grid-template-columns:repeat(2,1fr); }
  .stats-inner  { grid-template-columns:repeat(2,1fr); }
  .footer-grid  { grid-template-columns:1fr 1fr; }
  .footer-grid > :first-child { grid-column:1 / -1; }
  .testimonials { grid-template-columns:repeat(2,1fr); }
}

@media (max-width:768px) {
  .nav-links,.nav-cta { display:none; }
  .hamburger { display:flex; }
  .mobile-cta-bar { display:flex; }
  footer { padding-bottom:calc(32px + 72px); }

  .grid-2,.grid-3          { grid-template-columns:1fr; }
  .about-grid,.two-col,.bio-grid,.contact-grid { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
  .about-img { height:300px; }
  .gallery   { grid-template-columns:repeat(2,1fr); }
  .footer-grid   { grid-template-columns:1fr; gap:32px; }
  .footer-bottom { flex-direction:column; gap:8px; text-align:center; }
  .hero-ctas     { flex-direction:column; }
  .stats-inner   { grid-template-columns:repeat(2,1fr); }
  .stats-bar     { clip-path:none; padding:32px var(--pad); }
  .testimonials  { grid-template-columns:1fr; }
  .cta-inner     { flex-direction:column; text-align:center; }
  .program-card  { height:380px; }
  .clip-diagonal,.clip-diagonal-rev { clip-path:none; padding-bottom:var(--section-pad) !important; padding-top:var(--section-pad) !important; }
}

@media (max-width:480px) {
  .gallery { grid-template-columns:1fr; }
  .cta-banner::after { display:none; }
}
