/* ClearPath Tickets — "The Matchday Almanac"
   Broadsheet / printed-guide aesthetic: rules, columns, drop caps, listings.
   Fraunces (display) + Inter (text). Sharp edges, hairlines, no cards. */

:root{
  --ink:#1a201b;
  --ink-soft:#525a52;
  --green:#0b6c41;
  --green-deep:#08512f;
  --gold:#9a7b27;
  --paper:#f7f3e8;
  --paper-2:#efe9d8;
  --rule:#1a201b;
  --hair:rgba(26,32,27,.18);
  --hair-soft:rgba(26,32,27,.1);
  --maxw:1160px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--paper);
  line-height:1.62;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* keyboard accessibility — visible focus ring */
:focus-visible{outline:2px solid var(--green);outline-offset:2px}
/* respect reduced-motion preferences */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;
    transition-duration:.01ms!important;scroll-behavior:auto!important}
}

/* skip link */
.skip-link{position:absolute;left:-9999px;top:0;z-index:1000;background:var(--ink);color:#fff;
  padding:10px 16px;font-size:.8rem;font-weight:700;letter-spacing:.04em}
.skip-link:focus{left:8px;top:8px}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:600;line-height:1.06;letter-spacing:-.01em}
em{font-style:italic}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 26px}
.kicker{font-size:.7rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--green-deep)}

/* ---------- topbar ---------- */
.topbar{background:var(--ink);color:#f1ecdd;font-size:.76rem;text-align:center;padding:8px 16px;
  letter-spacing:.04em;text-transform:uppercase}
.topbar strong{color:#e9d499}

/* ---------- masthead / nav ---------- */
.navbar{border-bottom:2px solid var(--rule);background:var(--paper);position:sticky;top:0;z-index:50}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:60px;gap:18px}
.brand{display:flex;align-items:center;gap:10px;font-family:'Fraunces',serif;font-weight:600;font-size:1.18rem}
.brand-mark{width:30px;height:30px;flex:none}
.nav-links{list-style:none;display:flex;align-items:center;flex-wrap:wrap;gap:24px}
.nav-links a{font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);
  padding-bottom:2px;border-bottom:2px solid transparent;transition:.15s}
.nav-links a:hover{color:var(--ink);border-color:var(--green)}
.nav-cta{color:var(--green-deep)!important;border-color:var(--green)!important}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:24px;height:2px;background:var(--ink);border-radius:2px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 24px;
  font-weight:700;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;
  border:2px solid var(--ink);background:transparent;color:var(--ink);transition:.15s;line-height:1}
.btn:hover{background:var(--ink);color:var(--paper)}
.btn-primary{background:var(--green-deep);border-color:var(--green-deep);color:#fff}
.btn-primary:hover{background:var(--ink);border-color:var(--ink);color:#fff}
.btn-ghost{}
.btn-block{width:100%}

/* ---------- masthead band ---------- */
.masthead{border-bottom:1px solid var(--hair);padding:18px 0;text-align:center}
.masthead .dateline{display:flex;justify-content:space-between;font-size:.7rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink-soft);border-bottom:1px solid var(--hair);padding-bottom:12px;margin-bottom:14px}
.masthead .nameplate{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(2.2rem,6vw,3.6rem);letter-spacing:-.02em}
.masthead .tagline{font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--green-deep);margin-top:8px}

/* ---------- lead story (hero) ---------- */
.lead{padding:46px 0 56px;border-bottom:2px solid var(--rule)}
.lead-grid{display:grid;grid-template-columns:1.55fr .95fr;gap:42px}
.lead h1{font-size:clamp(2.4rem,5vw,4rem);margin:10px 0 18px}
.lead .standfirst{font-size:1.18rem;line-height:1.5;color:var(--ink);font-weight:500;
  border-left:3px solid var(--green);padding-left:16px;margin-bottom:20px}
.lead-cols{column-count:2;column-gap:28px;column-rule:1px solid var(--hair);font-size:.95rem;color:var(--ink-soft)}
.lead-cols p{margin-bottom:12px}
.lead-cols p:first-child::first-letter{font-family:'Fraunces',serif;font-size:3.1rem;float:left;
  line-height:.8;padding:6px 8px 0 0;color:var(--green-deep)}
.lead-ctas{display:flex;flex-wrap:wrap;gap:12px;margin-top:22px}
.lead-aside figure{border:1px solid var(--rule);background:#fff}
.lead-aside img{width:100%;aspect-ratio:4/4.4;object-fit:cover;filter:grayscale(.15) contrast(1.03)}
.lead-aside figcaption{font-size:.74rem;color:var(--ink-soft);padding:9px 12px;border-top:1px solid var(--hair);
  font-style:italic}
.lead-note{margin-top:16px;font-size:.78rem;color:var(--ink-soft);background:var(--paper-2);
  border:1px dashed var(--hair);padding:12px 14px}
.lead-note strong{color:var(--green-deep)}
.lead-stats{display:flex;border:1px solid var(--rule);margin-top:14px}
.lead-stats div{flex:1;padding:12px;text-align:center;border-right:1px solid var(--hair)}
.lead-stats div:last-child{border-right:0}
.lead-stats b{display:block;font-family:'Fraunces',serif;font-size:1.5rem;color:var(--green-deep)}
.lead-stats span{font-size:.64rem;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft)}

/* ---------- section heading (broadsheet) ---------- */
.sec{padding:48px 0;border-bottom:1px solid var(--hair)}
.sec-alt{background:var(--paper-2)}
.sec-head{display:flex;align-items:baseline;gap:16px;border-bottom:2px solid var(--rule);padding-bottom:10px;margin-bottom:26px}
.sec-head h2{font-size:clamp(1.5rem,3vw,2.1rem);white-space:nowrap}
.sec-head .lede{font-size:.9rem;color:var(--ink-soft);margin-left:auto;text-align:right;max-width:46ch}
.sec-num{font-family:'Fraunces',serif;color:var(--green);font-size:1.1rem}

/* ---------- fixtures diary (listings) ---------- */
.diary{display:grid}
.diary-item{display:grid;grid-template-columns:130px 1fr 130px;gap:24px;align-items:start;
  padding:18px 0;border-top:1px solid var(--hair)}
.diary-item:first-child{border-top:0}
.diary-when{font-family:'Fraunces',serif}
.diary-when .d{font-size:1.7rem;color:var(--green-deep);line-height:1}
.diary-when .m{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);font-family:'Inter'}
.diary-body h3{font-size:1.16rem;margin-bottom:4px}
.diary-body p{font-size:.88rem;color:var(--ink-soft)}
.diary-tag{justify-self:end;font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  border:1.5px solid var(--ink);padding:5px 10px;white-space:nowrap}
.diary-tag.t-super{background:var(--ink);color:var(--paper)}
.diary-tag.t-liga{border-color:var(--green-deep);color:var(--green-deep)}
.diary-tag.t-cup{border-color:var(--gold);color:var(--gold)}
.diary-foot{font-size:.82rem;color:var(--ink-soft);margin-top:18px;padding-top:14px;border-top:2px solid var(--rule);font-style:italic}

/* ---------- competition columns ---------- */
.cols3{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.colart{padding:0 26px;border-left:1px solid var(--hair)}
.colart:first-child{padding-left:0;border-left:0}
.colart .ch{font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--green);margin-bottom:6px}
.colart h3{font-size:1.5rem;margin-bottom:12px}
.colart>p{font-size:.92rem;color:var(--ink-soft)}
.colart>p:first-of-type::first-letter{font-family:'Fraunces',serif;font-size:2.6rem;float:left;line-height:.8;padding:4px 7px 0 0;color:var(--green-deep)}
.colfacts{list-style:none;margin-top:14px;border-top:1px solid var(--hair);padding-top:12px;display:grid;gap:6px}
.colfacts li{font-size:.82rem;color:var(--ink-soft);display:flex;justify-content:space-between;gap:10px;
  border-bottom:1px dotted var(--hair-soft);padding-bottom:5px}
.colfacts b{color:var(--ink)}

/* ---------- how to (ordered ledger) ---------- */
.ledger{display:grid;grid-template-columns:repeat(5,1fr);border:1px solid var(--rule)}
.ledger .step{padding:20px 18px;border-right:1px solid var(--hair)}
.ledger .step:last-child{border-right:0}
.ledger .step b{font-family:'Fraunces',serif;font-size:2.2rem;color:var(--green);display:block;line-height:1;margin-bottom:8px}
.ledger .step h3{font-size:1rem;margin-bottom:6px}
.ledger .step p{font-size:.82rem;color:var(--ink-soft)}

/* ---------- stadium directory (index list) ---------- */
.directory{display:grid}
.dir-item{display:grid;grid-template-columns:96px 1fr;gap:20px;align-items:center;
  padding:16px 0;border-top:1px solid var(--hair)}
.dir-item:first-child{border-top:0}
.dir-item img{width:96px;height:72px;object-fit:cover;border:1px solid var(--rule);filter:grayscale(.2)}
.dir-meta{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.dir-meta h3{font-size:1.22rem}
.dir-meta .city{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--green-deep)}
.dir-item p{font-size:.86rem;color:var(--ink-soft);margin-top:4px}
.dir-text{}

/* ---------- data table ---------- */
.table-wrap{overflow-x:auto;border:1px solid var(--rule)}
table{width:100%;border-collapse:collapse;min-width:640px}
th,td{padding:13px 16px;text-align:left;font-size:.86rem;border-bottom:1px solid var(--hair)}
thead th{border-bottom:2px solid var(--rule);font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--green-deep)}
tbody th{font-family:'Fraunces',serif;font-weight:600}
td{color:var(--ink-soft)}
tbody tr:last-child th,tbody tr:last-child td{border-bottom:0}

/* ---------- Q&A ---------- */
.qa{display:grid}
.qa details{border-top:1px solid var(--hair);padding:4px 0}
.qa details:first-child{border-top:0}
.qa summary{list-style:none;cursor:pointer;font-family:'Fraunces',serif;font-size:1.1rem;font-weight:600;
  padding:14px 0;display:flex;justify-content:space-between;gap:16px}
.qa summary::-webkit-details-marker{display:none}
.qa .ic{color:var(--green);font-size:1.3rem;transition:transform .2s}
.qa details[open] .ic{transform:rotate(45deg)}
.qa p{padding:0 0 16px;color:var(--ink-soft);font-size:.92rem;max-width:70ch}

/* ---------- coupon (subscribe) ---------- */
.coupon{border:3px double var(--ink);padding:34px;display:grid;grid-template-columns:1fr 1px 1fr;gap:34px;
  background:repeating-linear-gradient(45deg,transparent,transparent 14px,rgba(11,108,65,.03) 14px,rgba(11,108,65,.03) 28px)}
.coupon-rule{background:var(--hair)}
.coupon .ch{font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--green-deep)}
.coupon h2{font-size:clamp(1.5rem,3vw,2.1rem);margin:8px 0 10px}
.coupon>div>p{color:var(--ink-soft);font-size:.92rem}
.req-points{list-style:none;margin-top:18px;display:grid;gap:8px}
.req-points li{display:flex;gap:9px;align-items:center;font-size:.86rem;color:var(--ink-soft)}
.form-card h3{font-family:'Fraunces',serif;font-size:1.3rem}
.fc-sub{font-size:.8rem;color:var(--ink-soft);margin:5px 0 16px}
.form-group{margin-bottom:12px}
.form-group label{display:block;font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:5px}
.form-group input{width:100%;padding:12px 14px;border:1.5px solid var(--ink);background:#fff;font:inherit;font-size:.92rem;border-radius:0;-webkit-appearance:none;appearance:none}
.form-group input:focus{outline:0;border-color:var(--green);box-shadow:0 0 0 3px rgba(11,108,65,.18)}
.form-consent{display:flex;gap:9px;align-items:flex-start;font-size:.76rem;color:var(--ink-soft);margin:6px 0 16px}
.form-consent input{margin-top:3px;flex:none}
.form-consent a{color:var(--green-deep);text-decoration:underline}
.success-msg{display:none;margin-top:14px;padding:12px 14px;border:1.5px solid var(--green);
  color:var(--green-deep);font-size:.85rem;font-weight:600}
.success-msg.show{display:block}

/* ---------- colophon (trust + disclaimer) ---------- */
.colophon{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--rule);margin-bottom:24px}
.colophon .cell{padding:20px;border-right:1px solid var(--hair)}
.colophon .cell:last-child{border-right:0}
.colophon h3{font-size:1rem;margin:8px 0 5px}
.colophon p{font-size:.82rem;color:var(--ink-soft)}
.t-ic{width:28px;height:28px}
.disclaimer{font-size:.8rem;color:var(--ink-soft);border-top:2px solid var(--rule);padding-top:16px}
.disclaimer strong{color:var(--ink)}

/* ---------- footer ---------- */
.site-footer{background:var(--ink);color:#cdd6cd;padding:50px 0 26px;margin-top:0}
.site-footer .brand{color:#fff}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:30px;padding-bottom:30px;border-bottom:1px solid rgba(255,255,255,.14)}
.footer-about{margin:12px 0 0;font-size:.85rem;color:#9aa89a;max-width:270px}
.footer-col h5{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:#fff;margin-bottom:12px}
.footer-col ul{list-style:none;display:grid;gap:8px}
.footer-col a,.footer-col li{font-size:.85rem;color:#a7b4a7}
.footer-col a:hover{color:#fff}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-top:22px;font-size:.76rem;color:#869486}
.footer-bottom a{color:#cdd6cd}

/* ---------- legal pages ---------- */
.legal{padding:54px 0}
.legal-wrap{max-width:760px;margin:0 auto}
.legal h1{font-size:clamp(1.9rem,4vw,2.7rem);margin-bottom:6px}
.legal .updated{color:var(--ink-soft);font-size:.84rem;margin-bottom:26px;border-bottom:1px solid var(--hair);padding-bottom:14px}
.legal h2{font-size:1.25rem;margin:28px 0 9px}
.legal p,.legal li{color:var(--ink-soft)}
.legal ul{padding-left:20px;display:grid;gap:7px;margin:9px 0}
.legal a{color:var(--green-deep);text-decoration:underline}
.tag{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--green-deep)}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .lead-grid{grid-template-columns:1fr;gap:30px}
  .lead-cols{column-count:1}
  .cols3{grid-template-columns:1fr;gap:24px}
  .colart{border-left:0;padding:0;border-top:1px solid var(--hair);padding-top:20px}
  .colart:first-child{border-top:0;padding-top:0}
  .ledger{grid-template-columns:1fr 1fr}
  .ledger .step{border-bottom:1px solid var(--hair)}
  .coupon{grid-template-columns:1fr;gap:24px}
  .coupon-rule{display:none}
  .colophon{grid-template-columns:1fr 1fr}
  .sec-head{flex-direction:column;gap:6px}
  .sec-head h2{white-space:normal}
  .sec-head .lede{margin-left:0;text-align:left}
  .footer-top{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .nav-toggle{display:flex}
  #navLinks{position:fixed;inset:60px 0 auto 0;background:var(--paper);flex-direction:column;
    align-items:flex-start;gap:0;padding:8px 26px 18px;border-bottom:2px solid var(--rule);
    transform:translateY(-130%);transition:transform .28s}
  #navLinks.open{transform:translateY(0)}
  #navLinks li{width:100%}
  #navLinks a{display:block;padding:12px 0;width:100%;border-bottom:0}
  .nav-links:not(#navLinks){gap:12px 16px}
  .diary-item{grid-template-columns:84px 1fr}
  .diary-tag{grid-column:2;justify-self:start;margin-top:4px}
  .ledger{grid-template-columns:1fr}
  .colophon{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .lead-stats{flex-wrap:wrap}
  .lead-stats div{min-width:33%}
  .masthead .dateline{flex-wrap:wrap;justify-content:center;gap:4px 14px}
}
