
/* U.S. Taekwondo Hapkido unified site shell */
:root {
    --tkd-red: #d00000;
    --tkd-red-hot: #ff1a1a;
    --tkd-black: #030303;
    --tkd-panel: rgba(12,12,14,.96);
    --tkd-line: rgba(255, 0, 0, .72);
    --tkd-muted: #d8d8d8;
}

html { scroll-behavior: smooth; }

body {
    background:
        radial-gradient(circle at 20% 0%, rgba(255,0,0,.24), transparent 26%),
        radial-gradient(circle at 85% 14%, rgba(255,255,255,.06), transparent 22%),
        linear-gradient(135deg, #000 0%, #080808 45%, #1a0000 100%) !important;
    min-height: 100vh;
    position: relative;
    overflow-x: hidden;
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    opacity: .13;
    background:
        linear-gradient(120deg, transparent 0 82%, rgba(255,0,0,.85) 83%, transparent 84%),
        radial-gradient(circle, rgba(255,255,255,.55) 0 1px, transparent 1.4px);
    background-size: 260px 260px, 22px 22px;
    z-index: -1;
}

body::after {
    content: "";
    position: fixed;
    right: -180px;
    top: 120px;
    width: 520px;
    height: 520px;
    pointer-events: none;
    opacity: .12;
    background: url("brush-divider.svg") center/contain no-repeat;
    transform: rotate(-18deg);
    z-index: -1;
}

.site-brand-banner {
    background:
        linear-gradient(90deg, #050505, #210000 30%, #050505 70%),
        #050505;
    border-bottom: 3px solid var(--tkd-red);
    padding: 18px 18px 14px;
    box-shadow: 0 8px 35px rgba(0,0,0,.75), inset 0 -1px 0 rgba(255,255,255,.1);
    position: relative;
    overflow: hidden;
}

.site-brand-banner::before,
.site-brand-banner::after {
    content: "";
    position: absolute;
    top: 50%;
    width: 340px;
    height: 80px;
    background: url("brush-divider.svg") center/contain no-repeat;
    opacity: .38;
    transform: translateY(-50%);
    pointer-events: none;
}

.site-brand-banner::before {
    left: -90px;
}

.site-brand-banner::after {
    right: -90px;
    transform: translateY(-50%) scaleX(-1);
}

.site-brand-inner {
    max-width: 1350px;
    margin: 0 auto;
    border: 2px solid rgba(255,0,0,.8);
    background:
        linear-gradient(180deg, rgba(255,255,255,.95), rgba(232,232,232,.94));
    padding: 8px 18px;
    box-shadow: 0 0 22px rgba(255,0,0,.25), inset 0 0 0 2px rgba(0,0,0,.08);
    position: relative;
    z-index: 1;
}

.site-brand-inner img {
    display: block;
    width: 100%;
    max-width: 1200px;
    height: auto;
    margin: 0 auto;
}

.nav {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 0 !important;
    background:
        linear-gradient(180deg, #151515, #050505) !important;
    border-top: 1px solid rgba(255,255,255,.08) !important;
    border-bottom: 2px solid var(--tkd-red) !important;
    box-shadow: 0 8px 22px rgba(0,0,0,.55) !important;
    padding: 0 !important;
}

.nav a {
    color: #fff !important;
    padding: 11px 14px !important;
    text-decoration: none !important;
    font-weight: 900 !important;
    font-size: 14px !important;
    letter-spacing: .03em !important;
    text-transform: uppercase !important;
    border-right: 1px solid rgba(255,255,255,.08) !important;
    border-left: 1px solid rgba(255,0,0,.13) !important;
    background: linear-gradient(90deg, rgba(255,0,0,.08), transparent) !important;
}

.nav a:hover,
.nav a:focus {
    background: linear-gradient(180deg, var(--tkd-red-hot), #8b0000) !important;
    color: #050505 !important;
    text-shadow: none !important;
}

.header {
    position: relative;
    background:
        linear-gradient(135deg, rgba(120,0,0,.65), rgba(0,0,0,.95) 55%),
        #050505 !important;
    overflow: hidden;
}

.header::before {
    content: "";
    position: absolute;
    left: -80px;
    bottom: -32px;
    width: 360px;
    height: 110px;
    background: url("brush-divider.svg") center/contain no-repeat;
    opacity: .25;
    pointer-events: none;
}

.header h1 {
    text-shadow: 4px 4px 0 #000, 0 0 18px rgba(255,0,0,.65) !important;
}

.container, main {
    position: relative;
}

.section,
.gallery-section,
.player-panel,
.belt-section,
.day-card,
.training-card,
.testing-card,
.text-panel,
.sidebar,
.intro {
    border-color: rgba(255,0,0,.78) !important;
    box-shadow: 0 0 28px rgba(255,0,0,.16), inset 0 0 0 1px rgba(255,255,255,.04) !important;
}

.section h2,
.gallery-section h2,
.belt-section h2,
.player-panel h2 {
    text-shadow: 0 0 10px rgba(255,0,0,.35);
}

.section h2::after,
.gallery-section h2::after,
.belt-section h2::after,
.player-panel h2::after {
    content: "";
    display: block;
    width: 130px;
    height: 10px;
    background: url("mini-slash.svg") left center/contain no-repeat;
    margin-top: 8px;
}

button,
.watch-link,
.button-row a,
.footer a {
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}

button:hover,
.watch-link:hover,
.button-row a:hover,
.footer a:hover {
    transform: translateY(-1px);
    box-shadow: 0 0 18px rgba(255,0,0,.35);
}

/* Uploaded home page originally used a sidebar shell. Hide it and let the unified nav do the job. */
.layout {
    display: block !important;
    min-height: auto !important;
}
.layout aside {
    display: none !important;
}
.layout main {
    padding: 34px clamp(18px,4vw,58px) !important;
}

@media (max-width: 750px) {
    .site-brand-banner {
        padding: 12px 10px 10px;
    }
    .site-brand-inner {
        padding: 6px 8px;
    }
    .nav a {
        font-size: 12px !important;
        padding: 9px 10px !important;
    }
}


/* Option 2 dropdown navigation: clean launch menu */
.nav {
    display:flex !important;
    flex-wrap:wrap !important;
    align-items:stretch !important;
    justify-content:center !important;
    gap:0 !important;
    padding:0 !important;
    background:linear-gradient(180deg,#151515,#050505) !important;
    border-top:1px solid rgba(255,255,255,.08) !important;
    border-bottom:2px solid var(--tkd-red,#d00000) !important;
    box-shadow:0 8px 22px rgba(0,0,0,.55) !important;
    position:sticky;
    top:0;
    z-index:50;
}
.nav .nav-item{position:relative;display:flex;align-items:stretch}
.nav a,.nav .dropbtn{
    display:flex !important;
    align-items:center !important;
    color:#fff !important;
    padding:12px 16px !important;
    text-decoration:none !important;
    font-weight:900 !important;
    font-size:14px !important;
    letter-spacing:.04em !important;
    text-transform:uppercase !important;
    border-right:1px solid rgba(255,255,255,.08) !important;
    border-left:1px solid rgba(255,0,0,.13) !important;
    background:linear-gradient(90deg,rgba(255,0,0,.08),transparent) !important;
    cursor:pointer;
    white-space:nowrap;
    min-height:44px;
}
.nav .dropbtn::after{content:"▾";font-size:11px;margin-left:7px;color:#ff3a3a}
.nav a:hover,.nav a:focus,.nav .nav-item:hover>.dropbtn,.nav .nav-item:focus-within>.dropbtn,
.nav a.active,.nav .dropbtn.active{
    background:linear-gradient(180deg,#ff1a1a,#8b0000) !important;
    color:#fff !important;
    text-shadow:none !important;
}
.nav .dropdown{
    display:none;
    position:absolute;
    top:100%;
    left:0;
    min-width:235px;
    background:rgba(5,5,5,.98);
    border:1px solid rgba(255,0,0,.55);
    border-top:2px solid #ff1a1a;
    box-shadow:0 18px 35px rgba(0,0,0,.72);
    padding:7px;
    z-index:60;
}
.nav .nav-item:hover>.dropdown,.nav .nav-item:focus-within>.dropdown{display:block}
.nav .dropdown a{
    display:block !important;
    min-height:auto;
    padding:10px 12px !important;
    margin:2px 0;
    border:1px solid rgba(255,255,255,.08) !important;
    background:linear-gradient(90deg,rgba(255,0,0,.12),rgba(255,255,255,.03)) !important;
    font-size:13px !important;
    clip-path:none !important;
}
.nav .dropdown a:hover,.nav .dropdown a:focus,.nav .dropdown a.active{
    background:linear-gradient(90deg,#d60000,rgba(214,0,0,.32)) !important;
}
@media(max-width:760px){
    .nav{position:relative;justify-content:flex-start !important;overflow:visible}
    .nav .nav-item{width:50%;position:relative}
    .nav a,.nav .dropbtn{width:100%;justify-content:center;font-size:12px !important;padding:10px 8px !important}
    .nav .dropdown{left:0;right:auto;min-width:100%;width:100%;position:absolute}
}
@media(max-width:460px){.nav .nav-item{width:100%}.nav .dropdown{position:static;display:block;border-top:0;box-shadow:none}.nav .dropbtn::after{content:""}}


/* ===== Mobile / tablet responsive patch ===== */
@media (max-width: 900px) {
  body::after,
  .site-brand-banner::before,
  .site-brand-banner::after,
  .header::before {
    display: none !important;
  }

  .site-brand-banner {
    padding: 10px 8px 10px !important;
  }

  .site-brand-inner {
    padding: 6px 8px !important;
    margin: 0 6px !important;
  }

  .nav {
    display: block !important;
    padding: 0 !important;
  }

  .nav > a,
  .nav > .dropdown {
    display: block !important;
    width: 100% !important;
    border-right: 0 !important;
    border-left: 0 !important;
  }

  .nav a,
  .dropbtn {
    display: block !important;
    width: 100% !important;
    box-sizing: border-box !important;
    text-align: left !important;
    padding: 14px 16px !important;
    font-size: 15px !important;
  }

  .dropdown {
    position: static !important;
  }

  .dropdown-content {
    position: static !important;
    width: 100% !important;
    box-shadow: none !important;
    border-top: 1px solid rgba(255,255,255,.08) !important;
    border-bottom: 1px solid rgba(255,255,255,.08) !important;
  }

  .dropdown-content a {
    padding-left: 28px !important;
    font-size: 14px !important;
  }

  table {
    display: block;
    width: 100% !important;
    overflow-x: auto;
  }

  img {
    max-width: 100% !important;
    height: auto !important;
  }

  body, td, p, li {
    font-size: 16px !important;
    line-height: 1.45 !important;
  }

  .content, .container, .page-shell, .page-content, main {
    width: auto !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 14px !important;
    padding-right: 14px !important;
    box-sizing: border-box !important;
  }
}

@media (max-width: 600px) {
  .site-brand-inner img {
    max-width: 100% !important;
  }

  body, td, p, li {
    font-size: 15px !important;
  }

  h1 { font-size: 28px !important; }
  h2 { font-size: 22px !important; }
  h3 { font-size: 18px !important; }

  .content, .container, .page-shell, .page-content, main {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }
}


/* ===== Phase 2 polish: uniform titles, stronger cards, cleaner mobile menu ===== */
.header{
  max-width:1250px;
  margin:28px auto 0 !important;
  padding:26px clamp(18px,4vw,44px) !important;
  border:1px solid rgba(255,0,0,.62) !important;
  border-left:8px solid #ff1a1a !important;
  background:
    linear-gradient(90deg, rgba(214,0,0,.22), rgba(0,0,0,.78) 42%, rgba(0,0,0,.94)),
    linear-gradient(135deg,#070707,#170000) !important;
  box-shadow:0 16px 42px rgba(0,0,0,.5), inset 0 0 0 1px rgba(255,255,255,.04) !important;
  overflow:hidden;
}
.header h1{
  margin:0 !important;
  color:#ff1a1a !important;
  font-family:Arial Black, Impact, Arial, Helvetica, sans-serif !important;
  font-size:clamp(34px,5.2vw,64px) !important;
  line-height:.92 !important;
  text-transform:uppercase !important;
  letter-spacing:.035em !important;
  text-shadow:3px 3px 0 #000,0 0 18px rgba(255,0,0,.42) !important;
}
.header h1::after{
  content:"";
  display:block;
  width:160px;
  height:10px;
  margin-top:13px;
  background:url("mini-slash.svg") left center/contain no-repeat;
  filter:drop-shadow(0 0 8px rgba(255,0,0,.55));
}
.header p{
  max-width:900px;
  margin:14px 0 0 !important;
  color:#f2f2f2 !important;
  font-size:clamp(16px,2vw,20px) !important;
  line-height:1.5 !important;
}
.header img{
  display:block;
  max-width:100% !important;
  height:auto !important;
  margin:18px auto 0 !important;
  border:1px solid rgba(255,255,255,.15);
  box-shadow:0 0 22px rgba(255,0,0,.18);
}
.container{max-width:1250px;margin:0 auto;padding:30px clamp(14px,3vw,40px) !important;}
.section{border-radius:0 !important;}
.section h2{
  color:#ff1a1a !important;
  font-family:Arial Black, Impact, Arial, Helvetica, sans-serif !important;
  letter-spacing:.045em !important;
}
.phase2-start,.phase2-trust,.phase2-cta{position:relative;overflow:hidden;}
.phase2-lead{font-size:19px;color:#eaeaea;text-align:center;margin-top:-4px;}
.phase2-card-grid,.phase2-trust-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
  margin-top:22px;
}
.phase2-card,.phase2-trust-grid>div{
  display:block;
  padding:20px 18px;
  border:1px solid rgba(255,0,0,.55);
  background:linear-gradient(135deg,rgba(214,0,0,.16),rgba(255,255,255,.035));
  min-height:145px;
  box-shadow:0 14px 26px rgba(0,0,0,.25);
}
.phase2-card span,.phase2-trust-grid b{
  display:block;
  color:#fff;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.04em;
  font-size:18px;
  margin-bottom:10px;
}
.phase2-card small,.phase2-trust-grid span{
  display:block;
  color:#ddd;
  line-height:1.45;
  font-size:15px;
}
.phase2-card:hover{transform:translateY(-2px);box-shadow:0 0 24px rgba(255,0,0,.26);}
.phase2-cta{text-align:center;max-width:1250px;margin-left:auto;margin-right:auto;}
.phase2-cta p{max-width:760px;margin:0 auto 18px;color:#e5e5e5;font-size:18px;line-height:1.55;}
.phase2-actions{display:flex;gap:13px;justify-content:center;flex-wrap:wrap;}
.phase2-btn{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:165px;
  padding:13px 18px;
  border:1px solid #ff1a1a;
  background:linear-gradient(180deg,#ff1a1a,#9b0000);
  color:#fff !important;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.045em;
  text-decoration:none !important;
}
.phase2-btn-secondary{background:#070707;border-color:rgba(255,255,255,.28);}
.program-card,.highlight-card,.phase2-card,.phase2-trust-grid>div{transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease;}
.program-card:hover,.highlight-card:hover{transform:translateY(-2px);box-shadow:0 0 24px rgba(255,0,0,.24);border-color:#ff1a1a !important;}
.copyright-badger{margin-top:34px !important;}

/* tap-to-open mobile dropdowns */
@media(max-width:760px){
  .nav{position:relative !important;display:flex !important;}
  .nav .nav-item{width:50% !important;}
  .nav .dropdown{display:none !important;position:static !important;width:100% !important;min-width:100% !important;box-shadow:none !important;border-top:0 !important;}
  .nav .nav-item.open>.dropdown{display:block !important;}
  .nav .nav-item.has-dropdown{display:block !important;}
  .nav .nav-item.has-dropdown>.dropbtn::after{content:"+";font-size:16px;margin-left:8px;color:#ff3a3a;}
  .nav .nav-item.open>.dropbtn::after{content:"–";}
  .phase2-card-grid,.phase2-trust-grid{grid-template-columns:1fr 1fr;}
  .phase2-card,.phase2-trust-grid>div{min-height:auto;}
}
@media(max-width:520px){
  .nav .nav-item{width:100% !important;}
  .nav a,.nav .dropbtn{text-align:left !important;justify-content:space-between !important;padding:12px 16px !important;}
  .nav .dropdown a{padding-left:28px !important;background:rgba(255,255,255,.04) !important;}
  .header{margin-top:18px !important;padding:22px 16px !important;border-left-width:5px !important;}
  .header h1{font-size:32px !important;letter-spacing:.02em !important;}
  .container{padding-left:10px !important;padding-right:10px !important;}
  .phase2-card-grid,.phase2-trust-grid{grid-template-columns:1fr;}
  .hero h1{font-size:38px !important;}
  .hero p{font-size:16px !important;}
}

/* ===== Phase 2.1: stable banner/nav placement + balanced hero buttons ===== */
.site-brand-banner{
  position:relative !important;
  z-index:45 !important;
}
.nav{
  position:relative !important;
  top:auto !important;
  z-index:40 !important;
  margin:0 !important;
}
.hero .cta-row{
  display:grid !important;
  grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  gap:14px !important;
  max-width:780px !important;
  align-items:stretch !important;
}
.hero .cta-row .btn{
  width:100% !important;
  min-height:58px !important;
  padding:14px 12px !important;
  text-align:center !important;
  line-height:1.12 !important;
  font-size:clamp(12px,.92vw,16px) !important;
  white-space:normal !important;
  clip-path:polygon(0 0,94% 0,100% 50%,94% 100%,0 100%) !important;
}
@media(max-width:820px){
  .hero .cta-row{
    grid-template-columns:1fr !important;
    max-width:100% !important;
  }
  .hero .cta-row .btn{
    min-height:50px !important;
    clip-path:none !important;
  }
}

/* ===== Phase 3: color, font, footer, mobile action polish ===== */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=Oswald:wght@500;600;700&display=swap');
:root{
  --tkd-red:#c8102e;
  --tkd-red-hot:#e21b2d;
  --tkd-red-deep:#8b0018;
  --tkd-black:#050505;
  --tkd-charcoal:#111113;
  --tkd-dark:#18181b;
  --tkd-muted:#d8d8d8;
  --tkd-silver:#cfcfcf;
  --tkd-gold:#d6a632;
  --tkd-line:rgba(200,16,46,.68);
  --tkd-panel:rgba(13,13,15,.96);
}
html,body{font-family:'Inter',Arial,Helvetica,sans-serif !important;}
body{
  background:
    radial-gradient(circle at 20% 0%, rgba(200,16,46,.18), transparent 26%),
    radial-gradient(circle at 85% 14%, rgba(214,166,50,.06), transparent 22%),
    linear-gradient(135deg,#000 0%,#080808 48%,#140006 100%) !important;
}
.site-brand-banner{border-bottom-color:var(--tkd-red) !important;}
.site-brand-inner{border-color:rgba(200,16,46,.82) !important;box-shadow:0 0 22px rgba(200,16,46,.22), inset 0 0 0 2px rgba(0,0,0,.08) !important;}
.nav{
  background:linear-gradient(180deg,#161616,#060606) !important;
  border-bottom-color:var(--tkd-red) !important;
  box-shadow:0 8px 18px rgba(0,0,0,.5), inset 0 1px 0 rgba(214,166,50,.12) !important;
  position:relative !important;
  top:auto !important;
}
.nav a,.nav .dropbtn,.btn,.phase2-btn,.hero .cta-row .btn,button,.watch-link,.email-btn{
  font-family:'Oswald',Impact,'Arial Black',Arial,sans-serif !important;
  letter-spacing:.075em !important;
}
.nav a,.nav .dropbtn{font-size:15px !important;}
.nav .dropbtn::after{color:var(--tkd-gold) !important;}
.nav a:hover,.nav a:focus,.nav .nav-item:hover>.dropbtn,.nav .nav-item:focus-within>.dropbtn,.nav a.active,.nav .dropbtn.active{
  background:linear-gradient(180deg,var(--tkd-red-hot),var(--tkd-red-deep)) !important;
  color:#fff !important;
}
.nav .dropdown{border-color:rgba(200,16,46,.62) !important;border-top-color:var(--tkd-gold) !important;}
.nav .dropdown a:hover,.nav .dropdown a:focus,.nav .dropdown a.active{background:linear-gradient(90deg,var(--tkd-red),rgba(200,16,46,.34)) !important;}
.header{
  border-left-color:var(--tkd-red-hot) !important;
  border-color:rgba(200,16,46,.58) !important;
  background:
    linear-gradient(90deg,rgba(200,16,46,.18),rgba(0,0,0,.82) 42%,rgba(0,0,0,.96)),
    linear-gradient(135deg,#080808,#160006) !important;
}
.header h1,
.section h2,
.gallery-section h2,
.belt-section h2,
.player-panel h2,
.phase2-start h2,
.phase2-trust h2,
.phase2-cta h2{
  font-family:'Oswald',Impact,'Arial Black',Arial,sans-serif !important;
  color:var(--tkd-red-hot) !important;
  letter-spacing:.07em !important;
  font-weight:700 !important;
}
.header h1{
  text-shadow:3px 3px 0 #000,0 0 15px rgba(200,16,46,.38) !important;
}
.header h1::after{
  width:180px !important;
  height:5px !important;
  background:linear-gradient(90deg,var(--tkd-red-hot),var(--tkd-gold),transparent) !important;
  filter:none !important;
}
.section,.gallery-section,.player-panel,.belt-section,.day-card,.training-card,.testing-card,.text-panel,.sidebar,.intro{
  border-color:rgba(200,16,46,.62) !important;
  box-shadow:0 0 26px rgba(200,16,46,.12), inset 0 0 0 1px rgba(255,255,255,.045) !important;
}
.section h2::after,.gallery-section h2::after,.belt-section h2::after,.player-panel h2::after{
  height:4px !important;
  background:linear-gradient(90deg,var(--tkd-red-hot),var(--tkd-gold),transparent) !important;
  margin-top:10px !important;
}
.hero{
  border-color:rgba(200,16,46,.5) !important;
  background:linear-gradient(135deg,rgba(18,18,20,.97),rgba(6,6,7,.98)) !important;
}
.hero h1{
  font-family:'Oswald',Impact,'Arial Black',Arial,sans-serif !important;
  letter-spacing:.01em !important;
  text-shadow:3px 3px 0 #000,0 0 24px rgba(200,16,46,.35) !important;
}
.hero h1 span{color:var(--tkd-red-hot) !important;}
.btn,.phase2-btn,.hero .cta-row .btn{
  background:linear-gradient(180deg,var(--tkd-red-hot),var(--tkd-red-deep)) !important;
  border-color:var(--tkd-red-hot) !important;
  box-shadow:0 6px 0 rgba(0,0,0,.32),0 0 18px rgba(200,16,46,.16) !important;
}
.btn.secondary,.phase2-btn-secondary,.hero .cta-row .btn.secondary{
  background:linear-gradient(180deg,#151515,#050505) !important;
  border-color:rgba(214,166,50,.48) !important;
}
.btn:hover,.phase2-btn:hover,.hero .cta-row .btn:hover,.program-card:hover,.highlight-card:hover,.phase2-card:hover{
  transform:translateY(-2px) !important;
  box-shadow:0 9px 0 rgba(0,0,0,.28),0 0 24px rgba(200,16,46,.24) !important;
}
.phase3-trust-strip{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:0;
  margin:22px auto 28px;
  border:1px solid rgba(214,166,50,.38);
  background:linear-gradient(90deg,rgba(214,166,50,.09),rgba(200,16,46,.12),rgba(214,166,50,.07));
  box-shadow:0 18px 38px rgba(0,0,0,.26);
  overflow:hidden;
}
.phase3-trust-strip span{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:58px;
  padding:12px 14px;
  color:#fff;
  font-family:'Oswald',Impact,'Arial Black',Arial,sans-serif;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  text-align:center;
  border-right:1px solid rgba(255,255,255,.1);
}
.phase3-trust-strip span:last-child{border-right:0;}
.mobile-quick-actions{display:none;}
.copyright-badger{
  max-width:none !important;
  margin:34px auto 0 !important;
  padding:24px 16px !important;
  background:linear-gradient(180deg,#0a0a0b,#030303) !important;
  border-top:1px solid rgba(200,16,46,.55) !important;
  color:#cfcfcf !important;
  font-family:'Inter',Arial,sans-serif !important;
}
.copyright-badger img{width:32px !important;height:32px !important;}
body,td,p,li{font-family:'Inter',Arial,Helvetica,sans-serif !important;}
strong,b{font-weight:800;}
@media(max-width:900px){
  .phase3-trust-strip{grid-template-columns:repeat(2,minmax(0,1fr));}
  .phase3-trust-strip span:nth-child(2){border-right:0;}
}
@media(max-width:760px){
  .nav a,.nav .dropbtn{font-size:15px !important;letter-spacing:.055em !important;}
  .mobile-quick-actions{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:6px;
    padding:8px;
    background:#050505;
    border-bottom:1px solid rgba(200,16,46,.5);
  }
  .mobile-quick-actions a{
    display:flex;
    align-items:center;
    justify-content:center;
    min-height:44px;
    padding:9px 7px;
    color:#fff !important;
    text-decoration:none !important;
    text-transform:uppercase;
    font-family:'Oswald',Impact,'Arial Black',Arial,sans-serif;
    font-weight:700;
    letter-spacing:.05em;
    font-size:13px;
    border:1px solid rgba(214,166,50,.4);
    background:linear-gradient(180deg,#141414,#060606);
  }
  .mobile-quick-actions a:first-child{background:linear-gradient(180deg,var(--tkd-red-hot),var(--tkd-red-deep));border-color:var(--tkd-red-hot);}
}
@media(max-width:520px){
  .header h1{font-size:34px !important;}
  .phase3-trust-strip{grid-template-columns:1fr;}
  .phase3-trust-strip span{border-right:0;border-bottom:1px solid rgba(255,255,255,.1);min-height:48px;}
  .phase3-trust-strip span:last-child{border-bottom:0;}
  .mobile-quick-actions a{font-size:12px;min-height:42px;}
}
/* ===== Phase 4: crisp navigation, spacing, image polish, back-to-top ===== */
*{
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}

/* Main link bar: less chunky, cleaner spacing, no blurry poster-weight feel */
.nav{
  background:linear-gradient(180deg,#171717 0%,#080808 100%) !important;
  border-top:1px solid rgba(255,255,255,.07) !important;
  border-bottom:2px solid var(--tkd-red,#c8102e) !important;
  box-shadow:0 8px 18px rgba(0,0,0,.42), inset 0 1px 0 rgba(214,166,50,.10) !important;
}
.nav a,
.nav .dropbtn{
  font-family:'Inter',Arial,Helvetica,sans-serif !important;
  font-weight:750 !important;
  font-size:13px !important;
  letter-spacing:.105em !important;
  line-height:1.1 !important;
  padding:13px 18px !important;
  text-shadow:none !important;
  border-left:1px solid rgba(255,255,255,.055) !important;
  border-right:1px solid rgba(255,255,255,.055) !important;
  background:linear-gradient(90deg,rgba(200,16,46,.055),transparent) !important;
}
.nav .dropbtn::after{
  font-size:10px !important;
  margin-left:8px !important;
  opacity:.95 !important;
}
.nav a:hover,
.nav a:focus,
.nav .nav-item:hover>.dropbtn,
.nav .nav-item:focus-within>.dropbtn,
.nav a.active,
.nav .dropbtn.active{
  background:linear-gradient(180deg,var(--tkd-red-hot,#e21b2d),var(--tkd-red-deep,#8b0018)) !important;
  color:#fff !important;
  box-shadow:inset 0 -3px 0 rgba(214,166,50,.75) !important;
}

/* Dropdowns: cleaner, more breathing room, easier to scan */
.nav .dropdown{
  min-width:250px !important;
  padding:9px !important;
  background:rgba(7,7,8,.985) !important;
  border:1px solid rgba(200,16,46,.52) !important;
  border-top:3px solid var(--tkd-gold,#d6a632) !important;
  box-shadow:0 18px 34px rgba(0,0,0,.68), 0 0 0 1px rgba(255,255,255,.035) inset !important;
}
.nav .dropdown a{
  font-family:'Inter',Arial,Helvetica,sans-serif !important;
  font-weight:700 !important;
  font-size:12.5px !important;
  letter-spacing:.07em !important;
  padding:11px 13px 11px 15px !important;
  margin:3px 0 !important;
  border:1px solid rgba(255,255,255,.075) !important;
  border-left:3px solid rgba(214,166,50,.35) !important;
  background:linear-gradient(90deg,rgba(200,16,46,.10),rgba(255,255,255,.025)) !important;
  box-shadow:none !important;
}
.nav .dropdown a:hover,
.nav .dropdown a:focus,
.nav .dropdown a.active{
  border-left-color:var(--tkd-gold,#d6a632) !important;
  background:linear-gradient(90deg,rgba(200,16,46,.58),rgba(200,16,46,.16)) !important;
  box-shadow:none !important;
}

/* Header/title spacing polish */
.header{
  margin-top:24px !important;
  margin-bottom:0 !important;
}
.header h1{
  letter-spacing:.055em !important;
}
.container,
.layout main{
  line-height:1.55 !important;
}
.section,
.gallery-section,
.player-panel,
.belt-section,
.day-card,
.training-card,
.testing-card,
.text-panel,
.sidebar,
.intro{
  margin-top:24px !important;
  margin-bottom:24px !important;
}
.section p,
.text-panel p,
.intro p,
.container p,
main p{
  margin-top:.65em;
  margin-bottom:1em;
}
.section ul,
.section ol,
.container ul,
.container ol,
main ul,
main ol{
  padding-left:1.35em;
}
.section li,
.container li,
main li{
  margin:.28em 0;
}

/* Homepage hero balance */
.hero{
  align-items:stretch !important;
  gap:26px !important;
}
.hero > div:first-child,
.hero .hero-art{
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
}
.hero .hero-art{
  padding:24px !important;
  border:1px solid rgba(214,166,50,.24) !important;
  background:linear-gradient(135deg,rgba(214,166,50,.055),rgba(255,255,255,.025)) !important;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.035) !important;
}
.hero .hero-art h2{
  font-family:'Oswald',Impact,'Arial Black',Arial,sans-serif !important;
  letter-spacing:.06em !important;
  color:#fff !important;
  margin-top:0 !important;
}
.hero .hero-art h2 span{
  color:var(--tkd-red-hot,#e21b2d) !important;
}

/* Images: make old photos look intentional, not dumped in */
main img:not(.brandmark):not(.copyright-badger img),
.container img,
.section img,
.wide-img,
.hero-art img{
  max-width:100% !important;
  height:auto !important;
}
main img:not(.brandmark):not(.copyright-badger img):not([src*="facebook"]):not([src*="twitter"]):not([src*="linkedin"]):not([src*="google"]),
.wide-img{
  border:1px solid rgba(214,166,50,.22) !important;
  box-shadow:0 14px 28px rgba(0,0,0,.32),0 0 18px rgba(200,16,46,.10) !important;
}
.program-card img{
  border:0 !important;
  box-shadow:none !important;
}

/* Footer/contact: cleaner final landing area */
.copyright-badger{
  gap:10px !important;
  padding:20px 16px !important;
  font-size:13px !important;
  letter-spacing:.03em !important;
  border-top:1px solid rgba(200,16,46,.48) !important;
}
.copyright-badger img{
  width:28px !important;
  height:28px !important;
  flex:0 0 auto !important;
}
.phase2-cta{
  border-top:1px solid rgba(214,166,50,.18) !important;
  border-bottom:1px solid rgba(200,16,46,.35) !important;
}
.phase2-actions{
  align-items:stretch !important;
}
.phase2-btn{
  min-height:50px !important;
}

/* Mobile nav: less cramped, bigger tap targets, no forced blurry uppercase pile */
@media(max-width:760px){
  .nav{
    display:grid !important;
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:0 !important;
  }
  .nav .nav-item{
    width:auto !important;
    min-width:0 !important;
  }
  .nav a,
  .nav .dropbtn{
    font-size:12.5px !important;
    font-weight:750 !important;
    letter-spacing:.085em !important;
    padding:13px 12px !important;
    min-height:48px !important;
    justify-content:center !important;
    text-align:center !important;
  }
  .nav .nav-item.has-dropdown{
    display:block !important;
  }
  .nav .dropdown{
    grid-column:1 / -1 !important;
    width:100% !important;
    min-width:100% !important;
    padding:7px !important;
    background:#09090a !important;
  }
  .nav .dropdown a{
    font-size:12.5px !important;
    letter-spacing:.06em !important;
    text-align:left !important;
    justify-content:flex-start !important;
    min-height:42px !important;
    padding:11px 14px !important;
  }
  .mobile-quick-actions{
    gap:8px !important;
    padding:9px !important;
  }
}
@media(max-width:520px){
  .nav{
    grid-template-columns:1fr !important;
  }
  .nav a,
  .nav .dropbtn{
    justify-content:space-between !important;
    text-align:left !important;
    padding:13px 16px !important;
  }
  .hero{
    gap:16px !important;
    padding:20px !important;
  }
  .hero .hero-art{
    padding:18px !important;
  }
  .mobile-quick-actions{
    grid-template-columns:1fr !important;
  }
}

/* Back to top button */
#backToTop{
  position:fixed;
  right:18px;
  bottom:18px;
  width:46px;
  height:46px;
  border:1px solid rgba(214,166,50,.55);
  background:linear-gradient(180deg,var(--tkd-red-hot,#e21b2d),var(--tkd-red-deep,#8b0018));
  color:#fff;
  font-family:'Inter',Arial,sans-serif;
  font-size:22px;
  font-weight:900;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 12px 28px rgba(0,0,0,.45),0 0 18px rgba(200,16,46,.2);
  opacity:0;
  pointer-events:none;
  transform:translateY(8px);
  transition:opacity .18s ease, transform .18s ease;
  z-index:99;
  cursor:pointer;
}
#backToTop.visible{
  opacity:1;
  pointer-events:auto;
  transform:translateY(0);
}
#backToTop:hover,
#backToTop:focus{
  transform:translateY(-2px);
  outline:none;
}
@media(max-width:520px){
  #backToTop{
    right:12px;
    bottom:12px;
    width:42px;
    height:42px;
    font-size:20px;
  }
}


/* ===== Final QA / SEO polish ===== */
.site-footer{
  max-width:1250px;
  margin:34px auto 0;
  padding:24px clamp(16px,3vw,34px);
  display:grid;
  grid-template-columns:1.35fr .8fr 1fr;
  gap:24px;
  color:#e7e7e7;
  background:linear-gradient(135deg,rgba(12,12,14,.98),rgba(4,4,5,.98));
  border:1px solid rgba(200,16,46,.46);
  border-top:3px solid var(--tkd-red,#c8102e);
  box-shadow:0 18px 40px rgba(0,0,0,.36), inset 0 0 0 1px rgba(255,255,255,.035);
}
.site-footer h2,.site-footer h3{
  margin:0 0 10px;
  color:#fff;
  font-family:'Oswald',Impact,'Arial Black',Arial,sans-serif;
  text-transform:uppercase;
  letter-spacing:.065em;
}
.site-footer h2{font-size:24px;color:var(--tkd-red-hot,#e21b2d)}
.site-footer h3{font-size:17px;color:#fff}
.site-footer p{margin:.35em 0;line-height:1.5;color:#dcdcdc}
.site-footer ul{list-style:none;margin:0;padding:0;display:grid;gap:6px}
.site-footer a{color:#fff;text-decoration:none;border-bottom:1px solid rgba(214,166,50,.35)}
.site-footer a:hover,.site-footer a:focus{color:#fff;border-bottom-color:var(--tkd-red-hot,#e21b2d);text-shadow:0 0 10px rgba(200,16,46,.32)}
.site-footer-map{display:inline-block;margin-top:8px;padding:8px 12px;border:1px solid rgba(214,166,50,.42)!important;background:rgba(214,166,50,.08)}
@media(max-width:820px){.site-footer{grid-template-columns:1fr;gap:14px;margin-top:24px}}
@media(max-width:520px){.site-footer{padding:20px 14px}.site-footer h2{font-size:21px}}
