/*
Theme Name: Sunshine Coast Boxing & Kickboxing
Theme URI: https://example.com/
Author: ChatGPT
Description: A bold, mobile-first WordPress theme for Sunshine Coast Boxing & Kickboxing (Gibsons, BC). Designed to match a clean black/white badge-style logo aesthetic.
Version: 1.0.0
License: GNU General Public License v2 or later
Text Domain: scbk
*/

:root{
  --bg:#ffffff;
  --text:#0b0b0b;
  --muted:#4b4b4b;
  --soft:#f5f5f5;
  --line:#e6e6e6;
  --ink:#111111;
  --radius:18px;
  --shadow: 0 10px 30px rgba(0,0,0,.08);
  --max: 1160px;

  /* === Single source of truth for header logo sizing === */
  --logo-desktop: 60px;  /* was 44px */
  --logo-mobile: 72px;   /* bigger on phones, but not ridiculous */
}

/* Base */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height:1.55;
  -webkit-text-size-adjust:100%;
}
img{max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
a:hover{text-decoration:underline}
p{margin:0 0 1rem}

h1,h2,h3,h4{
  font-family: Graduate, Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height:1.1;
  margin:0 0 .8rem;
}
h1{font-size:2.1rem}
h2{font-size:1.7rem}
h3{font-size:1.25rem}

.container{max-width:var(--max);margin:0 auto;padding:0 18px}
.section{padding:56px 0}
.section.soft{
  background:var(--soft);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.kicker{
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.78rem;
  color:var(--muted);
  margin-bottom:10px;
}
.smallmuted{color:var(--muted);font-weight:700}

/* =========================================================
   HEADER
   ========================================================= */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
  gap:14px;
}

/* Brand (logo + 2 lines beside it) */
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}
.custom-logo-link{flex:0 0 auto}

/* Logo sizing: single source of truth */
.site-header .custom-logo,
.site-header .custom-logo-link img,
.site-header .brand img{
  width: var(--logo-desktop);
  height: var(--logo-desktop);
  object-fit:contain;
  max-width:none;
  max-height:none;
}

.brand > div{
  display:flex;
  flex-direction:column;
  gap:2px;
  min-width:0;
}

/* Title: allow up to 2 lines cleanly */
.brand .site-title{
  font-family: Graduate, Inter, system-ui;
  font-size:1.05rem;
  letter-spacing:.03em;
  margin:0;
  line-height:1.1;
  white-space:normal;
  overflow:hidden;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
}
.brand .smallmuted{
  margin:0;
  line-height:1.1;
  font-size:.85rem;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

/* Nav toggle button */
.nav-toggle{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:44px;height:44px;
  border:1px solid var(--line);
  border-radius:999px;
  background:#fff;
  cursor:pointer;
  position:relative;
  appearance:none;
  -webkit-appearance:none;
  font-size:0; /* hide any text */
}

/* Hamburger icon (3 lines) */
.nav-toggle svg,
.nav-toggle img,
.nav-toggle .icon{ display:none !important; }

.nav-toggle::before,
.nav-toggle::after,
.nav-toggle span{
  content:"";
  position:absolute;
  left:12px; right:12px;
  height:2px;
  background:var(--ink);
  border-radius:999px;
  display:block;
}
.nav-toggle::before{ top:15px; }
.nav-toggle span{ top:21px; }
.nav-toggle::after{ top:27px; }

/* Turn into X when aria-expanded=true */
.nav-toggle[aria-expanded="true"]::before{ top:21px; transform:rotate(45deg); }
.nav-toggle[aria-expanded="true"]::after{ top:21px; transform:rotate(-45deg); }
.nav-toggle[aria-expanded="true"] span{ opacity:0; }

/* Primary nav (mobile dropdown default) */
.primary-nav{
  display:none;
  position:absolute;
  left:16px; right:16px;
  top:74px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  box-shadow: 0 16px 40px rgba(0,0,0,.12);
  padding:10px;
}
.primary-nav.open{display:block}
.primary-nav ul{list-style:none;margin:0;padding:0}
.primary-nav li{margin:0}
.primary-nav a{
  display:block;
  padding:12px 12px;
  border-radius:12px;
  font-weight:800;
  letter-spacing:.02em;
}
.primary-nav a:hover{
  background:var(--soft);
  text-decoration:none;
}
.header-cta{display:none}

/* Desktop nav */
@media(min-width: 880px){
  .nav-toggle{display:none}
  .primary-nav{
    display:block;
    position:static;
    background:transparent;
    border:0;
    box-shadow:none;
    padding:0;
  }
  .primary-nav ul{
    display:flex;
    gap:18px;
    align-items:center;
    justify-content:flex-end;
    flex-wrap:wrap;
  }
  .primary-nav a{
    padding:10px 8px;
    border-radius:10px;
  }
  .primary-nav a:hover{background:var(--soft)}

  /* Prevent brand from overlapping nav */
  .header-inner{
    display:grid;
    grid-template-columns: minmax(260px, 520px) 1fr auto;
    align-items:center;
    gap:18px;
  }
}

/* =========================================================
   Buttons
   ========================================================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:12px 16px;
  border-radius:999px;
  border:1.5px solid var(--ink);
  font-weight:800;
  letter-spacing:.02em;
  background:var(--ink);
  color:#fff;
  box-shadow:var(--shadow);
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.btn:hover{transform:translateY(-1px);text-decoration:none}
.btn:active{transform:translateY(0)}
.btn.outline{background:#fff;color:var(--ink);box-shadow:none}
.btn.outline:hover{background:var(--soft)}
.btn.small{padding:10px 14px;font-size:.95rem}

/* =========================================================
   Hero
   ========================================================= */
.hero{padding:64px 0 46px}
.hero-grid{display:grid;gap:18px}
.hero-card{
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:22px;
  box-shadow:var(--shadow);
  background:
    radial-gradient(1200px 420px at 20% -10%, rgba(0,0,0,.06), rgba(0,0,0,0)),
    #fff;
}
.hero h1{font-size:2.25rem}
.hero .sub{font-size:1.03rem;color:var(--muted);max-width:52ch}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}
.hero-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.badge{
  border:1px dashed rgba(0,0,0,.35);
  padding:8px 10px;
  border-radius:999px;
  font-weight:700;
  font-size:.88rem;
  color:var(--muted);
  background:#fff;
}

/* Default hero media */
.hero-media{
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  min-height:260px;
  background: url("https://cccrossfit-smukg.wpcomstaging.com/wp-content/uploads/2026/01/hero-placeholder.jpg") center/cover no-repeat;
}
.hero-media .overlay{
  height:100%;
  display:flex;
  align-items:flex-end;
  padding:18px;
  background: linear-gradient(180deg, rgba(255,255,255,0), rgba(255,255,255,.92));
}
.hero-media .overlay p{
  margin:0;
  font-weight:800;
  letter-spacing:.02em;
}
@media(min-width: 900px){
  .hero-grid{grid-template-columns: 1.2fr .8fr;align-items:stretch}
  .hero h1{font-size:2.9rem}
}

/* =========================================================
   Cards / grids
   ========================================================= */
.grid{display:grid;gap:14px}
@media(min-width: 820px){.grid.cols-3{grid-template-columns: repeat(3,1fr)}}
@media(min-width: 820px){.grid.cols-2{grid-template-columns: repeat(2,1fr)}}
.card{
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:#fff;
  padding:18px;
  box-shadow: 0 10px 24px rgba(0,0,0,.05);
}
.card .meta{color:var(--muted);font-weight:700;font-size:.92rem}
.card h3{margin-top:8px}
.card ul{margin:10px 0 0;padding-left:18px}
.card li{margin:6px 0}

/* Schedule */
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:var(--radius);background:#fff}
table{border-collapse:collapse;width:100%}
th,td{padding:12px 12px;border-bottom:1px solid var(--line);text-align:left;white-space:nowrap}
th{font-weight:900;background:var(--soft)}
tr:last-child td{border-bottom:0}

/* Pricing */
.pricing{display:grid;gap:14px}
@media(min-width: 900px){.pricing{grid-template-columns: repeat(3,1fr)}}
.price{padding:22px;border-radius:var(--radius);border:1px solid var(--line);background:#fff}
.price.featured{border:2px solid var(--ink);box-shadow:var(--shadow)}
.price .amount{font-size:2.1rem;font-weight:900;letter-spacing:-.02em}

/* Testimonials */
.quote{position:relative;padding:18px}
.quote:before{
  content:"“";
  position:absolute;left:14px;top:-10px;
  font-family: Graduate, serif;
  font-size:58px;opacity:.12;
}
.quote p{margin:0 0 10px}
.quote .who{font-weight:900}
.slider-track{display:flex;gap:14px;overflow:auto;scroll-snap-type:x mandatory;padding-bottom:6px}
.slide{min-width: 86%;scroll-snap-align:start}
@media(min-width: 820px){.slide{min-width: 40%}}

/* Footer */
.site-footer{border-top:1px solid var(--line);padding:40px 0}
.footer-grid{display:grid;gap:18px}
@media(min-width: 820px){.footer-grid{grid-template-columns: 1.2fr .8fr .8fr}}
.footer-title{font-weight:900;margin:0 0 10px}
.footer-links a{display:block;padding:6px 0;color:var(--muted);font-weight:700}
.footer-links a:hover{color:var(--text);text-decoration:none}

/* WordPress core */
.wp-block-image, .wp-block-gallery{margin:0}
.wp-block-buttons{gap:12px}
.alignwide{max-width:var(--max);margin-left:auto;margin-right:auto}

/* Offer emblem */
.offer-emblem{
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  padding: 14px 18px 12px;
  border-radius: 999px;
  border: 7px solid #d40000;
  background: #fff;
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
  max-width: 420px;
  width:100%;
  text-decoration:none;
  color:inherit;
  cursor:pointer;
}
.offer-emblem:before{content:none !important;}
.offer-top{font-weight:900;letter-spacing:.06em;text-transform:uppercase;font-size:.78rem;color:#d40000}
.offer-mid{font-weight:900;letter-spacing:.04em;text-transform:uppercase;font-size:.92rem;margin-top:2px}
.offer-price{font-weight:900;font-size:1.9rem;letter-spacing:-.02em;color:#111;margin-top:2px}
.offer-bot{font-weight:800;font-size:.82rem;color:#d40000;margin-top:2px}
.offer-terms{font-weight:900;font-size:.80rem;letter-spacing:.06em;text-transform:uppercase;color:#d40000;margin-top:2px}

/* Hero variant: emblem instead of photo */
.hero-media.hero-emblem{background:#fff !important}
.hero-media.hero-emblem .overlay{
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:14px;
  background:transparent;
  text-align:center;
  padding:22px;
}
.hero-emblem-caption{margin:0 !important;font-weight:900;letter-spacing:.02em}

/* Mobile layout helpers (true small screens) */
@media (max-width: 760px){
  .container{ padding-left:16px; padding-right:16px; }
  .section{ padding-top:34px; padding-bottom:34px; }

  .hero{ padding-top:18px; }
  .hero-grid{ grid-template-columns:1fr !important; gap:16px !important; }
  .hero-media{ min-height:220px; }

  .btn, .wp-block-button__link{
    width:100%;
    min-height:46px;
    border-radius:14px;
    justify-content:center;
  }

  .table-wrap, .wp-block-table{
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }
  .wp-block-table table, .table-wrap table{ min-width:720px; }

  .footer-grid{ grid-template-columns:1fr !important; gap:14px !important; }
}

/* =========================================================
   Touch-device override: keep hamburger on iPhone/iPad even at ~980px widths
   + slightly bigger logo on mobile
   ========================================================= */
@media (max-width: 1024px) and (hover: none) and (pointer: coarse){
  :root{ --logo-desktop: var(--logo-mobile); } /* swap logo size on touch devices */

  .nav-toggle{ display:inline-flex !important; }
  .primary-nav{ display:none !important; }
  .primary-nav.open{ display:block !important; }
}

/* Improve anchor/section jump spacing with sticky header */
:target{ scroll-margin-top: 80px; }
/* =========================================================
   FIX: iPhone/Touch devices showing "desktop scaled down"
   Forces proper mobile layout + readable sizing
   Paste at VERY BOTTOM of style.css
   ========================================================= */
@media (max-width: 1024px) and (hover: none) and (pointer: coarse){
  html{
    font-size: 19px !important;            /* adjust 18–20 if needed */
    -webkit-text-size-adjust: 100% !important;
    text-size-adjust: 100% !important;
  }

  /* Force hamburger + dropdown nav */
  .nav-toggle{ display:inline-flex !important; }
  .primary-nav{ display:none !important; position:absolute !important; }
  .primary-nav.open{ display:block !important; }

  /* Make layouts single-column so it doesn't feel "shrunk" */
  .hero-grid{ grid-template-columns: 1fr !important; }
  .grid.cols-2, .grid.cols-3{ grid-template-columns: 1fr !important; }
  .pricing{ grid-template-columns: 1fr !important; }

  /* Comfortable spacing */
  .container{ max-width:100% !important; padding-left:16px !important; padding-right:16px !important; }
  .section{ padding: 40px 0 !important; }
}
/* =========================================================
   LOGO SIZE: bigger on desktop + mobile (safe sizes)
   Paste at VERY BOTTOM of style.css
   ========================================================= */
:root{
  --logo-desktop: 72px;   /* desktop logo size */
  --logo-mobile: 84px;    /* mobile logo size */
}

/* Desktop/global */
.site-header .custom-logo,
.site-header .custom-logo-link img,
.site-header .brand img{
  width: var(--logo-desktop) !important;
  height: var(--logo-desktop) !important;
  max-width:none !important;
  max-height:none !important;
  object-fit:contain !important;
}

/* Mobile/touch devices */
@media (max-width: 1024px) and (hover: none) and (pointer: coarse){
  .site-header .custom-logo,
  .site-header .custom-logo-link img,
  .site-header .brand img{
    width: var(--logo-mobile) !important;
    height: var(--logo-mobile) !important;
  }
}
/* =========================================================
   LOGO SIZE: bigger on desktop + mobile (safe sizes)
   Paste at VERY BOTTOM of style.css
   ========================================================= */
:root{
  --logo-desktop: 72px;   /* desktop logo size */
  --logo-mobile: 84px;    /* mobile logo size */
}

/* Desktop/global */
.site-header .custom-logo,
.site-header .custom-logo-link img,
.site-header .brand img{
  width: var(--logo-desktop) !important;
  height: var(--logo-desktop) !important;
  max-width:none !important;
  max-height:none !important;
  object-fit:contain !important;
}

/* Mobile/touch devices */
@media (max-width: 1024px) and (hover: none) and (pointer: coarse){
  .site-header .custom-logo,
  .site-header .custom-logo-link img,
  .site-header .brand img{
    width: var(--logo-mobile) !important;
    height: var(--logo-mobile) !important;
  }
}
html { outline: 10px solid lime !important; }
