/* Ulster County Open — shared site styles */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,700;0,900;1,700&display=swap');

:root{
  --bg:#ffffff; --card:#ffffff; --ink:#16140f; --muted:#6b6862; --hint:#9b988f;
  --line:#e0dbd0; --line2:#ccc8bc; --info:#185fa5;
  --clay:#b5451b; --clay-light:#f5ede6;
  --forest:#2a5a1f; --navy:#1b3464;
  --win:#eaf3de; --winborder:#9fc97e; --winink:#27500a;
  --grey:#f2f2f0; --greyink:#6b6862;
  --maxw:1320px;
  --gutter:clamp(20px,5vw,52px);
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;
  --serif:'Playfair Display',Georgia,"Times New Roman",serif;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--sans); font-size:17px; line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
h1,h2{font-family:var(--serif); font-weight:700; letter-spacing:-0.01em; line-height:1.05; margin:0 0 .5em; color:var(--ink)}
h3,h4{font-family:var(--sans); font-weight:700; letter-spacing:-0.01em; line-height:1.15; margin:0 0 .5em; color:var(--ink)}
h1{font-size:clamp(38px,7vw,76px)}
h2{font-size:clamp(28px,4vw,50px)}
h3{font-size:20px}
p{margin:0 0 1em}
a{color:var(--ink); text-decoration:none}
a:hover{text-decoration:underline}
.eyebrow{font-size:11px; letter-spacing:0.22em; text-transform:uppercase; color:var(--clay); font-weight:700; margin:0 0 14px; font-family:var(--sans)}
.lede{font-size:19px; line-height:1.55; color:var(--muted)}
.muted{color:var(--muted)}
.hint{color:var(--hint)}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 var(--gutter)}
.section{padding:clamp(52px,8vw,96px) 0}
.section--tight{padding:clamp(32px,5vw,60px) 0}
hr.rule{border:0; border-top:1px solid var(--line); margin:0}

/* ---- header ---- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:var(--bg);
  border-bottom:1px solid var(--line2);
}
.nav{
  max-width:var(--maxw); margin:0 auto;
  padding:14px var(--gutter);
  display:flex; align-items:center; justify-content:space-between; gap:18px;
}
.brand{display:flex; align-items:center; color:var(--ink); line-height:1}
.brand:hover{text-decoration:none}
.brand .mark-h{height:66px; width:auto; display:block}
.brand .mark-icon{height:40px; width:40px; display:none}
@media (max-width:760px){
  .brand .mark-h{display:none}
  .brand .mark-icon{display:block}
}
.nav-links{display:flex; align-items:center; gap:4px; list-style:none; margin:0; padding:0}
.nav-links a{font-size:13.5px; font-weight:600; color:var(--muted); padding:8px 13px; border-radius:20px; display:block; letter-spacing:0.01em}
.nav-links a:hover{color:var(--ink); background:var(--grey); text-decoration:none}
.nav-links a.active{color:var(--ink); background:var(--grey)}
.nav-toggle{display:none; background:none; border:1.5px solid var(--line2); border-radius:6px; padding:7px 9px; cursor:pointer; color:var(--ink)}
@media (max-width:760px){
  .nav-toggle{display:inline-flex}
  .nav{position:relative; flex-wrap:wrap}
  .nav-links{position:absolute; top:100%; left:0; right:0; flex-direction:column; align-items:stretch; gap:0; background:var(--bg); border-bottom:1px solid var(--line); padding:6px var(--gutter) 14px; display:none; z-index:10}
  .nav-links.open{display:flex}
  .nav-links a{padding:12px 6px; border-bottom:1px solid var(--line); border-radius:0}
  .nav-links a.active{background:transparent}
}

/* ---- buttons ---- */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--sans); font-size:14px; font-weight:700; letter-spacing:0.02em;
  padding:13px 28px; border-radius:999px; cursor:pointer;
  border:2px solid transparent; text-decoration:none; transition:background .12s,color .12s,border-color .12s;
  line-height:1;
}
.btn:hover{text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--clay); color:#fff; border-color:var(--clay)}
.btn--primary:hover{background:#9a3a14; border-color:#9a3a14}
.btn--ink{background:var(--ink); color:#fff; border-color:var(--ink)}
.btn--ink:hover{background:#000; border-color:#000}
.btn--ghost{background:transparent; color:var(--ink); border-color:var(--ink)}
.btn--ghost:hover{background:var(--ink); color:#fff}
.pill{display:inline-block; background:var(--clay); color:#fff; border-radius:999px; padding:5px 14px; font-size:11px; font-weight:700; letter-spacing:0.12em; text-transform:uppercase}

/* ---- cards / misc ---- */
.card{background:var(--card); border:1px solid var(--line); border-radius:8px; padding:28px}
.tag{display:inline-block; font-size:11px; letter-spacing:0.06em; font-weight:700; padding:4px 12px; border-radius:999px; background:var(--grey); color:var(--muted)}
.notice{background:var(--clay-light); border:1px solid rgba(181,69,27,.25); border-radius:8px; padding:15px 19px; font-size:15px; color:var(--muted)}
.notice strong{color:var(--clay)}
.notice.announce{background:var(--clay-light); border-color:rgba(181,69,27,.3)}
.notice.announce strong{color:var(--clay)}

/* ---- layout helpers ---- */
.split{display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(28px,5vw,64px); align-items:start}
@media (max-width:800px){.split{grid-template-columns:1fr; gap:28px}}
.factlist{list-style:none; margin:0; padding:0}
.factlist li{display:flex; justify-content:space-between; gap:14px; padding:13px 0; border-bottom:1px solid var(--line)}
.factlist li:last-child{border-bottom:0}
.factlist .k{color:var(--muted); font-size:14px}
.factlist .v{font-weight:700; text-align:right; font-size:14px}

/* ---- photos ---- */
.photo-strip{display:grid; grid-template-columns:repeat(4,1fr); gap:2px}
@media (max-width:680px){.photo-strip{grid-template-columns:repeat(2,1fr)}}
.photo-strip-item{aspect-ratio:3/4; overflow:hidden; background:var(--grey)}
.photo-strip-item img{width:100%; height:100%; object-fit:cover; display:block}

/* ---- social icons ---- */
.social-row{display:flex; gap:14px; align-items:center}
.social-icon{display:inline-flex; align-items:center; justify-content:center; width:22px; height:22px; color:var(--muted); transition:color .1s; flex-shrink:0}
.social-icon:hover{color:var(--ink); text-decoration:none}
.social-icon svg{width:17px; height:17px; fill:currentColor}

/* ---- OOP date buttons ---- */
.date-btns{display:flex; gap:8px; flex-wrap:wrap; margin:20px 0}
.date-btn{font:inherit; font-size:13px; font-weight:600; padding:9px 18px; border:1.5px solid var(--line2); border-radius:999px; background:var(--card); color:var(--muted); cursor:pointer; transition:all .12s}
.date-btn:hover{border-color:var(--ink); color:var(--ink)}
.date-btn.active{background:var(--clay); color:#fff; border-color:var(--clay)}
.oop-state{color:var(--hint); font-size:15px; padding:6px 0}
.venue-group{margin-bottom:32px}
.venue-group h3{font-size:11px; letter-spacing:0.16em; text-transform:uppercase; color:var(--hint); padding-bottom:10px; margin-bottom:2px; border-bottom:1px solid var(--line)}
.match-list{list-style:none; margin:0; padding:0}
.match-row{display:grid; grid-template-columns:96px 1fr; gap:16px; align-items:center; padding:14px 0; border-bottom:1px solid var(--line)}
.match-row:last-child{border-bottom:0}
.match-row .time{font-weight:700; font-size:14px}
.match-row .who{font-size:15px}
.match-row .who .cat{font-size:11px; color:var(--hint); font-weight:700; letter-spacing:0.04em; text-transform:uppercase}
@media (max-width:560px){.match-row{grid-template-columns:72px 1fr}}

/* ---- draws tab bar ---- */
.draw-tabs{background:var(--bg); border-bottom:1px solid var(--line)}
.draw-tabs-inner{max-width:var(--maxw); margin:0 auto; padding:0 var(--gutter); display:flex; gap:4px; overflow-x:auto; -webkit-overflow-scrolling:touch; scrollbar-width:none}
.draw-tabs-inner::-webkit-scrollbar{display:none}
.draw-tab{background:none; border:none; font:inherit; font-size:14px; font-weight:600; color:var(--muted); padding:14px 16px; cursor:pointer; white-space:nowrap; border-bottom:3px solid transparent; margin-bottom:-1px; transition:color .12s}
.draw-tab:hover{color:var(--ink)}
.draw-tab.active{color:var(--clay); border-bottom-color:var(--clay)}
.draw-tab .tab-badge{display:inline-block; margin-left:7px; font-size:10px; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; padding:2px 8px; border-radius:999px; vertical-align:middle}
.draw-tab .tab-badge.soon{background:var(--grey); color:var(--hint)}
.draw-tab .tab-badge.active-draw{background:var(--clay-light); color:var(--clay)}
.draw-tab .tab-badge.done{background:#eaf3de; color:var(--winink)}

/* ---- draw viewer ---- */
.draw-viewer{width:100%; height:calc(100vh - 160px); min-height:500px; border:none; display:block; background:var(--grey)}
.draw-placeholder{display:flex; flex-direction:column; align-items:center; justify-content:center; height:calc(100vh - 160px); min-height:400px; text-align:center; color:var(--hint); padding:40px}
.draw-placeholder p{font-size:16px; max-width:400px; margin:0 auto}

/* ---- page head (inner pages) ---- */
.page-head{padding:clamp(36px,6vw,72px) 0 clamp(22px,4vw,38px)}
.page-head h1{margin:0 0 12px}
.prose{max-width:680px}
.prose h2{font-size:clamp(20px,3vw,30px); margin:44px 0 14px}
.prose p{margin:0 0 17px; color:var(--muted)}
.prose p.lead-p{color:var(--ink)}
.prose a{text-decoration:underline}

/* ---- footer ---- */
.site-footer{border-top:1px solid var(--line); background:var(--grey); padding:52px 0 40px; margin-top:20px}
.footer-grid{display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:44px}
.footer-grid h4{font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:var(--hint); margin-bottom:14px; font-weight:700}
.footer-grid ul{list-style:none; margin:0; padding:0}
.footer-grid li{margin-bottom:9px}
.footer-grid a,.footer-grid p{font-size:14px; color:var(--muted); margin:0 0 8px}
.footer-grid .footer-logo{height:36px; width:auto; margin-bottom:16px; display:block}
.footer-base{margin-top:38px; padding-top:20px; border-top:1px solid var(--line); display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; font-size:12.5px; color:var(--hint)}
@media (max-width:680px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:440px){.footer-grid{grid-template-columns:1fr}}

/* ---- contact page ---- */
.contact-block{padding:clamp(32px,5vw,52px) 0; border-bottom:1px solid var(--line)}
.contact-block:last-child{border-bottom:0}
.contact-block h2{margin:0 0 10px}
.contact-block p{color:var(--muted); margin:0 0 16px}
.contact-email{font-size:clamp(15px,2vw,18px); font-weight:700; letter-spacing:-0.01em; color:var(--clay); font-family:var(--serif)}
.contact-email:hover{text-decoration:underline}

:focus-visible{outline:2px solid var(--clay); outline-offset:2px}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
