/* ===== Linn Creek Kickboxing Club — shared site styles ===== */
:root{
  --sand:#E7DECF; --sand-2:#EFE9DC; --paper:#F6F1E7;
  --ink:#26221C; --ink-soft:#4C453A; --muted:#837A69; --muted-2:#A79D89;
  --line:#D7CDB8; --clay:#B95B36; --clay-deep:#8F4527;
  --pine:#3B5142; --pine-soft:#5B6E5C; --slate:#53707A; --ochre:#C6932E;
  --espresso:#211D17; --espresso-2:#2A251D; --on-dark:#ECE2D0; --on-dark-muted:#A99E89;
  --maxw:1180px; --r:5px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--sand);color:var(--ink);font-family:'Hanken Grotesk',sans-serif;font-size:17px;line-height:1.68;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.05;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
h1,h2,h3,.display{font-family:'Fraunces',serif;font-weight:900;line-height:1.0;letter-spacing:-.015em}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
.accent{color:var(--clay)}
.kicker{font-family:'Hanken Grotesk',sans-serif;text-transform:uppercase;letter-spacing:.26em;font-size:.72rem;font-weight:700;color:var(--clay)}
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:'Hanken Grotesk',sans-serif;font-weight:700;letter-spacing:.02em;font-size:1rem;padding:14px 28px;border-radius:40px;cursor:pointer;border:1.5px solid transparent;transition:transform .16s ease,background .2s ease,color .2s ease,border-color .2s ease}
.btn-primary{background:var(--clay);color:var(--paper)}
.btn-primary:hover{background:var(--ink);color:var(--paper);transform:translateY(-2px)}
.btn-ghost{border-color:var(--ink);color:var(--ink);background:transparent}
.btn-ghost:hover{background:var(--ink);color:var(--paper);transform:translateY(-2px)}
.btn-light{border-color:var(--on-dark);color:var(--on-dark);background:transparent}
.btn-light:hover{background:var(--on-dark);color:var(--espresso);transform:translateY(-2px)}

/* header */
header{position:sticky;top:0;z-index:100;background:rgba(231,222,207,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{display:flex;align-items:center;gap:13px}
.brand .markwrap{width:44px;height:44px;flex:none}
.brand .name{font-family:'Fraunces',serif;font-weight:900;font-size:1.28rem;line-height:.92;letter-spacing:-.01em}
.brand .name small{display:block;font-family:'Hanken Grotesk';font-size:.58rem;letter-spacing:.28em;color:var(--muted);font-weight:600;text-transform:uppercase;margin-top:3px}
.nav-links{display:flex;align-items:center;gap:24px}
.nav-links a{font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;font-weight:600;color:var(--ink-soft);transition:color .15s}
.nav-links a:hover{color:var(--clay)}
.nav-links a.current{color:var(--clay)}
.nav-phone{font-family:'Fraunces',serif;font-weight:600;font-size:1.05rem;color:var(--ink)}
.nav-phone:hover{color:var(--clay)}
.menu-btn{display:none;background:none;border:0;color:var(--ink);cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.menu-btn span{width:26px;height:2px;background:var(--ink);display:block}

/* homepage hero */
.hero{position:relative;padding:96px 0 100px;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(820px 520px at 82% -8%,rgba(198,147,46,.22),transparent 62%),radial-gradient(760px 600px at 110% 60%,rgba(185,91,54,.14),transparent 60%),radial-gradient(700px 520px at -8% 112%,rgba(59,81,66,.10),transparent 60%)}
.topo{position:absolute;pointer-events:none;opacity:.5}
.topo.tr{top:-120px;right:-160px;width:620px;color:var(--clay)}
.topo.bl{bottom:-200px;left:-200px;width:560px;color:var(--slate);opacity:.32}
.topo ellipse{fill:none;stroke:currentColor;stroke-width:1.1}
.hero .wrap{position:relative;z-index:2}
.hero-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:50px;align-items:center}
.hero h1{font-size:clamp(3rem,8.2vw,6.4rem);margin:20px 0 26px;letter-spacing:-.02em}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .line span{display:block;transform:translateY(106%);animation:rise .85s cubic-bezier(.16,1,.3,1) forwards}
.hero h1 .line:nth-child(1) span{animation-delay:.08s}
.hero h1 .line:nth-child(2) span{animation-delay:.2s}
.hero h1 .line:nth-child(3) span{animation-delay:.32s}
.hero .sub{max-width:46ch;color:var(--ink-soft);font-size:1.13rem;margin-bottom:34px;opacity:0;animation:fade .8s ease .55s forwards}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap;opacity:0;animation:fade .8s ease .68s forwards}
.trust{display:flex;gap:30px;margin-top:38px;flex-wrap:wrap;opacity:0;animation:fade .8s ease .82s forwards}
.trust div{font-size:.82rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.trust strong{display:block;font-family:'Fraunces';font-size:2rem;color:var(--ink);font-weight:900;line-height:1}
.hero-badge{display:flex;justify-content:center;opacity:0;animation:fade 1s ease .42s forwards}
.hero-badge .crest{width:100%;max-width:320px;height:auto;filter:drop-shadow(0 18px 34px rgba(60,40,20,.22))}
@keyframes rise{to{transform:translateY(0)}}
@keyframes fade{to{opacity:1}}

/* sections */
section{padding:96px 0;position:relative}
.sec-head{max-width:700px;margin-bottom:56px}
.sec-head h2{font-size:clamp(2.2rem,5vw,3.5rem);margin:16px 0 18px}
.sec-head p{color:var(--ink-soft);font-size:1.08rem}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* USP band */
.usp{background:var(--espresso);color:var(--on-dark);border-top:1px solid #3c352a;border-bottom:1px solid #3c352a}
.usp .wrap{padding-top:46px;padding-bottom:46px;text-align:center;max-width:920px}
.usp p{font-family:'Fraunces';font-weight:600;font-size:clamp(1.3rem,3.4vw,1.9rem);line-height:1.3;color:var(--on-dark)}
.usp p .accent{color:var(--ochre)}
.usp .small{font-family:'Hanken Grotesk';font-weight:400;font-size:1rem;color:var(--on-dark-muted);margin-top:14px}

/* the road */
.road{background:var(--espresso);color:var(--on-dark);position:relative;overflow:hidden}
.road .topo-dark{position:absolute;top:-160px;left:-140px;width:560px;color:#fff;opacity:.05;pointer-events:none}
.road .topo-dark ellipse{fill:none;stroke:currentColor;stroke-width:1.2}
.road .wrap{position:relative;z-index:2}
.road .sec-head h2{color:var(--on-dark)} .road .sec-head p{color:var(--on-dark-muted)}
.road-intro{max-width:760px;margin-bottom:64px}
.road-intro .kicker{color:var(--ochre)}
.trail{display:grid;grid-template-columns:repeat(4,1fr);position:relative}
.trail::before{content:"";position:absolute;top:33px;left:11%;right:11%;border-top:2px dotted var(--clay);opacity:.65;z-index:0}
.stop{position:relative;z-index:1;padding:0 18px;text-align:center}
.stop .pin{width:66px;height:66px;border-radius:50%;margin:0 auto 22px;background:var(--espresso);border:2px solid var(--clay);display:flex;align-items:center;justify-content:center;color:var(--ochre);position:relative;z-index:2}
.stop .pin svg{width:32px;height:32px}
.stop .place{font-family:'Fraunces';font-weight:900;font-size:1.45rem;line-height:1.05;margin-bottom:4px}
.stop .state{font-size:.72rem;text-transform:uppercase;letter-spacing:.18em;color:var(--ochre);font-weight:700;margin-bottom:6px}
.stop .mentor{font-size:.86rem;color:var(--on-dark);font-weight:600;margin-bottom:10px}
.stop .mentor em{color:var(--on-dark-muted);font-weight:400;font-style:normal}
.stop p{font-size:.95rem;color:var(--on-dark-muted);line-height:1.6}
.road-foot{margin-top:60px;text-align:center;font-family:'Fraunces';font-style:italic;font-size:1.35rem;color:var(--on-dark);max-width:60ch;margin-left:auto;margin-right:auto;line-height:1.4}

/* values */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.val{border-top:2px solid var(--clay);padding-top:24px}
.val h3{font-size:1.6rem;margin-bottom:10px}
.val p{color:var(--ink-soft);font-size:.98rem}

/* programs / card grid (reused for related links) */
.programs{background:var(--sand-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.prog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.prog{display:block;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:36px 32px;position:relative;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease;color:inherit}
.prog:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(60,40,20,.10)}
.prog .ic{font-family:'Fraunces';font-weight:900;font-size:2.4rem;color:var(--clay);opacity:.35;position:absolute;top:20px;right:28px}
.prog h3{font-size:1.65rem;margin-bottom:12px}
.prog p{color:var(--ink-soft);font-size:.97rem;margin-bottom:16px}
.prog .tag{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:600}
.prog .more{display:inline-block;margin-top:14px;font-weight:700;color:var(--clay);font-size:.9rem}
.price{font-family:'Fraunces',serif;font-weight:900;font-size:1.5rem;color:var(--clay);display:block;margin:4px 0 10px}
.price small{font-family:'Hanken Grotesk',sans-serif;font-weight:600;font-size:.8rem;color:var(--muted);letter-spacing:.02em}

/* schedule table */
.sched-table{width:100%;border-collapse:collapse;font-size:.97rem}
.sched-table th{font-family:'Hanken Grotesk';font-weight:700;text-transform:uppercase;letter-spacing:.08em;text-align:left;padding:16px 18px;color:var(--clay);border-bottom:2px solid var(--line)}
.sched-table td{padding:16px 18px;border-bottom:1px solid var(--line);color:var(--ink-soft)}
.sched-table td:first-child{color:var(--ink);font-weight:600;white-space:nowrap}
.sched-table tr:hover td{background:var(--sand-2)}
.sched-note{margin-top:20px;color:var(--muted);font-size:.86rem}

/* offer / CTA band */
.offer{background:linear-gradient(150deg,var(--pine),#2c3d31 60%);color:var(--on-dark);position:relative;overflow:hidden}
.offer .topo-dark{position:absolute;bottom:-180px;right:-140px;width:520px;color:#fff;opacity:.06;pointer-events:none}
.offer .topo-dark ellipse{fill:none;stroke:currentColor;stroke-width:1.2}
.offer .wrap{position:relative;z-index:2;text-align:center;max-width:760px}
.offer .kicker{color:var(--ochre)}
.offer h2{font-size:clamp(2.4rem,6vw,4.2rem);margin:16px 0 18px;color:var(--on-dark)}
.offer p{color:var(--on-dark-muted);font-size:1.14rem;margin-bottom:30px}
.offer .cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* location */
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.loc-grid h2{font-size:clamp(2rem,4.6vw,3.1rem);margin-bottom:20px}
.loc-grid p{color:var(--ink-soft);margin-bottom:16px}
.nap{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:30px}
.nap dt{font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--clay);font-weight:700;margin-top:20px}
.nap dt:first-child{margin-top:0}
.nap dd{font-size:1.05rem;color:var(--ink);margin-top:4px}
.nap dd a:hover{color:var(--clay)}
.areas{display:flex;flex-wrap:wrap;gap:9px;margin-top:14px}
.areas span{font-size:.82rem;border:1px solid var(--line);padding:6px 13px;border-radius:40px;color:var(--ink-soft)}
.areas a{display:inline-flex}
.areas a:hover span{border-color:var(--clay);color:var(--clay)}
.map-embed{aspect-ratio:1/1;border-radius:var(--r);border:1px solid var(--line);background:var(--paper);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px;text-align:center;padding:32px}
.map-embed .pin{width:46px;height:46px;color:var(--clay)}
.map-embed strong{font-family:'Fraunces';font-size:1.4rem}
.map-embed p{color:var(--muted);font-size:.84rem;max-width:32ch}

/* testimonials (kept for when real reviews exist) */
.testi{background:var(--sand-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.quote{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:32px}
.quote .stars{color:var(--ochre);letter-spacing:3px;font-size:1rem;margin-bottom:14px}
.quote p{font-size:1.04rem;margin-bottom:18px;font-family:'Fraunces';font-weight:500;line-height:1.4}
.quote .who{font-weight:700;font-size:.95rem}
.quote .who small{display:block;color:var(--muted);font-size:.8rem;font-weight:400}

/* faq */
.faq .wrap{max-width:880px}
.faq details{border-bottom:1px solid var(--line);padding:4px 0}
.faq summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px;padding:24px 0;font-family:'Fraunces';font-weight:600;font-size:1.32rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{color:var(--clay);font-size:1.6rem;transition:transform .2s;line-height:1;flex:none}
.faq details[open] summary .pm{transform:rotate(45deg)}
.faq details p{color:var(--ink-soft);padding:0 0 26px;max-width:74ch}

/* footer */
footer{background:var(--espresso);color:var(--on-dark);padding:66px 0 32px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.1fr;gap:42px;margin-bottom:48px}
.foot-brand .brand{margin-bottom:18px}
.foot-brand .brand .name,.foot-brand .brand .name small{color:var(--on-dark)}
.foot-brand p{color:var(--on-dark-muted);font-size:.95rem;max-width:38ch}
.foot-col h4{font-family:'Fraunces';font-size:1.1rem;margin-bottom:16px;color:var(--on-dark)}
.foot-col a,.foot-col address{display:block;color:var(--on-dark-muted);font-size:.93rem;margin-bottom:10px;font-style:normal;line-height:1.5}
.foot-col a:hover{color:var(--ochre)}
.socials{display:flex;gap:12px;margin-top:6px}
.socials a{width:38px;height:38px;border:1px solid #3c352a;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--on-dark-muted);transition:.2s}
.socials a:hover{border-color:var(--ochre);color:var(--ochre)}
.socials svg{width:18px;height:18px}
.foot-bottom{border-top:1px solid #3c352a;padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:#7c7158;font-size:.82rem}

/* ===== inner-page components ===== */
.breadcrumb{font-size:.78rem;color:var(--muted);padding:18px 0 0;letter-spacing:.02em}
.breadcrumb a:hover{color:var(--clay)}
.breadcrumb span{color:var(--ink-soft)}
.page-hero{position:relative;overflow:hidden;padding:64px 0 56px}
.page-hero::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(700px 460px at 88% -20%,rgba(198,147,46,.18),transparent 60%),radial-gradient(620px 460px at -10% 120%,rgba(59,81,66,.08),transparent 60%)}
.page-hero .wrap{position:relative;z-index:2}
.page-hero h1{font-size:clamp(2.6rem,6.5vw,4.6rem);margin:14px 0 20px;max-width:18ch}
.page-hero .sub{max-width:54ch;color:var(--ink-soft);font-size:1.15rem;margin-bottom:28px}
.page-hero .cta-row{display:flex;gap:14px;flex-wrap:wrap}

.prose{padding:72px 0}
.prose .wrap{max-width:760px}
.prose h2{font-size:clamp(1.8rem,4vw,2.6rem);margin:48px 0 16px}
.prose h2:first-child{margin-top:0}
.prose h3{font-size:1.35rem;margin:28px 0 10px;font-family:'Fraunces';font-weight:600}
.prose p{margin-bottom:18px;color:var(--ink-soft)}
.prose p strong{color:var(--ink)}
.prose ul{list-style:none;margin:0 0 22px}
.prose ul li{position:relative;padding-left:30px;margin-bottom:12px;color:var(--ink-soft)}
.prose ul li::before{content:"";position:absolute;left:0;top:11px;width:12px;height:2px;background:var(--clay)}
.prose .lead{font-size:1.2rem;color:var(--ink);font-family:'Fraunces';font-weight:500;line-height:1.5}

.related{padding:80px 0;background:var(--sand-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.related .sec-head{margin-bottom:36px}

@media(max-width:900px){
  .hero-grid,.loc-grid{grid-template-columns:1fr;gap:42px}
  .hero-badge{order:-1;max-width:230px;margin:0 auto}
  .hero-badge .crest{max-width:230px}
  .values-grid,.testi-grid,.prog-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr;gap:34px}
  .trail{grid-template-columns:1fr}
  .trail::before{top:24px;bottom:24px;left:33px;right:auto;border-top:0;border-left:2px dotted var(--clay)}
  .stop{display:grid;grid-template-columns:66px 1fr;gap:20px;text-align:left;padding:0 0 36px}
  .stop:last-child{padding-bottom:0}
  .stop .pin{margin:0}
  .nav-links{position:fixed;inset:76px 0 auto 0;background:var(--sand-2);flex-direction:column;align-items:flex-start;gap:0;padding:10px 26px 22px;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .3s ease}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{padding:14px 0;width:100%;border-bottom:1px solid var(--line);font-size:.9rem}
  .nav-links .btn{margin-top:14px;width:100%;justify-content:center}
  .nav .nav-phone{display:none}
  .menu-btn{display:flex}
  section,.prose{padding:56px 0}
  .mobile-cta{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:90;background:var(--clay);color:var(--paper);align-items:center;justify-content:center;gap:8px;padding:15px;font-family:'Fraunces';font-weight:600;font-size:1.1rem;box-shadow:0 -8px 24px rgba(0,0,0,.22)}
  body{padding-bottom:56px}
}
.mobile-cta{display:none}
@media(max-width:560px){.trust{gap:22px}}
