/* Calgary Tennis Club — replica of current Wild Apricot theme (homestead_roman_bricks) */
:root{
  --green:#1A7B30;       /* header & nav band */
  --green-dark:#063328;  /* brand dark / footer / hovers */
  --green-mid:#084B3B;
  --teal:#13AD8E;        /* links & buttons */
  --mint:#89E0CF;        /* headings & active nav */
  --gold:#E0C772;
  --bg:#171817;          /* page background */
  --bar:#2b2b2b;         /* breadcrumb bar */
  --panel:#202120;       /* live-feature cards */
  --panel-head:#272827;
  --text:#e7e7e3;
  --muted:#a6a8a3;
  --cream:#eceae0;       /* big titles */
  --line:rgba(255,255,255,.12);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Open Sans',-apple-system,Segoe UI,Roboto,sans-serif;color:var(--text);background:var(--bg);line-height:1.6}
a{color:var(--teal);text-decoration:none}
a:hover{color:var(--green-dark);text-decoration:none}
img{max-width:100%;display:block}

/* header */
.site-header{background:var(--green)}
.logo-band{display:flex;justify-content:center;padding:30px 20px 16px}
.logo img{height:128px}
.main-nav{background:var(--green);border-top:1px solid rgba(255,255,255,.14)}
.main-nav>ul{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;align-items:center;max-width:1180px;margin:0 auto}
.main-nav>ul>li{position:relative}
.main-nav>ul>li>a{display:block;color:#fff;padding:18px 18px;font-size:.82rem;font-weight:600;letter-spacing:1.3px;text-transform:uppercase}
.main-nav>ul>li>a:hover{color:var(--mint)}
.main-nav>ul>li.sel>a{color:var(--mint)}
.main-nav>ul>li.has-sub:not(.hamburger)>a::after{content:"\00A0\203A";font-weight:400}
.hamburger>a{font-size:1.15rem;letter-spacing:0!important}
.main-nav li ul{position:absolute;top:100%;left:0;background:var(--green-dark);list-style:none;min-width:230px;display:none;z-index:20;box-shadow:0 8px 20px rgba(0,0,0,.4)}
.hamburger ul{left:auto;right:0}
.main-nav li.has-sub:hover>ul{display:block}
.main-nav li ul li a{display:block;color:#fff;padding:12px 18px;font-size:.76rem;letter-spacing:1px;text-transform:uppercase;font-weight:600}
.main-nav li ul li a:hover{background:var(--green);color:#fff}
.sub-bar{background:var(--bar);border-top:1px solid rgba(0,0,0,.25)}
.sub-bar{display:flex;justify-content:space-between;align-items:center;max-width:1180px;margin:0 auto;padding:12px 20px}
.crumb{color:var(--mint);font-family:'Roboto Condensed',sans-serif;font-size:.84rem;letter-spacing:2px;text-transform:uppercase}
.login{display:inline-flex;align-items:center;gap:9px;color:#fff}
.login:hover{color:#fff}
.login .avatar{width:26px;height:26px;border-radius:50%;background:url(./assets/avatar.svg) center/cover no-repeat}
.login-text{text-decoration:underline}

/* content */
.content{max-width:1000px;margin:0 auto;padding:38px 20px 64px}
.page-title{font-family:'Roboto Condensed',sans-serif;font-weight:300;text-transform:uppercase;font-size:2.7rem;letter-spacing:1px;color:var(--cream);margin-bottom:34px;line-height:1.05}
.intro{display:grid;grid-template-columns:58% 42%;gap:38px;align-items:start;margin-bottom:52px}
.intro-photo img{width:100%;height:auto;border-radius:2px}
.intro-text p{margin-bottom:16px;font-size:1rem;color:var(--text)}
.btn{display:inline-block;background:var(--teal);color:#fff;padding:13px 26px;font-weight:700;font-size:.82rem;letter-spacing:1.2px;text-transform:uppercase}
.btn:hover{background:var(--green-dark);color:#fff}

.two-col{display:grid;grid-template-columns:1fr 1fr;gap:50px;margin-bottom:20px}
.col-title{font-family:'Roboto Condensed',sans-serif;font-weight:400;text-transform:uppercase;font-size:1.7rem;color:var(--mint);margin-bottom:14px;letter-spacing:.5px}
.col-body p{margin-bottom:12px;color:var(--text)}
.col-body ul{margin:0 0 6px 20px}
.col-body li{margin-bottom:6px;color:var(--text)}
.col-body a{color:var(--teal)}

/* ===== live features (added) ===== */
.live{margin-top:60px;border-top:1px solid var(--line);padding-top:46px}
.live-title{font-family:'Roboto Condensed',sans-serif;font-weight:400;text-transform:uppercase;font-size:1.9rem;color:var(--mint);margin-bottom:10px;letter-spacing:.5px}
.live-sub{max-width:680px;margin:0 0 30px;color:var(--muted);font-size:.98rem}
.live-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-bottom:30px}
.live-grid:last-child{margin-bottom:0}
.heat-grid{grid-template-columns:1.6fr 1fr}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:8px;overflow:hidden}
.panel-title{background:var(--panel-head);color:var(--mint);font-family:'Roboto Condensed',sans-serif;font-weight:400;text-transform:uppercase;letter-spacing:1px;font-size:1.05rem;padding:13px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.panel-body{padding:18px}
.panel-note{font-size:.82rem;color:var(--muted);margin:-2px 0 14px}
.live-badge{font-size:.6rem;font-weight:700;letter-spacing:1.5px;color:#fff;background:#c0392b;padding:3px 9px;border-radius:99px;animation:pulse 2s infinite;font-family:'Open Sans',sans-serif}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.55}}

/* weather */
.wx-main{display:flex;align-items:center;gap:22px}
.wx-temp{display:flex;align-items:flex-start;line-height:.85}
.wx-temp>span:first-child{font-family:'Roboto Condensed',sans-serif;font-size:3.8rem;color:#fff;font-weight:300}
.wx-deg{font-size:1.1rem;color:var(--mint);margin-top:6px}
.wx-cond{font-size:1.02rem;color:var(--text)}
.wx-icon{font-size:2.1rem;line-height:1}
.wx-feels{color:var(--muted);font-size:.85rem;margin-top:2px}
.verdict{margin:18px 0;padding:11px 16px;background:var(--teal);color:#fff;border-radius:5px;font-weight:700;text-align:center;font-size:.9rem;letter-spacing:.3px}
.verdict.warn{background:#c0392b}
.verdict.caution{background:#c98a16}
.wx-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.wx-stat{display:flex;flex-direction:column;background:rgba(255,255,255,.05);border:1px solid var(--line);padding:11px 14px;border-radius:5px}
.wx-label{font-size:.66rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
.wx-val{font-size:1.1rem;font-weight:700;color:#fff}
.lightning{margin-top:14px;background:rgba(192,57,43,.18);border:1px solid #c0392b;color:#f1b0a8;padding:11px 14px;border-radius:5px;font-size:.86rem;font-weight:600}
.wx-foot{margin-top:16px;padding-top:12px;border-top:1px solid var(--line);font-size:.74rem;color:var(--muted)}

/* courts */
.occ-summary{font-size:1.05rem;margin-bottom:16px;color:var(--text)}
.occ-summary .occ-free{font-family:'Roboto Condensed',sans-serif;font-size:2rem;font-weight:700;color:var(--mint)}
.court-grid{display:flex;flex-direction:column;gap:16px}
.court-group-label{font-family:'Roboto Condensed',sans-serif;text-transform:uppercase;letter-spacing:1.2px;font-size:.72rem;color:var(--muted);margin-bottom:8px;display:flex;align-items:center;gap:8px}
.court-group-label .dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.court-group-label .dot.clay{background:#cc7a4d}
.court-group-label .dot.hard{background:#4f93c4}
.court-row{display:grid;grid-template-columns:repeat(3,1fr);gap:9px}
.court{aspect-ratio:1.15;border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;border:1px solid var(--line);position:relative}
.court .cnum{font-family:'Roboto Condensed',sans-serif;font-size:1.3rem;font-weight:700}
.court .cstate{font-size:.6rem;text-transform:uppercase;letter-spacing:.5px;opacity:.9;margin-top:2px}
.court.free{background:rgba(19,173,142,.18);color:#5fe0c4;border-color:rgba(19,173,142,.45)}
.court.busy{background:rgba(192,57,43,.16);color:#f0a89e;border-color:rgba(192,57,43,.4)}
.court.clay{box-shadow:inset 0 3px 0 rgba(204,122,77,.6)}
.court.hard{box-shadow:inset 0 3px 0 rgba(79,147,196,.55)}

/* heatmap */
.heatmap{display:grid;grid-template-columns:auto repeat(7,1fr);gap:5px;font-size:.7rem}
.heatmap .hlabel{color:var(--muted);display:flex;align-items:center;justify-content:center}
.heatmap .hcell{aspect-ratio:1;border-radius:3px;min-height:16px}
.g1,.hcell[data-l="1"]{background:#bcd9b3}
.g2,.hcell[data-l="2"]{background:#d8d488}
.g3,.hcell[data-l="3"]{background:#e3c069}
.g4,.hcell[data-l="4"]{background:#d18f50}
.g5,.hcell[data-l="5"]{background:#b85138}
.heat-legend{display:flex;align-items:center;gap:6px;margin-top:14px;font-size:.72rem;color:var(--muted)}
.heat-legend .g{width:16px;height:16px;border-radius:3px;display:inline-block}
.insights{list-style:none;margin:0}
.insights li{padding:13px 0;border-bottom:1px solid var(--line);display:flex;gap:11px;align-items:flex-start;font-size:.92rem;color:var(--text)}
.insights li:last-child{border-bottom:0}
.insights li b{color:var(--mint);font-weight:700}
.ins-ico{font-size:1.1rem;flex-shrink:0}

/* footer */
.site-footer{background:var(--green-dark);color:#fff;padding:50px 20px 20px}
.footer-top{max-width:1000px;margin:0 auto 40px;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.footer-logo img{height:96px}
.footer-links{display:flex;flex-direction:column;gap:8px}
.footer-links a{color:#fff}
.footer-links a:hover{color:var(--mint)}
.footer-bottom{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:40px}
.footer-map iframe{width:100%;height:300px;border:0;border-radius:4px}
.footer-contact h4{font-size:.78rem;letter-spacing:1.5px;margin:14px 0 4px;color:var(--mint);text-transform:uppercase}
.footer-contact h4:first-child{margin-top:0}
.footer-contact p{font-size:.95rem;margin-bottom:6px;color:rgba(255,255,255,.85)}
.social{display:flex;gap:10px;margin-top:18px}
.social a{width:34px;height:34px;border:1px solid rgba(255,255,255,.4);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.8rem}
.social a:hover{background:var(--teal)}
.copyright{text-align:center;padding-top:30px;font-size:.85rem;opacity:.8}
.demo-stamp{text-align:center;margin-top:8px;font-size:.7rem;opacity:.45;letter-spacing:1px}

@media(max-width:760px){
  .intro,.two-col,.footer-top,.footer-bottom,.live-grid,.heat-grid{grid-template-columns:1fr}
  .main-nav li ul{position:static;display:none}
  .page-title{font-size:2rem}
  .court-grid{grid-template-columns:repeat(3,1fr)}
  .logo img{height:96px}
}
