:root {
  --green-dark: #4e6445;
  --green: #71855f;
  --green-light: #dfe8d7;
  --accent: #c97b2a;
  --text: #1f2933;
  --muted: #5b6770;
  --white: #ffffff;
  --shadow: 0 12px 30px rgba(0,0,0,.12);
  --radius: 18px;
  --max: 1120px;
}

*{box-sizing:border-box;}
body{
  margin:0;
  font-family:Arial,Helvetica,sans-serif;
  color:var(--text);
  background:linear-gradient(180deg,#eef4e8 0%,#ffffff 220px);
  line-height:1.6;
  overflow-x:hidden;
}

img{max-width:100%;height:auto;display:block;}

.container{
  width:min(calc(100% - 2rem),var(--max));
  margin:0 auto;
}

.top-accent-bar{
  height:6px;
  background:linear-gradient(90deg,#71855f 0%,#4e6445 100%);
}

.site-header{
  position:sticky;
  top:0;
  z-index:1000;
  background:rgba(255,255,255,.96);
  border-bottom:1px solid rgba(78,100,69,.14);
  box-shadow:0 4px 18px rgba(0,0,0,.06);
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  padding:.25rem 0;
}

.brand{
  display:inline-flex;
  align-items:center;
  text-decoration:none;
}

.brand-logo{
  width:480px;
  max-width:65vw;
  height:auto;
  filter:drop-shadow(0 6px 12px rgba(0,0,0,.18));
}

#nav-placeholder{
  flex:1 1 100%;
  min-width:0;
}

.menu-toggle{
  display:none;
  appearance:none;
  border:1px solid rgba(78,100,69,.15);
  background:#eef4e8;
  color:var(--green-dark);
  border-radius:12px;
  padding:.65rem .9rem;
  font-size:1.2rem;
  font-weight:700;
  cursor:pointer;
   position:absolute;
  left:0;
}

.top-nav{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  gap:.4rem;
  padding:.25rem 0 .4rem;
}

.top-nav a,
.top-nav summary{
  text-decoration:none;
  padding:.65rem .85rem;
  border-radius:999px;
  background:#eef4e8;
  color:var(--green-dark);
  font-weight:700;
  border:1px solid rgba(78,100,69,.10);
  white-space:nowrap;
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  cursor:pointer;
  list-style:none;
}

.top-nav summary.nav-black{
  color:#000;
}

.top-nav summary::-webkit-details-marker{
  display:none;
}

.top-nav a:hover,
.top-nav summary:hover{
  background:var(--green);
  color:#fff;
}

.top-nav a.active{
  background:var(--green-dark);
  color:#fff;
}

.nav-group{
  position:relative;
  flex:0 0 auto;
}

.dropdown{
  position:absolute;
  top:calc(100% + .4rem);
  left:0;
  min-width:320px;
  max-width:min(92vw, 540px);
  background:#fff;
  border:1px solid rgba(78,100,69,.12);
  border-radius:18px;
  box-shadow:var(--shadow);
  padding:1rem;
  z-index:1001;
  max-height:50vh;
  overflow-y:auto;
}

.dropdown-grid{
  display:grid;
  gap:.9rem;
}

.province h4{
  margin:0 0 .35rem;
  color:var(--green-dark);
}

.province-links{
  display:flex;
  flex-wrap:wrap;
  gap:.35rem;
}

.province-links a{
  padding:.45rem .7rem;
  font-size:.92rem;
}

.hero-banner{
  padding:2rem 0 1.5rem;
  text-align:center;
}

.hero-banner img{
  display:block;
  margin-left:auto;
  margin-right:auto;
}

.hero-banner-inner{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:1.5rem;
  align-items:center;
}

.hero-copy{
  background:linear-gradient(135deg,rgba(113,133,95,.14),rgba(255,255,255,.96));
  border:1px solid rgba(78,100,69,.14);
  border-radius:28px;
  box-shadow:var(--shadow);
  padding:clamp(1.5rem,3vw,2.6rem);
}

.hero-panel-card{
  background:#fff;
  border-radius:24px;
  box-shadow:var(--shadow);
  border:1px solid rgba(0,0,0,.06);
  padding:1.4rem;
}

.hero-card{
  max-width:736px;
  margin:0 auto;
  text-align:center;
}

.hero-card .page-title,
.hero-card .video-frame,
.hero-card .video-wrap{
  margin-left:auto;
  margin-right:auto;
}
.hero-kicker{
  display:inline-block;
  background:var(--green-dark);
  color:#fff;
  padding:.4rem .8rem;
  border-radius:999px;
  font-size:.82rem;
  font-weight:700;
  margin-bottom:1rem;
}

.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.8rem;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  font-weight:700;
  border-radius:999px;
  padding:.9rem 1.2rem;
}

.btn-primary{
  background:var(--green-dark);
  color:#fff;
}

.btn-secondary{
  background:#fff;
  color:var(--green-dark);
  border:1px solid rgba(78,100,69,.2);
}

.section{
  padding:1rem 0;
}

.card{
  background:#fff;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:1.4rem;
  border:1px solid rgba(0,0,0,.06);
}

.grid-two{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.25rem;
}

.resources-panel{
  background:linear-gradient(180deg,#ffffff 0%,#f6f9f3 100%);
}

/* ── Canvas overflow fix ── */
canvas {
  max-width: 100%;
  box-sizing: border-box;
}

.footer-logo-float {
  display: flex;
  justify-content: center;
  margin-bottom: -50px;
  position: relative;
  z-index: 2;
}

.footer-logo-float img {
  width: 220px;
  max-width: 60vw;
  height: auto;
  display: block;
}

.footer{
  margin-top:0;
  background:linear-gradient(180deg,#71855f 0%,#4e6445 100%);
  color:#fff;
  text-align:center;
  width:100%;
  box-sizing:border-box;
  padding:55px 1rem 18px;
}

.footer-inner{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:.25rem;
  padding:0;
  box-sizing:border-box;
}

.footer-inner p{
  margin:0;
  font-size:.88rem;
  line-height:1.5;
  word-wrap:break-word;
  max-width:320px;
}

#footer-placeholder{
  margin-top:0;
}

.page-main{
  padding:1.25rem 0 0;
}

.page-title{
  margin:0 0 1rem 0;
  text-align:center;
  color:var(--green-dark);
}

.video-wrap{
  width:min(100%, 736px);
  margin:0 auto;
}

.video-wrap video{
  width:736px;
  max-width:100%;
  height:414px;
  max-height:calc(100vw * 9 / 16);
  display:block;
  border-radius:18px;
  box-shadow:var(--shadow);
  background:#000;
}
.page-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.8rem;
  justify-content:center;
  margin-top:1.25rem;
}

@media (max-width:900px){
  .hero-banner-inner{grid-template-columns:1fr;}
  .grid-two{grid-template-columns:1fr;}

  .header-inner{
    padding:.5rem 0;
  }

  .menu-toggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    margin-left:auto;
  }

  .top-nav{
    display:none;
    flex:1 1 100%;
    flex-direction:column;
    align-items:stretch;
    gap:.5rem;
    padding:.5rem 0 .25rem;
    overflow:visible;
  }

  .top-nav.open{
    display:flex;
  }

  .top-nav a,
  .top-nav summary{
    text-align:center;
    justify-content:center;
    width:100%;
  }

  .nav-group{
    width:100%;
    max-width:100%;
    flex: 1 1 100%;
    box-sizing: border-box;
  }

  .dropdown{
    position:static;
    min-width:0;
    max-width:100%;
    width:100%;
    overflow:hidden;
    margin-top:.45rem;
    box-sizing:border-box;
  }

  details.nav-group,
  details.nav-group > .dropdown,
  details.nav-group > .dropdown > div {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  details.nav-group > .dropdown > .dropdown-grid-two {
    display: block !important;
    width: 100% !important;
  }
}
.tap-expand {
  cursor: zoom-in;
}
.tap-expand:hover {
  opacity: 0.9;
}
.fullscreen-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.9);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}

.fullscreen-overlay img {
  max-width: 95%;
  max-height: 95%;
}
@media (max-width:640px){
  .mobile-notice { display: block; }
  .training-grid { grid-template-columns: 1fr; }
  .brand-logo{width:90vw;}
  .hero-actions{flex-direction:column;}
  .btn{width:100%;}
  .footer-logo-float img { width: min(200px, 58vw); }
  .footer-logo-float { margin-bottom: -45px; }
  .footer { padding-top: 50px; }
}

/* Shared chart zoom support */
.fullscreen-overlay,
.zoom-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.88);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:9999;
  overflow:hidden;
}

.fullscreen-overlay img,
.zoom-stage img{
  max-width:92vw;
  max-height:88vh;
  width:auto;
  height:auto;
  display:block;
  margin:0 auto;
  transform-origin:center center;
  user-select:none;
  -webkit-user-drag:none;
}

.chart-card img[src$=".svg"],
.table-like img[src$=".svg"],
.program-main img.tap-expand[src$=".svg"],
img.tap-expand[src$=".svg"],
.tap-expand{
  cursor:zoom-in;
  touch-action:manipulation;
}

.zoom-stage{
  position:relative;
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  pointer-events:none;
}

.zoom-stage img{
  pointer-events:auto;
  will-change:transform;
}

.zoom-close{
  position:absolute;
  top:14px;
  right:14px;
  width:44px;
  height:44px;
  border:0;
  border-radius:999px;
  background:rgba(255,255,255,.94);
  color:#1f2a1f;
  font-size:28px;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  z-index:10000;
  box-shadow:0 4px 18px rgba(0,0,0,.25);
}

.zoom-hint{
  position:absolute;
  left:50%;
  bottom:14px;
  transform:translateX(-50%);
  background:rgba(0,0,0,.55);
  color:#fff;
  padding:.45rem .75rem;
  border-radius:999px;
  font-size:.9rem;
  z-index:10000;
  white-space:nowrap;
  pointer-events:none;
}

@media (max-width:700px){
  .chart-card img[src$=".svg"],
  .table-like img[src$=".svg"],
  .program-main img.tap-expand[src$=".svg"],
  img.tap-expand[src$=".svg"]{
    width:100vw;
    max-width:100vw;
    margin-left:calc(50% - 50vw);
    margin-right:calc(50% - 50vw);
  }
}
/* =========================
   PROGRAM SUB-LINK STYLING
========================= */

.program{
  margin-bottom: 0.8rem;
}

.program strong{
  display:block;
  color: var(--green-dark);
  margin-bottom: 0.2rem;
  font-size: 0.95rem;
}

.program a{
  display:block;
  padding-left: 10px;
  font-size: 0.9rem;
}


/* Programs submenu */
.program-links{
  display:block;
}

.program-links .program{
  display:block;
  margin-bottom:1rem;
}

.program-links .program:last-child{
  margin-bottom:0;
}

.program-links .program strong{
  display:block;
  margin:0 0 .35rem;
  color:var(--green-dark);
  font-size:.98rem;
  font-weight:700;
}

.program-links .program a{
  display:block;
  padding:.35rem 0 .35rem .85rem;
  font-size:.92rem;
  line-height:1.45;
  text-decoration:none;
  color:var(--green-dark);
  background:none;
  border:none;
  border-radius:0;
}

.program-links .program a:hover{
  color:var(--green);
  background:none;
}
/* FORCE Programs layout override */
.province-links.program-links{
  display:block !important;
}
.program-warning-wrap{
  margin:2rem auto;
  max-width:520px;   /* keeps it aligned with your content width */
}

.warning-left{
  display:block;
  margin:0 0 0.75rem 0;
}

.program-warning{
  text-align:left;   /* this is the key change */
}
.distance-table {
  border-collapse: collapse;
  width: 100%;
}

.distance-table td,
.distance-table th {
  text-align: center;   /* headers stay centered */
}

.distance-table td {
  padding: 4px 8px;
  line-height: 1.2;
  vertical-align: middle;
}

/* Numeric columns aligned right */
.distance-table td:nth-child(1),
.distance-table td:nth-child(2),
.distance-table td:nth-child(3),
.distance-table td:nth-child(4) {
  text-align: right;
  font-variant-numeric: tabular-nums; /* makes numbers line up nicely */
}

/* Link column centered */
.distance-table td:nth-child(5) {
  text-align: center;
}


.distance-table p {
  margin: 0;          /* removes big paragraph gaps */
}

/* =========================
   MOBILE NOTICE BANNER
========================= */
.mobile-notice {
  display: none;
  background: var(--green-dark);
  color: #fff;
  text-align: center;
  padding: .75rem 1rem;
  font-size: .9rem;
  font-weight: 600;
}

/* =========================
   TRAINING GRID & CARDS
========================= */
.training-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}

.training-card {
  display: block;
  background: #fff;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  border: 1px solid rgba(0,0,0,.06);
  padding: 1.4rem;
  text-decoration: none;
  color: var(--text);
}

.training-card:hover {
  border-color: var(--green);
}

.training-card h3 {
  color: var(--green-dark);
  margin: 0 0 .5rem;
}

@media (max-width: 900px) {
  .training-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
  .mobile-notice { display: block; }
  .training-grid { grid-template-columns: 1fr; }
}
.bc-flag-inline{
  width: 80px;          /* adjust size here */
  height: auto;
  display: inline-block;
  vertical-align: middle;
  margin-left: 10px;
}
/* Chart content links */
.container a {
  color: #000;
  text-decoration: underline;  /* add this line */
}

.container a:hover {
  text-decoration: none;  /* change this from underline to none */
}

/* Preserve nav styling */
.top-nav a {
  color: inherit;
}



/* Using the System dropdown */
.dropdown-using-system{
  max-width: min(92vw, 820px);
}

.dropdown-grid-two{
  display:grid;
  grid-template-columns: repeat(2, minmax(260px, 1fr));
  gap: 1rem 1.25rem;
}

.province-span-2{
  grid-column: 1 / -1;
}

@media (max-width: 900px) {
  .dropdown-using-system {
    max-width: 100%;
  }
  .dropdown-grid-two {
    grid-template-columns: 1fr;
  }
  .province-span-2 {
    grid-column: 1;
  }
}

/* Highlight primary tool in dropdown */
.highlight-tool{
  background:linear-gradient(180deg,#f6f9f3 0%,#eef4e8 100%);
  border:1px solid rgba(78,100,69,.18);
  border-radius:14px;
  padding:.5rem;
}

.highlight-tool h4{
  color:var(--green-dark);
}
.primary-tool-link{
  font-weight:700;
  color: #000;
}

.primary-tool-link:hover{
  color:var(--green);
}

/* Force equal layout */
.swimmer-distance-grid {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 1rem;
  align-items: stretch;
}

/* Make SVGs behave consistently */
.svg-chart {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

/* Ensure panels match height */
.chart-panel {
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Center swimmer image */
.swimmer-center {
  display: flex;
  align-items: center;
  justify-content: center;
}

.swimmer-illustration {
  width: 140px;
  max-width: 100%;
  height: auto;
}


/* Swimmer distance conversion page */
.chart-page-card{
  padding: 1.25rem;
}

.swimmer-distance-grid{
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  gap:1rem;
  align-items:center;
}

.chart-panel{
  display:flex;
  align-items:center;
  justify-content:center;
  background:#fff;
  border-radius:16px;
}

.svg-chart{
  width:100%;
  height:auto;
  display:block;
}

.swimmer-center{
  display:flex;
  align-items:center;
  justify-content:center;
}

.swimmer-illustration{
  width:140px;
  max-width:100%;
  height:auto;
}

@media (max-width:900px){
  .swimmer-distance-grid{
    grid-template-columns:1fr;
  }

  .swimmer-illustration{
    width:180px;
    margin:0 auto;
  }
}

