/* Tampa Bay Curling Club - hand-coded stylesheet
   Ice-sheet palette: deep harbor navy, ice blue, granite grey, a single curling-red accent.
   No framework, no build step. Just CSS. */

:root{
  --navy:#0b3d5c;
  --navy-deep:#082b41;
  --ice:#eef6fb;
  --ice-line:#d6e6f0;
  --sky:#2f6fa3;
  --sky-soft:#cfe3f0;
  --granite:#3a4750;
  --rock:#c0392b;       /* curling-red button */
  --ink:#1d2a33;
  --muted:#5e6f7a;
  --paper:#ffffff;
  --shadow:0 1px 2px rgba(11,61,92,.06), 0 8px 24px rgba(11,61,92,.08);
  --radius:14px;
  --shell:1080px;
  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  font-size:17px;
  /* faint ice-sheet texture: two soft horizontal pebble lines */
  background-image:
    linear-gradient(180deg,#f7fbfe 0%, #ffffff 240px);
  background-repeat:no-repeat;
}
h1,h2,h3,h4{font-family:var(--serif);color:var(--navy);line-height:1.15;font-weight:600;letter-spacing:-.01em}
a{color:var(--sky);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block}
p{margin:0 0 1rem}
.muted{color:var(--muted)}
.small{font-size:.86rem}

.shell{max-width:var(--shell);margin-inline:auto;padding-inline:22px;width:100%}

.skip{position:absolute;left:-999px;top:0;background:var(--navy);color:#fff;padding:10px 16px;z-index:50;border-radius:0 0 8px 0}
.skip:focus{left:0}

/* ---------- masthead ---------- */
.masthead{
  background:var(--navy);
  color:#eaf3fa;
  position:sticky;top:0;z-index:30;
  border-bottom:3px solid var(--rock);
}
.mast-row{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:66px}
.logo{display:flex;align-items:center;gap:10px;color:#fff;font-family:var(--serif);font-size:1.18rem}
.logo:hover{text-decoration:none}
.logo-mark{color:var(--sky-soft);display:inline-flex}
.logo-mark--sm{color:var(--sky)}
.logo-text b{font-weight:700}
.logo-text{font-weight:500}

.mainnav{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.mainnav a{
  color:#d6e8f4;padding:8px 13px;border-radius:8px;font-weight:500;font-size:.97rem;
}
.mainnav a:hover{background:rgba(255,255,255,.10);text-decoration:none;color:#fff}
.mainnav a.is-current{background:var(--rock);color:#fff}

.navtoggle{display:none}
.navtoggle-btn{display:none;cursor:pointer;padding:10px;border-radius:8px}
.navtoggle-btn span{display:block;width:24px;height:2px;background:#eaf3fa;margin:5px 0;border-radius:2px}

/* ---------- hero ---------- */
.hero{
  background:
    radial-gradient(900px 380px at 78% -10%, rgba(47,111,163,.22), transparent 60%),
    linear-gradient(180deg,#f3f9fd 0%, #ffffff 100%);
  border-bottom:1px solid var(--ice-line);
}
.hero-grid{display:grid;grid-template-columns:1.25fr .9fr;gap:42px;align-items:center;padding:64px 22px 56px}
.eyebrow{
  text-transform:uppercase;letter-spacing:.14em;font-size:.74rem;font-weight:600;
  color:var(--sky);margin:0 0 14px
}
.hero h1{font-size:clamp(2.1rem,4.6vw,3.3rem);margin:0 0 18px}
.lede{font-size:1.18rem;color:var(--granite);max-width:36ch;margin:0 0 26px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.hero-note{font-size:.95rem;color:var(--muted);max-width:46ch}
.hero-art{display:flex;justify-content:center}
.house-art{width:100%;max-width:330px;filter:drop-shadow(0 18px 30px rgba(11,61,92,.18));border-radius:18px}

.btn{
  display:inline-block;padding:13px 22px;border-radius:10px;font-weight:600;font-size:1rem;
  border:2px solid transparent;cursor:pointer;transition:transform .04s ease, box-shadow .15s ease;
  text-align:center;
}
.btn:hover{text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--rock);color:#fff;box-shadow:0 6px 16px rgba(192,57,43,.28)}
.btn-primary:hover{background:#a93226;color:#fff}
.btn-ghost{background:#fff;color:var(--navy);border-color:var(--sky-soft)}
.btn-ghost:hover{border-color:var(--sky);color:var(--navy)}

/* ---------- stat band ---------- */
.band{background:var(--navy-deep);color:#dcebf0;color:#dfeef8}
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:26px 22px}
.stat{display:flex;flex-direction:column;gap:3px;border-left:3px solid var(--rock);padding-left:14px}
.stat-num{font-family:var(--serif);font-size:1.5rem;font-weight:700;color:#fff}
.stat-label{font-size:.86rem;color:#a9c6da;line-height:1.4}

/* ---------- prose ---------- */
.prose-wrap{padding:54px 22px 8px}
.prose{max-width:68ch}
.prose h2{font-size:1.6rem;margin:2.2rem 0 .8rem}
.prose h3{font-size:1.22rem;margin:1.6rem 0 .5rem;color:var(--granite)}
.prose p{margin:0 0 1.05rem}
.prose ul{margin:0 0 1.2rem;padding-left:0;list-style:none}
.prose ul li{position:relative;padding-left:30px;margin:.5rem 0}
.prose ul li::before{
  content:"";position:absolute;left:4px;top:.55em;width:12px;height:12px;border-radius:50%;
  background:radial-gradient(circle at 50% 50%, var(--rock) 0 4px, #fff 4px 6px, var(--sky) 6px 12px);
}
.prose img{border-radius:var(--radius);box-shadow:var(--shadow);margin:1.6rem 0;border:1px solid var(--ice-line)}
.prose figure{margin:1.6rem 0}
.prose figcaption{font-size:.85rem;color:var(--muted);margin-top:.5rem;text-align:center}
.prose a{border-bottom:1px solid var(--sky-soft)}
.prose blockquote{
  margin:1.6rem 0;padding:14px 22px;border-left:4px solid var(--sky);
  background:var(--ice);border-radius:0 10px 10px 0;color:var(--granite);font-style:italic
}

/* ---------- section heads + tiles ---------- */
.section-head{font-size:1.7rem;margin:54px 0 22px;text-align:left}
.section-head::after{content:"";display:block;width:54px;height:3px;background:var(--rock);margin-top:10px;border-radius:2px}
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;padding-bottom:8px}
.tile{
  display:flex;flex-direction:column;background:#fff;border:1px solid var(--ice-line);
  border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);color:var(--ink);
  transition:transform .12s ease, box-shadow .15s ease, border-color .15s ease;
}
.tile:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(11,61,92,.14);border-color:var(--sky-soft);text-decoration:none}
.tile h3{margin:0 0 8px;font-size:1.2rem}
.tile p{font-size:.95rem;color:var(--muted);margin:0 0 16px;flex:1}
.tile-go{font-weight:600;color:var(--rock);font-size:.92rem}

/* ---------- cta strip ---------- */
.cta-strip{margin:60px 0 0;background:linear-gradient(120deg,var(--navy),var(--sky))}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:36px 22px;flex-wrap:wrap}
.cta-inner h2{color:#fff;margin:0 0 6px;font-size:1.5rem}
.cta-inner .muted{color:#d3e6f3}

/* ---------- page head + article ---------- */
.page-head{
  background:linear-gradient(180deg,#f3f9fd,#ffffff);
  border-bottom:1px solid var(--ice-line);padding:30px 0 26px
}
.crumbs{font-size:.86rem;color:var(--muted);margin-bottom:8px}
.crumbs a{color:var(--sky)}
.page-head h1{font-size:clamp(1.8rem,3.6vw,2.5rem);margin:0}
.article{padding:40px 22px 20px}

/* ---------- press list ---------- */
.press-list{list-style:none;padding:0;margin:1.5rem 0;display:grid;gap:16px}
.press-item{
  border:1px solid var(--ice-line);border-radius:var(--radius);padding:20px 22px;background:#fff;
  box-shadow:var(--shadow);border-left:4px solid var(--rock)
}
.press-item h3{margin:0 0 4px;font-size:1.18rem}
.press-outlet{font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:var(--sky);font-weight:600;margin:0 0 8px}
.press-item p{margin:0;color:var(--granite)}

/* ---------- contact ---------- */
.contact-wrap{padding:38px 22px 20px;max-width:760px}
.contact-intro{margin-bottom:18px}
.notice{
  background:#e7f6ec;border:1px solid #b6e0c4;color:#1e6b3a;
  padding:14px 18px;border-radius:10px;margin:0 0 22px;font-weight:500
}
.cform{display:grid;gap:18px;background:#fff;border:1px solid var(--ice-line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow)}
.field{display:grid;gap:6px}
.field span{font-weight:600;font-size:.92rem;color:var(--granite)}
.cform input,.cform textarea{
  font:inherit;padding:12px 14px;border:1px solid #cddde8;border-radius:10px;background:#fbfdff;color:var(--ink);
}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--sky);box-shadow:0 0 0 3px rgba(47,111,163,.15)}
.cform button{justify-self:start}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* ---------- footer ---------- */
.endpiece{background:var(--navy);color:#cfe1ee;margin-top:64px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:36px;padding:46px 22px 30px}
.foot-brand{display:flex;align-items:center;gap:9px;font-family:var(--serif);font-size:1.2rem;color:#fff;margin-bottom:10px}
.foot-about .muted{color:#aecbe0;max-width:48ch}
.foot-about .small{color:#8fb3cc}
.foot-nav h2{font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;color:#8fb3cc;margin:0 0 12px}
.foot-nav ul{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.foot-nav a{color:#dcecf6}
.foot-nav a:hover{color:#fff}
.foot-base{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:16px 22px;border-top:1px solid rgba(255,255,255,.12);flex-wrap:wrap;font-size:.88rem}
.foot-base .muted{color:#8fb3cc}

/* ---------- responsive ---------- */
@media (max-width:860px){
  .hero-grid{grid-template-columns:1fr;gap:28px;padding:44px 22px 40px}
  .hero-art{order:-1;max-width:260px;margin-inline:auto}
  .stat-row{grid-template-columns:repeat(2,1fr);gap:18px}
  .foot-grid{grid-template-columns:1fr;gap:24px}
}
@media (max-width:680px){
  .navtoggle-btn{display:block}
  .mainnav{
    display:none;position:absolute;top:66px;left:0;right:0;background:var(--navy-deep);
    flex-direction:column;align-items:stretch;gap:0;padding:8px 14px 16px;border-bottom:3px solid var(--rock)
  }
  .navtoggle:checked ~ .mainnav{display:flex}
  .mainnav a{padding:12px 12px;border-radius:8px}
  .cta-inner{flex-direction:column;align-items:flex-start}
}
@media (max-width:430px){
  .stat-row{grid-template-columns:1fr}
}
