/* ============================================================
   ST IVES & ST LEONARDS KARATE CLUB — Main Stylesheet
   ISMAA Karate Academy
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@400;500;600;700&family=Open+Sans:ital,wght@0,300;0,400;0,600;0,700;1,400&display=swap');

/* ============================================================
   Variables
   ============================================================ */
:root {
  --black:   #0d0d0d;
  --dark:    #1a1a1a;
  --mid:     #252525;
  --border:  rgba(255,255,255,0.08);
  --red:     #c41e3a;
  --red-dk:  #9b1830;
  --orange:  #ff6b00;
  --orange-dk:#e05c00;
  --white:   #ffffff;
  --offwhite:#f5f5f5;
  --muted:   rgba(255,255,255,0.65);

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

  --nav-h:   75px;
  --radius:  6px;
  --trans:   0.3s ease;
  --shadow:  0 4px 24px rgba(0,0,0,0.35);
  --shadow-lg: 0 8px 48px rgba(0,0,0,0.55);
}

/* ============================================================
   Reset
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html  { scroll-behavior: smooth; }
body  { font-family: var(--font-b); background: var(--black); color: var(--white); line-height: 1.65; overflow-x: hidden; }
img   { max-width: 100%; height: auto; display: block; }
a     { color: inherit; text-decoration: none; }
ul    { list-style: none; }
button { font-family: var(--font-b); cursor: pointer; }

/* ============================================================
   Typography
   ============================================================ */
h1,h2,h3,h4,h5,h6 { font-family: var(--font-h); font-weight: 700; letter-spacing:.02em; line-height:1.15; }
h1 { font-size: clamp(2.2rem, 6vw, 4.5rem); }
h2 { font-size: clamp(1.6rem, 3.5vw, 2.75rem); }
h3 { font-size: clamp(1.2rem, 2.5vw, 1.75rem); }
h4 { font-size: 1.2rem; }
p  { margin-bottom: 1rem; color: var(--muted); }
p:last-child { margin-bottom: 0; }

/* ============================================================
   Layout
   ============================================================ */
.container { max-width: 1200px; margin: 0 auto; padding: 0 1.5rem; }
.section   { padding: 5rem 0; }
.section--dark  { background: var(--dark); }
.section--mid   { background: var(--mid); }
.section--white { background: var(--offwhite); color: var(--black); }
.section--white p { color: rgba(0,0,0,0.7); }
.section--white h2,.section--white h3,.section--white h4 { color: var(--black); }

.sec-header          { text-align:center; margin-bottom:3rem; }
.sec-header .eyebrow { font-family:var(--font-h); font-size:.8rem; text-transform:uppercase; letter-spacing:.18em; color:var(--orange); margin-bottom:.5rem; }
.sec-header h2       { text-transform:uppercase; }
.sec-header .lead    { max-width:600px; margin:.75rem auto 0; font-size:1.05rem; }
.divider             { width:56px; height:4px; background:linear-gradient(135deg,var(--red),var(--orange)); border-radius:2px; margin:.75rem auto; }

.grid-2 { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1.5rem; }
.grid-3 { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:1.5rem; }
.grid-4 { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:1.5rem; }

.split { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
@media(max-width:768px){ .split { grid-template-columns:1fr; gap:2rem; } }

/* ============================================================
   Buttons
   ============================================================ */
.btn {
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:var(--font-h); font-size:1rem; font-weight:600;
  text-transform:uppercase; letter-spacing:.1em;
  padding:.9rem 2rem; border-radius:4px; border:none;
  cursor:pointer; transition:var(--trans);
}
.btn-primary {
  background:linear-gradient(135deg,var(--red),var(--orange));
  color:var(--white);
  box-shadow:0 4px 18px rgba(196,30,58,.4);
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 6px 28px rgba(196,30,58,.6); }
.btn-outline {
  background:transparent; color:var(--white); border:2px solid var(--white);
}
.btn-outline:hover { background:var(--white); color:var(--black); }
.btn-outline-red {
  background:transparent; color:var(--red); border:2px solid var(--red);
}
.btn-outline-red:hover { background:var(--red); color:var(--white); }
.btn-lg { padding:1.1rem 2.75rem; font-size:1.1rem; }
.btn-sm { padding:.6rem 1.25rem; font-size:.85rem; }

/* ============================================================
   Navigation
   ============================================================ */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  height:var(--nav-h);
  background:rgba(13,13,13,.97);
  backdrop-filter:blur(10px);
  border-bottom:2px solid var(--red);
  transition:var(--trans);
}
.nav.scrolled { box-shadow:var(--shadow); }

.nav-inner {
  display:flex; align-items:center; justify-content:space-between;
  height:100%; max-width:1400px; margin:0 auto; padding:0 1.5rem;
}

.nav-logo { display:flex; align-items:center; }
.nav-logo img:not(.nav-logo-wide) { width:110px; height:110px; object-fit:contain; }
.nav-logo-wide { width:auto; height:88px; object-fit:contain; max-width:440px; }
.nav-logo-text { display:flex; flex-direction:column; line-height:1.2; }
.nav-logo-name { font-family:var(--font-h); font-size:.88rem; font-weight:700; text-transform:uppercase; letter-spacing:.04em; }
.nav-logo-sub  { font-size:.65rem; color:var(--orange); text-transform:uppercase; letter-spacing:.12em; }

.nav-links { display:flex; align-items:center; gap:.15rem; }
.nav-link {
  font-family:var(--font-h); font-size:.82rem; text-transform:uppercase; letter-spacing:.08em;
  color:rgba(255,255,255,.78); padding:.5rem .8rem; border-radius:4px; transition:var(--trans);
}
.nav-link:hover,.nav-link.active { color:var(--white); background:rgba(255,255,255,.06); }
.nav-link.active { color:var(--orange); }

.nav-cta { background:var(--red) !important; color:var(--white) !important; border-radius:30px; padding:.5rem 1.4rem !important; }
.nav-cta:hover { background:var(--orange) !important; transform:translateY(-1px); }

/* Dropdown */
.nav-item { position:relative; }
.nav-dropdown {
  position:absolute; top:calc(100% + 4px); left:0;
  background:var(--dark); border:1px solid var(--border); border-radius:var(--radius);
  min-width:190px; opacity:0; visibility:hidden; transform:translateY(-8px);
  transition:var(--trans); box-shadow:var(--shadow);
}
.nav-item:hover .nav-dropdown { opacity:1; visibility:visible; transform:translateY(0); }
.nav-dropdown a {
  display:block; padding:.7rem 1rem;
  font-family:var(--font-h); font-size:.78rem; text-transform:uppercase; letter-spacing:.08em;
  color:rgba(255,255,255,.75); border-bottom:1px solid rgba(255,255,255,.04); transition:var(--trans);
}
.nav-dropdown a:hover { color:var(--orange); padding-left:1.4rem; background:rgba(255,255,255,.03); }
.nav-dropdown a:last-child { border-bottom:none; }

/* Hamburger */
.nav-toggle { display:none; flex-direction:column; gap:5px; background:none; border:none; padding:5px; }
.nav-toggle span { display:block; width:24px; height:2px; background:var(--white); transition:var(--trans); }
.nav-toggle.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.nav-toggle.open span:nth-child(2) { opacity:0; }
.nav-toggle.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

@media(max-width:960px){
  .nav-toggle { display:flex; }
  .nav-logo-wide { max-width:280px; height:72px; }
  .nav-links {
    position:fixed; top:var(--nav-h); left:0; right:0;
    flex-direction:column; align-items:stretch; gap:0;
    background:var(--dark); padding:1rem;
    transform:translateY(-120%); opacity:0; visibility:hidden;
    transition:var(--trans); border-bottom:2px solid var(--red);
    max-height:calc(100vh - var(--nav-h)); overflow-y:auto;
  }
  .nav-links.open { transform:translateY(0); opacity:1; visibility:visible; }
  .nav-link { padding:.9rem 1rem; border-bottom:1px solid var(--border); font-size:.95rem; }
  .nav-dropdown { position:static; opacity:1; visibility:visible; transform:none; background:rgba(0,0,0,.25); box-shadow:none; border:none; }
  .nav-cta { border-radius:4px !important; margin-top:.5rem; text-align:center; justify-content:center; }
}

/* ============================================================
   Hero
   ============================================================ */
.hero {
  position:relative; min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden; background:var(--black);
}
.hero-bg { position:absolute; inset:0; z-index:0; }
.hero-bg video { width:100%; height:100%; object-fit:cover; opacity:.25; }
.hero-overlay {
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(135deg,rgba(13,13,13,.88) 0%,rgba(196,30,58,.2) 50%,rgba(13,13,13,.88) 100%);
}
.hero-content {
  position:relative; z-index:2;
  text-align:center;
  padding:calc(var(--nav-h) + 3rem) 1.5rem 5rem;
  max-width:860px; margin:0 auto;
}
.hero-pill {
  display:inline-flex; align-items:center; gap:.5rem;
  background:rgba(255,107,0,.12); border:1px solid rgba(255,107,0,.4);
  color:var(--orange); font-family:var(--font-h); font-size:.75rem;
  text-transform:uppercase; letter-spacing:.18em;
  padding:.35rem 1rem; border-radius:30px; margin-bottom:1.5rem;
}
.hero-logo-wrap {
  width:min(480px, 88vw); height:auto; margin:0 auto 2rem;
  filter:drop-shadow(0 0 30px rgba(196,30,58,.5));
  animation:logoPulse 3s ease-in-out infinite;
}
.hero-logo-wrap img { width:100%; height:auto; object-fit:contain; }
@keyframes logoPulse {
  0%,100% { filter:drop-shadow(0 0 20px rgba(196,30,58,.4)); }
  50%      { filter:drop-shadow(0 0 45px rgba(255,107,0,.65)); }
}
.hero h1 { text-transform:uppercase; margin-bottom:.75rem; text-shadow:0 2px 20px rgba(0,0,0,.6); }
.hero h1 span { color:var(--red); }
.hero-sub {
  font-family:var(--font-h); font-size:clamp(.9rem,2vw,1.2rem);
  text-transform:uppercase; letter-spacing:.2em; color:rgba(255,255,255,.75); margin-bottom:.4rem;
}
.hero-tagline { font-style:italic; color:var(--orange); font-size:clamp(.95rem,1.5vw,1.1rem); margin-bottom:2.5rem; }
.hero-ctas { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }
.hero-scroll {
  position:absolute; bottom:1.75rem; left:50%; transform:translateX(-50%);
  z-index:2; display:flex; flex-direction:column; align-items:center;
  gap:.4rem; color:rgba(255,255,255,.4); font-size:.7rem; letter-spacing:.12em; text-transform:uppercase;
  animation:scrollBob 2s ease-in-out infinite;
}
.hero-scroll::after { content:''; width:1px; height:36px; background:linear-gradient(to bottom,rgba(255,255,255,.4),transparent); }
@keyframes scrollBob {
  0%,100% { transform:translateX(-50%) translateY(0); }
  50%      { transform:translateX(-50%) translateY(8px); }
}

/* ============================================================
   Stats Strip
   ============================================================ */
.stats-strip { background:linear-gradient(135deg,var(--red-dk),var(--red)); padding:2.25rem 0; }
.stats-strip .container { display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); gap:1rem; text-align:center; }
.stat-num { font-family:var(--font-h); font-size:2.6rem; font-weight:700; line-height:1; }
.stat-lbl { font-size:.75rem; text-transform:uppercase; letter-spacing:.12em; color:rgba(255,255,255,.8); margin-top:.25rem; }

/* ============================================================
   CTA Banner
   ============================================================ */
.cta-banner { background:linear-gradient(135deg,var(--red-dk) 0%,var(--red) 40%,var(--orange-dk) 100%); padding:4rem 0; text-align:center; }
.cta-banner h2 { text-transform:uppercase; margin-bottom:.75rem; }
.cta-banner p  { color:rgba(255,255,255,.85); max-width:500px; margin:0 auto 2rem; }

/* ============================================================
   Cards
   ============================================================ */
.card {
  background:var(--dark); border-radius:var(--radius); overflow:hidden;
  border:1px solid var(--border); transition:var(--trans);
}
.card:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); border-color:var(--red); }
.card-img { width:100%; height:200px; object-fit:cover; }
.card-img-placeholder { width:100%; height:200px; background:linear-gradient(135deg,var(--mid),var(--dark)); display:flex; align-items:center; justify-content:center; font-size:4rem; }
.card-body { padding:1.5rem; }
.card-tag { display:inline-block; font-family:var(--font-h); font-size:.68rem; text-transform:uppercase; letter-spacing:.1em; color:var(--orange); border:1px solid var(--orange); padding:.18rem .55rem; border-radius:3px; margin-bottom:.75rem; }
.card-title { font-size:1.15rem; margin-bottom:.5rem; }
.card-text { font-size:.9rem; color:var(--muted); }

/* ============================================================
   Timetable
   ============================================================ */
.timetable-wrap { overflow-x:auto; border-radius:var(--radius); }
.timetable { width:100%; border-collapse:collapse; font-size:.9rem; }
.timetable th { background:var(--red); color:var(--white); font-family:var(--font-h); text-transform:uppercase; letter-spacing:.08em; padding:1rem 1.25rem; text-align:left; }
.timetable td { padding:.85rem 1.25rem; border-bottom:1px solid var(--border); color:rgba(255,255,255,.85); }
.timetable tr:nth-child(even) td { background:rgba(255,255,255,.02); }
.timetable tr:hover td { background:rgba(196,30,58,.1); }
.badge { display:inline-block; padding:.18rem .55rem; border-radius:3px; font-size:.72rem; font-family:var(--font-h); text-transform:uppercase; letter-spacing:.06em; }
.badge-ninja   { background:rgba(255,107,0,.18); color:var(--orange); }
.badge-junior  { background:rgba(0,150,255,.18); color:#4db8ff; }
.badge-open    { background:rgba(196,30,58,.18); color:#f57; }
.badge-all     { background:rgba(100,200,100,.18); color:#7ec; }

/* ============================================================
   Instructor Card
   ============================================================ */
.instr-card { background:var(--dark); border-radius:var(--radius); overflow:hidden; text-align:center; border:1px solid var(--border); transition:var(--trans); }
.instr-card:hover { transform:translateY(-5px); border-color:var(--red); box-shadow:var(--shadow-lg); }
.instr-card-photo { width:100%; height:280px; object-fit:cover; object-position:top; }
.instr-card-placeholder { width:100%; height:280px; background:linear-gradient(135deg,var(--mid),var(--dark)); display:flex; align-items:center; justify-content:center; font-size:5.5rem; }
.instr-card-body { padding:1.5rem; }
.instr-card-name  { font-size:1.25rem; margin-bottom:.2rem; }
.instr-card-grade { color:var(--orange); font-family:var(--font-h); font-size:.82rem; text-transform:uppercase; letter-spacing:.1em; margin-bottom:.75rem; }
.instr-card-bio   { font-size:.88rem; color:var(--muted); line-height:1.65; }

/* ============================================================
   Event Cards
   ============================================================ */
.event-card {
  background:var(--dark); border-radius:var(--radius); overflow:hidden;
  display:flex; border:1px solid var(--border); transition:var(--trans);
}
.event-card:hover { border-color:var(--red); transform:translateX(4px); }
.event-date { background:var(--red); color:var(--white); padding:1.25rem; min-width:80px; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; font-family:var(--font-h); flex-shrink:0; }
.event-day   { font-size:2rem; font-weight:700; line-height:1; }
.event-month { font-size:.72rem; text-transform:uppercase; letter-spacing:.1em; }
.event-body  { padding:1.25rem 1.5rem; flex:1; }
.event-title { font-size:1.05rem; margin-bottom:.2rem; }
.event-meta  { font-size:.78rem; color:rgba(255,255,255,.45); margin-bottom:.4rem; }
.event-desc  { font-size:.88rem; color:var(--muted); margin:0; }

/* ============================================================
   Gallery
   ============================================================ */
.gallery-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:1rem; }
.g-item { position:relative; overflow:hidden; border-radius:var(--radius); aspect-ratio:4/3; background:var(--mid); }
.g-item img { width:100%; height:100%; object-fit:cover; transition:transform .4s ease; }
.g-item:hover img { transform:scale(1.06); }
.g-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,.8) 0%,transparent 55%); opacity:0; transition:var(--trans); display:flex; align-items:flex-end; padding:.85rem; }
.g-item:hover .g-overlay { opacity:1; }
.g-caption { font-size:.82rem; }

/* ============================================================
   Forms
   ============================================================ */
.form-row   { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; }
@media(max-width:600px){ .form-row { grid-template-columns:1fr; } }
.form-group { margin-bottom:1.25rem; }
.form-label { display:block; font-family:var(--font-h); font-size:.8rem; text-transform:uppercase; letter-spacing:.08em; color:rgba(255,255,255,.65); margin-bottom:.45rem; }
.form-label .req { color:var(--red); }
.form-control {
  width:100%; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.14);
  border-radius:var(--radius); color:var(--white); font-family:var(--font-b); font-size:.98rem;
  padding:.85rem 1rem; transition:var(--trans); appearance:none;
}
.form-control:focus { outline:none; border-color:var(--orange); background:rgba(255,107,0,.05); box-shadow:0 0 0 3px rgba(255,107,0,.12); }
.form-control::placeholder { color:rgba(255,255,255,.28); }
select.form-control { cursor:pointer; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23fff' stroke-width='2' fill='none'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 1rem center; padding-right:2.5rem; }
select.form-control option { background:#1a1a1a; color:#ffffff; }
textarea.form-control { min-height:130px; resize:vertical; }
.form-check { display:flex; align-items:flex-start; gap:.75rem; cursor:pointer; }
.form-check input[type="checkbox"] { width:19px; height:19px; flex-shrink:0; accent-color:var(--red); cursor:pointer; margin-top:2px; }
.form-check-label { font-size:.9rem; color:var(--muted); }
.form-check-label a { color:var(--orange); text-decoration:underline; }

/* ============================================================
   Page Hero (inner pages)
   ============================================================ */
.page-hero {
  background:linear-gradient(135deg,var(--black),var(--dark));
  padding:calc(var(--nav-h) + 4rem) 0 4rem;
  text-align:center; position:relative; overflow:hidden;
  border-bottom:1px solid rgba(196,30,58,.25);
}
.page-hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at center,rgba(196,30,58,.12) 0%,transparent 70%); }
.page-hero-content { position:relative; z-index:1; }
.breadcrumb { font-size:.75rem; color:rgba(255,255,255,.4); text-transform:uppercase; letter-spacing:.1em; margin-bottom:1rem; }
.breadcrumb a { color:var(--orange); }
.page-hero h1 { text-transform:uppercase; }
.page-hero-sub { color:var(--orange); font-family:var(--font-h); font-size:.9rem; text-transform:uppercase; letter-spacing:.18em; margin-top:.75rem; }

/* ============================================================
   Accordion
   ============================================================ */
.accordion-item { border-bottom:1px solid var(--border); }
.accordion-btn {
  width:100%; background:none; border:none; color:var(--white);
  display:flex; justify-content:space-between; align-items:center;
  padding:1.25rem 0; cursor:pointer;
  font-family:var(--font-h); font-size:1.05rem; text-transform:uppercase; letter-spacing:.03em;
  text-align:left; transition:var(--trans);
}
.accordion-btn:hover { color:var(--orange); }
.accordion-icon { font-size:1.4rem; flex-shrink:0; color:var(--red); transition:transform .3s ease; }
.accordion-item.open .accordion-icon { transform:rotate(45deg); }
.accordion-body { max-height:0; overflow:hidden; transition:max-height .4s ease, padding .3s ease; padding-bottom:0; }
.accordion-item.open .accordion-body { max-height:600px; padding-bottom:1.25rem; }
.accordion-body p { color:rgba(255,255,255,.72); line-height:1.75; }

/* ============================================================
   Timeline
   ============================================================ */
.timeline { position:relative; padding-left:2rem; }
.timeline::before { content:''; position:absolute; left:0; top:0; bottom:0; width:2px; background:linear-gradient(to bottom,var(--red),var(--orange)); }
.tl-item { position:relative; padding-bottom:2.5rem; }
.tl-item::before { content:''; position:absolute; left:-2.45rem; top:.25rem; width:14px; height:14px; border-radius:50%; background:var(--red); border:2px solid var(--dark); box-shadow:0 0 0 3px rgba(196,30,58,.4); }
.tl-date  { font-family:var(--font-h); font-size:.78rem; text-transform:uppercase; letter-spacing:.12em; color:var(--orange); margin-bottom:.25rem; }
.tl-title { font-size:1.1rem; margin-bottom:.45rem; }
.tl-text  { font-size:.9rem; color:var(--muted); line-height:1.75; margin:0; }

/* ============================================================
   Fact Cards
   ============================================================ */
.fact-card {
  background:var(--dark); border-radius:var(--radius); padding:2rem;
  text-align:center; border:1px solid var(--border); transition:var(--trans);
  position:relative; overflow:hidden;
}
.fact-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(135deg,var(--red),var(--orange)); }
.fact-card:hover { transform:translateY(-5px); border-color:rgba(255,107,0,.3); box-shadow:0 10px 40px rgba(255,107,0,.12); }
.fact-icon { font-size:2.5rem; margin-bottom:.85rem; }
.fact-num  { font-family:var(--font-h); font-size:3rem; font-weight:700; color:var(--orange); line-height:1; margin-bottom:.4rem; }
.fact-lbl  { font-family:var(--font-h); font-size:.95rem; text-transform:uppercase; letter-spacing:.06em; margin-bottom:.65rem; }
.fact-txt  { font-size:.88rem; color:var(--muted); margin:0; }

/* ============================================================
   Contact Info
   ============================================================ */
.contact-list { display:flex; flex-direction:column; gap:1.5rem; }
.contact-item { display:flex; gap:1rem; align-items:flex-start; }
.contact-icon { width:46px; height:46px; background:rgba(196,30,58,.12); border:1px solid rgba(196,30,58,.3); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.2rem; flex-shrink:0; }
.contact-text h4 { font-size:.78rem; text-transform:uppercase; letter-spacing:.12em; color:var(--orange); margin-bottom:.2rem; }
.contact-text p  { color:rgba(255,255,255,.8); margin:0; font-size:.95rem; }
.map-wrap { border-radius:var(--radius); overflow:hidden; border:1px solid var(--border); }
.map-wrap iframe { width:100%; height:380px; border:none; display:block; }

/* ============================================================
   Cookie Banner
   ============================================================ */
.cookie-banner {
  position:fixed; bottom:0; left:0; right:0; z-index:9999;
  background:var(--dark); border-top:2px solid var(--red);
  padding:1.25rem 1.5rem;
  display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap;
  box-shadow:0 -4px 24px rgba(0,0,0,.5);
}
.cookie-banner.hidden { display:none; }
.cookie-text { font-size:.88rem; color:rgba(255,255,255,.8); flex:1; min-width:200px; }
.cookie-text a { color:var(--orange); text-decoration:underline; }
.cookie-btns { display:flex; gap:.75rem; flex-shrink:0; }

/* ============================================================
   Footer
   ============================================================ */
.footer { background:var(--black); border-top:1px solid var(--border); padding:2.25rem 0 1rem; }
.footer-grid { display:grid; grid-template-columns:2fr repeat(3,1fr); gap:2rem; margin-bottom:1.5rem; }
.footer-brand img { width:60px; margin-bottom:.6rem; }
.footer-brand p { font-size:.82rem; color:rgba(255,255,255,.55); line-height:1.65; margin-bottom:.85rem; }
.footer-heading { font-family:var(--font-h); font-size:.72rem; text-transform:uppercase; letter-spacing:.18em; color:var(--orange); margin-bottom:.6rem; }
.footer-links { display:flex; flex-direction:column; gap:.25rem; }
.footer-link { font-size:.82rem; color:rgba(255,255,255,.55); transition:var(--trans); padding:.08rem 0; }
.footer-link:hover { color:var(--white); padding-left:.5rem; }
.footer-bottom { border-top:1px solid var(--border); padding-top:1rem; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:.75rem; }
.footer-copy { font-size:.78rem; color:rgba(255,255,255,.35); margin:0; }
.social-links { display:flex; gap:.65rem; }
.social-link { width:36px; height:36px; background:rgba(255,255,255,.05); border:1px solid var(--border); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.9rem; color:rgba(255,255,255,.55); transition:var(--trans); }
.social-link:hover { background:var(--red); border-color:var(--red); color:var(--white); }
.social-link--wa { background:#25d366; border-color:#25d366; color:#fff; width:44px; height:44px; }
.social-link--wa svg { width:22px; height:22px; }
.social-link--wa:hover { background:#1da851 !important; border-color:#1da851 !important; }
@media(max-width:900px){ .footer-grid { grid-template-columns:1fr 1fr; gap:2rem; } }
@media(max-width:600px){ .footer-grid { grid-template-columns:1fr; } }

/* ============================================================
   Utilities & Animations
   ============================================================ */
.text-center { text-align:center; }
.text-red    { color:var(--red); }
.text-orange { color:var(--orange); }
.mt-1 { margin-top:.5rem; }
.mt-2 { margin-top:1rem; }
.mt-3 { margin-top:2rem; }
.mt-4 { margin-top:3rem; }
.mb-2 { margin-bottom:1rem; }
.mb-3 { margin-bottom:2rem; }

.fade-in { opacity:0; transform:translateY(22px); transition:opacity .65s ease, transform .65s ease; }
.fade-in.visible { opacity:1; transform:translateY(0); }

.alert { padding:1rem 1.25rem; border-radius:var(--radius); border-left:4px solid; margin-bottom:1rem; font-size:.9rem; }
.alert-success { background:rgba(76,175,80,.1); border-color:#4caf50; color:rgba(255,255,255,.85); }
.alert-info    { background:rgba(0,120,255,.1); border-color:#0078ff; color:rgba(255,255,255,.85); }
.alert-warn    { background:rgba(255,107,0,.1);  border-color:var(--orange); color:rgba(255,255,255,.85); }
.alert-error   { background:rgba(196,30,58,.12); border-color:#c41e3a;      color:rgba(255,255,255,.85); }

@media(max-width:768px){ .section { padding:3rem 0; } .hide-mobile { display:none !important; } }
@media(min-width:769px){ .hide-desktop { display:none !important; } }

/* ============================================================
   Classes List (horizontal row layout)
   ============================================================ */
.classes-list { display:flex; flex-direction:column; gap:.75rem; }
.class-row {
  display:flex; align-items:center; gap:1.25rem;
  background:var(--mid); border:1px solid var(--border);
  border-radius:var(--radius); padding:1.1rem 1.4rem;
  transition:var(--trans);
}
.class-row:hover { border-color:var(--red); background:rgba(196,30,58,.06); transform:translateX(4px); }
.class-icon { font-size:1.8rem; flex-shrink:0; width:2.5rem; text-align:center; }
.class-info { display:flex; flex-direction:column; gap:.2rem; flex:1; }
.class-info strong { font-family:var(--font-h); font-size:1rem; text-transform:uppercase; letter-spacing:.04em; color:var(--white); }
.class-desc { font-size:.88rem; color:var(--muted); }
.class-meta { font-size:.78rem; color:var(--orange); font-family:var(--font-h); letter-spacing:.04em; }
@media(max-width:600px){ .class-row { flex-wrap:wrap; } .class-icon { width:auto; } }

/* ============================================================
   Values compact (inline icon + text)
   ============================================================ */
.values-compact .grid-4 { gap:1rem; }
.value-item {
  display:flex; flex-direction:column; align-items:center; text-align:center;
  gap:.4rem; padding:1.5rem 1rem;
  background:var(--mid); border:1px solid var(--border); border-radius:var(--radius);
  transition:var(--trans);
}
.value-item:hover { border-color:rgba(255,107,0,.35); transform:translateY(-4px); }
.value-icon { font-size:2rem; }
.value-lbl { font-family:var(--font-h); font-size:.95rem; text-transform:uppercase; letter-spacing:.06em; color:var(--white); }
.value-txt { font-size:.85rem; color:var(--muted); margin:0; line-height:1.6; }
