/* =====================================================================
   Sports & Courts — 2026 redesign  ·  "Athletic Editorial"
   Anton (display) + Hanken Grotesk (body) · warm paper · ink-blue · orange
   Loaded LAST in head.tpl so it owns the cascade over Bootstrap/legacy CSS.
   ===================================================================== */

:root {
    /* brand */
    --orange: #f8973b;
    --orange-600: #e87d20;
    --blue: #155196;
    --blue-700: #103f76;
    --blue-900: #0b2747;

    /* warm paper neutrals, tinted toward the brand blue */
    --paper: #f4efe5;
    --paper-2: #ece4d6;
    --paper-3: #e3d9c7;
    --ink: #16233a;          /* near-black, blued */
    --ink-soft: #43526c;     /* secondary text — blue-gray, never flat gray */
    --line: rgba(22, 35, 58, .14);
    --card: #fbf8f2;

    /* fluid type scale (Anton display + Hanken body) */
    --fs-eyebrow: clamp(.72rem, .68rem + .2vw, .8rem);
    --fs-body:    clamp(1rem, .96rem + .25vw, 1.15rem);
    --fs-lead:    clamp(1.15rem, 1.02rem + .7vw, 1.5rem);
    --fs-h3:      clamp(1.4rem, 1.1rem + 1.4vw, 2.1rem);
    --fs-h2:      clamp(2.6rem, 1.4rem + 5.6vw, 6rem);
    --fs-display: clamp(3.4rem, 1.1rem + 10.5vw, 10.5rem);
    --fs-index:   clamp(3rem, 1.5rem + 7vw, 8rem);

    /* space + shape */
    --gutter: clamp(1.25rem, 5vw, 6rem);
    --section-y: clamp(4.5rem, 9vw, 9.5rem);
    --maxw: 1320px;
    --r: 14px;
    --r-lg: 22px;
    --shadow: 0 18px 50px -22px rgba(16, 35, 66, .45);
    --shadow-sm: 0 8px 24px -14px rgba(16, 35, 66, .4);
    --ease: cubic-bezier(.22, 1, .36, 1);
}

*, *::before, *::after { box-sizing: border-box; }

/* The legacy base.css pins the root to 62.5% (10px), which crushes this
   redesign's entire rem/clamp type scale to ~64% of its intended size.
   modern.css loads last, so restore a standard 16px root for the 2026 pages. */
html { font-size: 100%; -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body.sc2026 {
    margin: 0;
    background: var(--paper);
    color: var(--ink);
    font-family: "Hanken Grotesk", system-ui, sans-serif;
    font-size: var(--fs-body);
    line-height: 1.62;
    font-weight: 400;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
}
body.sc2026 img { max-width: 100%; display: block; }
body.sc2026 a { color: inherit; text-decoration: none; }

/* legacy framework wrappers shouldn't constrain the new full-bleed layout */
body.sc2026 #container,
body.sc2026 .box,
body.sc2026 #mnav-wrapper,
body.sc2026 .content_box { all: unset; display: block; }

::selection { background: var(--orange); color: #fff; }

/* ---------- shared primitives ---------- */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }

.eyebrow {
    font-size: var(--fs-eyebrow);
    font-weight: 700;
    letter-spacing: .26em;
    text-transform: uppercase;
    color: var(--orange-600);
    display: inline-flex;
    align-items: center;
    gap: .7em;
    margin: 0 0 1.1rem;
}
.eyebrow::before {
    content: "";
    width: 2.4em; height: 2px;
    background: var(--orange);
    display: inline-block;
}
.eyebrow.on-dark { color: var(--orange); }

.display, h1.display, h2.display {
    font-family: "Anton", "Hanken Grotesk", sans-serif;
    font-weight: 400;
    line-height: .92;
    letter-spacing: -.005em;
    text-transform: uppercase;
    margin: 0;
}
.h2 { font-size: var(--fs-h2); }
.lead { font-size: var(--fs-lead); line-height: 1.45; color: var(--ink); max-width: 46ch; }
.muted { color: var(--ink-soft); }
.accent { color: var(--orange); }

/* oversized section index numeral */
.index-num {
    display: block;
    font-family: "Anton", sans-serif;
    font-size: var(--fs-index);
    line-height: .8;
    color: transparent;
    -webkit-text-stroke: 2px var(--line);
    letter-spacing: .02em;
    user-select: none;
    margin-bottom: .3rem;
}

/* buttons */
.btn {
    --bg: var(--orange); --fg: #fff;
    display: inline-flex; align-items: center; gap: .6em;
    font-family: "Hanken Grotesk", sans-serif;
    font-weight: 800; font-size: .95rem;
    letter-spacing: .04em; text-transform: uppercase;
    background: var(--bg); color: var(--fg);
    padding: 1.05em 1.7em; border: 0; border-radius: 100px;
    cursor: pointer;
    transition: transform .25s var(--ease), box-shadow .25s var(--ease), background .2s var(--ease);
    will-change: transform;
}
.btn:hover { transform: translateY(-2px); box-shadow: 0 14px 30px -12px rgba(232,125,32,.7); background: #ffa64f; }
.btn .arrow { transition: transform .25s var(--ease); }
.btn:hover .arrow { transform: translateX(4px); }
.btn--ghost {
    --bg: transparent; --fg: var(--ink);
    border: 2px solid var(--ink); padding: calc(1.05em - 2px) calc(1.7em - 2px);
}
.btn--ghost:hover { background: var(--ink); color: var(--paper); box-shadow: none; }
.btn--light { --bg:#fff; --fg: var(--blue-900); }
.btn--light:hover { background: var(--paper); }
.btn--ghost-light { --bg: transparent; --fg: #fff; border: 2px solid rgba(255,255,255,.55); padding: calc(1.05em - 2px) calc(1.7em - 2px); }
.btn--ghost-light:hover { background: #fff; color: var(--blue-900); box-shadow: none; }

/* ============================ HEADER ============================ */
.sc-header {
    position: fixed; inset: 0 0 auto 0; z-index: 100;
    display: flex; align-items: center; justify-content: space-between;
    gap: 1.5rem;
    padding: clamp(.7rem, 1.6vw, 1.2rem) var(--gutter);
    background: color-mix(in oklab, var(--paper) 82%, transparent);
    -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
    border-bottom: 1px solid transparent;
    transition: background .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease), padding .3s var(--ease);
}
.sc-header.is-stuck {
    background: color-mix(in oklab, var(--paper) 93%, transparent);
    box-shadow: 0 14px 34px -26px rgba(16, 35, 66, .65);
    border-bottom-color: var(--line);
    padding-block: clamp(.5rem, 1vw, .8rem);
}
.sc-header__logo img { height: clamp(46px, 5.2vw, 68px); width: auto; transition: height .3s var(--ease); }
.sc-header.is-stuck .sc-header__logo img { height: clamp(40px, 4vw, 52px); }

.sc-nav { display: flex; align-items: center; gap: clamp(1rem, 2vw, 2.1rem); }
.sc-nav__links { display: flex; gap: clamp(1rem, 1.8vw, 2rem); list-style: none; margin: 0; padding: 0; }
.sc-nav__links a {
    font-weight: 600; font-size: .94rem; letter-spacing: .02em;
    color: var(--ink); position: relative; padding-block: .3rem;
}
.sc-nav__links a::after {
    content: ""; position: absolute; left: 0; bottom: 0; height: 2px; width: 100%;
    background: var(--orange); transform: scaleX(0); transform-origin: left;
    transition: transform .3s var(--ease);
}
.sc-nav__links a:hover::after { transform: scaleX(1); }
.sc-header .btn { padding: .8em 1.35em; font-size: .82rem; }

.sc-burger { display: none; flex-direction: column; gap: 5px; background: none; border: 0; cursor: pointer; padding: 8px; }
.sc-burger span { width: 26px; height: 2.5px; background: var(--ink); border-radius: 2px; transition: transform .3s var(--ease), opacity .2s; }

/* mobile drawer */
.sc-drawer { position: fixed; inset: 0; z-index: 200; visibility: hidden; }
.sc-drawer__scrim { position: absolute; inset: 0; background: rgba(11,39,71,.5); opacity: 0; transition: opacity .35s var(--ease); }
.sc-drawer__panel {
    position: absolute; inset: 0 0 0 auto; width: min(86vw, 400px);
    background: var(--blue-900); color: #fff;
    padding: 5.5rem var(--gutter) 2rem; display: flex; flex-direction: column; gap: .3rem;
    transform: translateX(100%); transition: transform .4s var(--ease);
}
.sc-drawer.is-open { visibility: visible; }
.sc-drawer.is-open .sc-drawer__scrim { opacity: 1; }
.sc-drawer.is-open .sc-drawer__panel { transform: none; }
.sc-drawer__panel a { font-family: "Anton", sans-serif; text-transform: uppercase; font-size: 1.7rem; letter-spacing: .01em; padding: .55rem 0; border-bottom: 1px solid rgba(255,255,255,.12); }
.sc-drawer__panel a:hover { color: var(--orange); }
.sc-drawer__close { position: absolute; top: 1.4rem; right: var(--gutter); background: none; border: 0; color: #fff; font-size: 2rem; cursor: pointer; line-height: 1; }
.sc-drawer__cta { margin-top: 1.4rem; }

/* ============================ HERO ============================ */
.hero { position: relative; min-height: 100svh; display: flex; align-items: flex-end; overflow: hidden; color: #fff; }
.hero__media { position: absolute; inset: 0; z-index: -2; }
.hero__media video, .hero__media img { width: 100%; height: 100%; object-fit: cover; }
.hero::after {
    content: ""; position: absolute; inset: 0; z-index: -1;
    background: linear-gradient(180deg, rgba(11,39,71,.55) 0%, rgba(11,39,71,.18) 38%, rgba(11,39,71,.82) 100%);
}
.hero__inner { width: 100%; max-width: var(--maxw); margin-inline: auto; padding: var(--gutter); padding-bottom: clamp(3rem, 7vh, 6rem); }
.hero__title { font-size: var(--fs-display); }
.hero__title .ln { display: block; overflow: hidden; }
.hero__title .ln > span { display: block; }
.hero__title .accent { color: var(--orange); }
.hero__sub { max-width: 40ch; font-size: var(--fs-lead); margin: 1.4rem 0 2rem; color: rgba(255,255,255,.9); }
.hero__cta { display: flex; flex-wrap: wrap; gap: .9rem; align-items: center; }
.hero__meta { position: absolute; top: 0; right: 0; height: 100%; display: none; }
.scroll-cue { position: absolute; right: var(--gutter); bottom: clamp(3rem,7vh,6rem); writing-mode: vertical-rl; font-size: .72rem; letter-spacing: .26em; text-transform: uppercase; font-weight: 700; opacity: .85; display: flex; align-items: center; gap: 1rem; }
.scroll-cue::after { content: ""; width: 1px; height: 54px; background: rgba(255,255,255,.7); animation: cue 1.8s var(--ease) infinite; transform-origin: top; }
@keyframes cue { 0%,100% { transform: scaleY(.3); opacity:.4 } 50% { transform: scaleY(1); opacity:1 } }

/* ============================ SECTION SHELL ============================ */
.section { padding-block: var(--section-y); position: relative; }
.section--paper2 { background: var(--paper-2); }
.section-head { display: grid; grid-template-columns: auto 1fr; gap: clamp(1rem, 3vw, 3rem); align-items: end; margin-bottom: clamp(2.5rem, 5vw, 4.5rem); }

/* ---------- intro / welcome ---------- */
.intro__grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2rem, 5vw, 5rem); align-items: center; }
.intro__copy h2 { margin-bottom: 1.5rem; }
.intro__copy .lead { max-width: 52ch; margin-bottom: 1.3rem; }
.intro__figure { position: relative; }
.intro__figure img { border-radius: var(--r-lg); aspect-ratio: 4/5; object-fit: cover; box-shadow: var(--shadow); }
.intro__tag {
    position: absolute; left: -1.5rem; bottom: 1.8rem;
    background: var(--orange); color: #fff; font-family: "Anton", sans-serif; text-transform: uppercase;
    padding: .9rem 1.3rem; border-radius: 12px; line-height: .95; box-shadow: var(--shadow-sm);
}
.intro__tag b { display: block; font-size: 2.2rem; }
.intro__tag span { font-size: .8rem; letter-spacing: .1em; font-family: "Hanken Grotesk"; font-weight: 700; }

/* ---------- facility ---------- */
.facility__list { display: grid; gap: clamp(1.2rem, 2.5vw, 2rem); grid-template-columns: repeat(3, 1fr); }
.fac {
    position: relative; border-radius: var(--r-lg); overflow: hidden; min-height: clamp(360px, 42vw, 540px);
    display: flex; align-items: flex-end; color: #fff; isolation: isolate;
}
.fac img { position: absolute; inset: 0; z-index: -2; height: 100%; width: 100%; object-fit: cover; transition: transform .8s var(--ease); }
.fac::after { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, rgba(11,39,71,0) 30%, rgba(11,39,71,.9) 100%); }
.fac:hover img { transform: scale(1.06); }
.fac__body { padding: clamp(1.3rem, 2vw, 2rem); }
.fac__kicker { font-size: .72rem; font-weight: 800; letter-spacing: .2em; text-transform: uppercase; color: var(--orange); }
.fac__name { font-family: "Anton", sans-serif; text-transform: uppercase; font-size: clamp(1.7rem, 2.4vw, 2.5rem); line-height: .95; margin: .3rem 0 .5rem; }
.fac__desc { font-size: .96rem; color: rgba(255,255,255,.85); margin: 0; }

/* ---------- rental band ---------- */
.rental { background: var(--blue-900); color: #fff; position: relative; overflow: hidden; }
.rental::before {
    content: ""; position: absolute; inset: 0; z-index: 0; opacity: .5;
    background:
      radial-gradient(120% 120% at 100% 0%, rgba(248,151,59,.35), transparent 45%),
      radial-gradient(90% 90% at 0% 100%, rgba(21,81,150,.55), transparent 50%);
}
.rental .wrap { position: relative; z-index: 1; }
.rental__grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(2rem,5vw,5rem); align-items: center; }
.rental__copy .lead { color: rgba(255,255,255,.86); max-width: 50ch; }
.rental__copy h2 { color: #fff; margin-bottom: 1.4rem; }
.rental__side { border-left: 2px solid rgba(255,255,255,.16); padding-left: clamp(1.5rem,3vw,2.6rem); }
.rental__side ul { list-style: none; margin: 0 0 1.8rem; padding: 0; display: grid; gap: 1rem; }
.rental__side li { display: flex; gap: .9rem; align-items: flex-start; font-size: 1.02rem; }
.rental__side li i { color: var(--orange); margin-top: .25em; }

/* ---------- events ---------- */
.events:not(:has(.ev)) { display: none; }
.ev {
    display: grid; grid-template-columns: clamp(220px, 28%, 320px) 1fr; gap: clamp(1.5rem, 3vw, 3rem);
    background: var(--card); border: 1px solid var(--line); border-radius: var(--r-lg); overflow: hidden;
    box-shadow: var(--shadow-sm); transition: transform .3s var(--ease), box-shadow .3s var(--ease);
}
.ev:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.ev__poster { background: #0b0b0b; }
.ev__poster img { height: 100%; width: 100%; object-fit: cover; }
.ev__body { padding: clamp(1.6rem, 2.5vw, 2.6rem); align-self: center; }
.ev__date { display: inline-flex; align-items: center; gap: .5em; background: var(--orange); color: #fff; font-weight: 800; font-size: .82rem; letter-spacing: .03em; padding: .45em .9em; border-radius: 100px; }
.ev__name { font-family: "Anton", sans-serif; text-transform: uppercase; color: var(--blue); font-size: clamp(1.5rem, 2.6vw, 2.4rem); line-height: .98; margin: 1rem 0 .8rem; }
.ev__meta { color: var(--ink-soft); margin: 0 0 .5rem; font-size: 1rem; }
.ev__cta { display: inline-flex; align-items: center; gap: .5em; margin-top: 1rem; font-weight: 800; text-transform: uppercase; letter-spacing: .04em; color: var(--blue); }
.ev:hover .ev__cta { color: var(--orange-600); }
.ev__cta .arrow { transition: transform .25s var(--ease); }
.ev:hover .ev__cta .arrow { transform: translateX(4px); }

/* ---------- partners ---------- */
.partners-grid { display: flex; flex-wrap: wrap; gap: clamp(.8rem, 1.5vw, 1.3rem); }
.pchip {
    flex: 1 1 160px; max-width: 210px; aspect-ratio: 5/4;
    display: flex; flex-direction: column; align-items: center; justify-content: center; gap: .9rem;
    padding: 1.4rem;
    background: var(--card); border: 1px solid var(--line); border-radius: var(--r);
    transition: transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
}
.pchip:hover { transform: translateY(-4px); box-shadow: var(--shadow-sm); border-color: transparent; }
.pchip img { max-height: 66px; width: auto; object-fit: contain; filter: saturate(.4) opacity(.8); transition: filter .3s var(--ease); }
.pchip:hover img { filter: none; }
.pchip__name { font-size: .72rem; font-weight: 600; letter-spacing: .05em; text-transform: uppercase; color: var(--ink-soft); text-align: center; line-height: 1.25; }

/* ============================ FOOTER ============================ */
.sc-footer { background: var(--ink); color: var(--paper); padding-block: clamp(3.5rem, 6vw, 5.5rem) 2rem; }
.sc-footer__top { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: clamp(2rem, 4vw, 4rem); align-items: start; }
.sc-footer__brand .display { font-size: clamp(2.4rem, 4vw, 3.6rem); color: var(--paper); line-height: .9; }
.sc-footer__brand .accent { color: var(--orange); }
.sc-footer p, .sc-footer address { color: rgba(244,239,229,.7); font-style: normal; line-height: 1.8; }
.sc-footer h4 { font-size: .76rem; letter-spacing: .2em; text-transform: uppercase; color: var(--orange); margin: 0 0 1.1rem; font-weight: 800; }
.sc-footer__col ul { list-style: none; margin: 0; padding: 0; display: grid; gap: .6rem; }
.sc-footer__col a { color: rgba(244,239,229,.82); }
.sc-footer__col a:hover { color: var(--orange); }
.sc-footer__bar { margin-top: clamp(2.5rem, 4vw, 4rem); padding-top: 1.5rem; border-top: 1px solid rgba(244,239,229,.14); display: flex; justify-content: space-between; flex-wrap: wrap; gap: 1rem; font-size: .85rem; color: rgba(244,239,229,.55); }
.sc-footer__social a { display: inline-grid; place-items: center; width: 40px; height: 40px; border: 1px solid rgba(244,239,229,.25); border-radius: 50%; color: var(--paper); margin-right: .5rem; transition: background .25s var(--ease), color .25s, border-color .25s; }
.sc-footer__social a:hover { background: var(--orange); border-color: var(--orange); color: #fff; }

/* ============================ MOTION ============================ */
[data-reveal] { opacity: 0; transform: translateY(28px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
[data-reveal].is-in { opacity: 1; transform: none; }
[data-reveal-stagger] > * { opacity: 0; transform: translateY(24px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
[data-reveal-stagger].is-in > * { opacity: 1; transform: none; }
[data-reveal-stagger].is-in > *:nth-child(2) { transition-delay: .08s; }
[data-reveal-stagger].is-in > *:nth-child(3) { transition-delay: .16s; }
[data-reveal-stagger].is-in > *:nth-child(4) { transition-delay: .24s; }
[data-reveal-stagger].is-in > *:nth-child(5) { transition-delay: .32s; }

/* ============================ RESPONSIVE ============================ */
@media (max-width: 1024px) {
    .sc-nav__links, .sc-header .btn--header { display: none; }
    .sc-burger { display: flex; }
    .intro__grid, .rental__grid { grid-template-columns: 1fr; }
    .rental__side { border-left: 0; border-top: 2px solid rgba(255,255,255,.16); padding-left: 0; padding-top: 2rem; }
    .facility__list { grid-template-columns: 1fr 1fr; }
    .sc-footer__top { grid-template-columns: 1fr 1fr; }
    .sc-footer__brand { grid-column: 1 / -1; }
}
@media (max-width: 680px) {
    .section-head { grid-template-columns: 1fr; }
    .facility__list { grid-template-columns: 1fr; }
    .ev { grid-template-columns: 1fr; }
    .ev__poster { aspect-ratio: 4/3; }
    .intro__tag { left: 1rem; }
    .sc-footer__top { grid-template-columns: 1fr; }
    .scroll-cue { display: none; }
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; scroll-behavior: auto !important; }
    [data-reveal], [data-reveal-stagger] > * { opacity: 1 !important; transform: none !important; }
}


/* =====================================================================
   INNER PAGES (About, Training, Contact, Calendar, …)
   Shared components built on the same system as the home page.
   ===================================================================== */

/* ---- page hero (title band) ---- */
.page-hero {
    position: relative; isolation: isolate; color: #fff;
    display: flex; align-items: flex-end; overflow: hidden;
    min-height: clamp(300px, 44vh, 460px);
    padding: clamp(7rem, 13vh, 9.5rem) 0 clamp(2.4rem, 5vh, 3.6rem);
    background-color: var(--blue-900);
    background-image:
        radial-gradient(110% 120% at 100% 0%, rgba(248,151,59,.30), transparent 46%),
        radial-gradient(90% 90% at 0% 100%, rgba(21,81,150,.55), transparent 55%);
}
.page-hero__media { position: absolute; inset: 0; z-index: 0; }
.page-hero__media img { width: 100%; height: 100%; object-fit: cover; }
.page-hero__media::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(11,39,71,.55), rgba(11,39,71,.42) 45%, rgba(11,39,71,.9));
}
.page-hero > .wrap { position: relative; z-index: 1; width: 100%; }
.page-hero .index-num { -webkit-text-stroke-color: rgba(255,255,255,.25); margin-bottom: .1rem; }
.page-hero h1 { font-size: var(--fs-h2); margin: .15rem 0 0; }
.page-hero__sub { max-width: 56ch; color: rgba(255,255,255,.86); font-size: var(--fs-lead); line-height: 1.45; margin: 1.1rem 0 0; }

/* ---- prose (rich body copy) ---- */
.prose { max-width: 72ch; }
.prose > p { margin: 0 0 1.35rem; color: var(--ink); line-height: 1.78; }
.prose > p.lead { font-size: var(--fs-lead); line-height: 1.5; }
.prose a { color: var(--blue); font-weight: 600; text-decoration: underline; text-decoration-color: var(--orange); text-underline-offset: 3px; text-decoration-thickness: 2px; }
.prose a:hover { color: var(--orange-600); }
.prose h2, .prose h3 { font-family: "Anton", sans-serif; text-transform: uppercase; color: var(--ink); line-height: 1; margin: 2.2rem 0 1rem; }

/* two-column inner layout: copy + aside */
.inner-split { display: grid; grid-template-columns: 1.15fr .85fr; gap: clamp(2rem, 5vw, 5rem); align-items: start; }
.inner-split__aside img { border-radius: var(--r-lg); box-shadow: var(--shadow); }

/* ---- forms ---- */
.sc-form { display: grid; gap: 1.15rem; max-width: 640px; }
.sc-form__row { display: grid; gap: 1.15rem; grid-template-columns: 1fr 1fr; }
.sc-field { display: grid; gap: .45rem; }
.sc-form [hidden] { display: none !important; }
.sc-field > label { font-weight: 700; font-size: .78rem; letter-spacing: .05em; text-transform: uppercase; color: var(--ink-soft); }
.sc-field input, .sc-field select, .sc-field textarea {
    font-family: "Hanken Grotesk", sans-serif; font-size: 1rem; color: var(--ink);
    background: var(--card); border: 1.5px solid var(--line); border-radius: 12px;
    padding: .85rem 1rem; width: 100%;
    transition: border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.sc-field input::placeholder, .sc-field textarea::placeholder { color: color-mix(in oklab, var(--ink-soft) 65%, transparent); }
.sc-field input:focus, .sc-field select:focus, .sc-field textarea:focus {
    outline: none; border-color: var(--blue); box-shadow: 0 0 0 4px rgba(21,81,150,.12);
}
.sc-field textarea { min-height: 150px; resize: vertical; }
.sc-form__status { font-weight: 600; color: var(--blue); min-height: 1.2em; }

/* ---- contact info rail ---- */
.contact-card { background: var(--card); border: 1px solid var(--line); border-radius: var(--r-lg); padding: clamp(1.5rem, 3vw, 2.2rem); box-shadow: var(--shadow-sm); }
.contact-card h3 { font-family: "Anton", sans-serif; text-transform: uppercase; color: var(--blue); margin: 0 0 1rem; font-size: 1.5rem; }
.contact-line { display: flex; gap: .8rem; align-items: flex-start; margin-bottom: .9rem; color: var(--ink); }
.contact-line i { color: var(--orange); margin-top: .25em; width: 1.1em; text-align: center; }
.contact-line a { color: var(--ink); }
.contact-line a:hover { color: var(--orange-600); }
.contact-line--muted { flex-wrap: wrap; font-size: .88rem; color: var(--ink-soft); }
.contact-line--muted a { color: var(--ink-soft); font-size: .92rem; }
.contact-line--muted i { font-size: .9em; }
.contact-line__hint { flex-basis: 100%; margin-left: 1.9em; font-size: .74rem; color: var(--ink-soft); opacity: .8; }

/* ---- training partner rows ---- */
.partner { display: grid; grid-template-columns: 210px 1fr; gap: clamp(1.5rem, 3vw, 3rem); align-items: center; padding: clamp(1.8rem, 3.5vw, 2.8rem) 0; border-top: 1px solid var(--line); }
.partner:first-of-type { border-top: 0; padding-top: 0; }
.partner__logo { display: grid; place-items: center; background: var(--card); border: 1px solid var(--line); border-radius: var(--r); padding: 1.6rem; aspect-ratio: 3/2; }
.partner__logo img { max-height: 96px; max-width: 100%; width: auto; object-fit: contain; }
.partner__name { font-family: "Anton", sans-serif; text-transform: uppercase; font-size: clamp(1.5rem, 2.4vw, 2.1rem); color: var(--blue); line-height: 1; margin: 0 0 .7rem; }
.partner__name a { color: inherit; }
.partner__name a:hover { color: var(--orange-600); }
.partner__desc { color: var(--ink-soft); margin: 0 0 1rem; max-width: 60ch; }
.partner__contact { display: flex; flex-wrap: wrap; gap: .4rem 1.4rem; }
.partner__contact a { display: inline-flex; gap: .5em; align-items: center; color: var(--ink-soft); font-weight: 600; }
.partner__contact a:hover { color: var(--orange-600); }

/* ---- photo gallery ---- */
.gallery-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); gap: clamp(.6rem, 1.2vw, 1rem); }
.gallery-grid a { display: block; overflow: hidden; border-radius: var(--r); }
.gallery-grid img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; transition: transform .5s var(--ease); }
.gallery-grid a:hover img { transform: scale(1.06); }
.gallery-grid .span-2 { grid-column: span 2; }

/* ---- embeds (calendar / map) ---- */
.embed-frame { border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--line); box-shadow: var(--shadow-sm); background: var(--card); }
.embed-frame iframe { display: block; width: 100%; border: 0; }
.embed-cal iframe { height: min(78vh, 720px); }
.embed-map iframe { height: 420px; }

@media (max-width: 900px) {
    .inner-split { grid-template-columns: 1fr; }
}
@media (max-width: 680px) {
    .sc-form__row { grid-template-columns: 1fr; }
    .partner { grid-template-columns: 1fr; }
    .partner__logo { max-width: 220px; }
    .gallery-grid .span-2 { grid-column: span 1; }
}
