/* Austin Pickleball Courts — shared stylesheet (index + city pages) */
:root{
  --green:#1ba35a; --green-dark:#0f7a40; --ink:#16241d; --muted:#5d6b62;
  --bg:#f4f6f3; --card:#ffffff; --line:#e3e8e3; --gold:#e0962f;
  --indoor:#2f6fb0; --outdoor:#1ba35a; --free:#7a4fc4; --paid:#54606a; --soon:#b06a16;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:var(--green-dark)}
.wrap{max-width:1100px;margin:0 auto;padding:0 20px}

header{background:var(--card);border-bottom:1px solid var(--line)}
.hrow{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.logo{display:flex;align-items:center;gap:9px;font-weight:800;font-size:20px;color:var(--ink);text-decoration:none}
.logo .dot{width:26px;height:26px;border-radius:50%;background:var(--green);
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px}
nav a{margin-left:18px;text-decoration:none;color:var(--muted);font-size:14px;font-weight:600}
nav a:hover{color:var(--green-dark)}
.crumb{font-size:13px;color:var(--muted);padding:12px 0}
.crumb a{text-decoration:none}

.hero{padding:24px 0 6px}
h1{font-size:33px;line-height:1.18;letter-spacing:-.5px}
.hero p{margin-top:10px;color:var(--muted);max-width:760px;font-size:15.5px}
.verified-line{margin-top:12px;font-size:13px;color:var(--green-dark);font-weight:600}

.stats{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0 4px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:11px;padding:10px 16px;min-width:90px}
.stat .n{font-size:21px;font-weight:800}
.stat .l{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}

.controls{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:22px 0 14px}
.search{flex:1;min-width:220px;display:flex;align-items:center;gap:8px;background:var(--card);
  border:1px solid var(--line);border-radius:10px;padding:10px 13px}
.search input{border:0;outline:0;font-size:14.5px;width:100%;background:transparent;color:var(--ink)}
.chip{border:1px solid var(--line);background:var(--card);color:var(--muted);font-weight:600;
  font-size:13px;padding:8px 14px;border-radius:999px;cursor:pointer;white-space:nowrap}
.chip.on{background:var(--green-dark);border-color:var(--green-dark);color:#fff}

.sec-label{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;
  color:var(--muted);margin:26px 0 9px}
#map{height:380px;border-radius:14px;border:1px solid var(--line);z-index:0;background:#e9efe9}
.maphint{font-size:12px;color:var(--muted);margin-top:6px}

.grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:8px}
@media(max-width:720px){.grid{grid-template-columns:1fr}h1{font-size:26px}}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:0;overflow:hidden;
  cursor:pointer;transition:box-shadow .15s,transform .15s;display:block;text-decoration:none;color:var(--ink)}
.cardbody{padding:15px 18px 18px}
.card:hover{box-shadow:0 8px 22px rgba(20,48,42,.10);transform:translateY(-2px)}
.card.home{border-color:var(--green);box-shadow:0 0 0 1px var(--green) inset}
.badges{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:9px}
.b{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;
  padding:3px 8px;border-radius:6px;color:#fff}
.b.indoor{background:var(--indoor)} .b.outdoor{background:var(--outdoor)} .b.both{background:var(--indoor)}
.b.free{background:var(--free)} .b.paid{background:var(--paid)} .b.membership{background:var(--paid)}
.b.soon{background:var(--soon)} .b.home{background:var(--gold)}
.card h3{font-size:17.5px;margin-bottom:2px}
.addr{font-size:13px;color:var(--muted);margin-bottom:11px}
.facts{display:grid;grid-template-columns:1fr 1fr;gap:7px 14px;font-size:13px}
.facts .k{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.4px}
.facts .v{font-weight:600}
.facts .wide{grid-column:1/3}
.verified{margin-top:12px;font-size:12px;color:var(--green-dark);font-weight:600}
.verified.warn{color:var(--soon)}
.more{margin-top:9px;font-size:13px;font-weight:700;color:var(--green-dark)}

/* index city cards */
.citygrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:8px}
@media(max-width:760px){.citygrid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.citygrid{grid-template-columns:1fr}}
.citycard{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px;
  text-decoration:none;color:var(--ink);transition:box-shadow .15s,transform .15s}
.citycard:hover{box-shadow:0 8px 22px rgba(20,48,42,.10);transform:translateY(-2px)}
.citycard h3{font-size:18px}
.citycard .ccount{font-size:13px;color:var(--muted);margin-top:3px}
.citycard .cbar{margin-top:10px;font-size:12px;color:var(--muted)}

.pending{background:#fff8ee;border:1px dashed #e0b87a;border-radius:14px;padding:16px 18px;margin-top:14px}
.pending h4{font-size:15px}
.pending p{font-size:13px;color:#7a5a28;margin-top:5px}

.suggest{background:linear-gradient(110deg,#0f7a40,#1ba35a);color:#fff;border-radius:16px;
  padding:22px 24px;margin:26px 0;display:flex;justify-content:space-between;
  align-items:center;flex-wrap:wrap;gap:14px}
.suggest h3{font-size:19px}
.suggest p{font-size:14px;opacity:.92;margin-top:3px}
.btn{background:#fff;color:var(--green-dark);border:0;font-weight:800;font-size:14px;
  padding:11px 20px;border-radius:9px;cursor:pointer}
.btn.gold{background:var(--gold);color:#fff}

footer{border-top:1px solid var(--line);margin-top:30px;padding:22px 0;font-size:13px;color:var(--muted)}
footer b{color:var(--ink)}

.ov{position:fixed;inset:0;background:rgba(16,36,29,.55);display:none;
  align-items:flex-start;justify-content:center;padding:34px 16px;z-index:1000;overflow:auto}
.ov.on{display:flex}
.modal{background:#fff;border-radius:16px;max-width:560px;width:100%;padding:24px}
.modal h2{font-size:22px}
.modal .close{float:right;font-size:24px;cursor:pointer;color:var(--muted);line-height:1}
.mfacts{margin:14px 0;border-top:1px solid var(--line)}
.mrow{display:flex;padding:9px 0;border-bottom:1px solid var(--line);font-size:14px;gap:12px}
.mrow .k{width:118px;flex:none;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.4px;padding-top:2px}
.mrow .v{font-weight:600}
.mrow .v a{word-break:break-all}
.ai-note{font-size:12px;background:#eef4ff;border:1px solid #cfe0fb;color:#244c86;
  border-radius:8px;padding:8px 11px;margin-top:10px}
.ai-note.fix{background:#fef0f0;border-color:#f3c9c9;color:#9a3434}
.faq{margin-top:14px}
.faq .q{font-weight:700;font-size:14px;margin-top:11px}
.faq .a{font-size:13.5px;color:var(--muted);margin-top:2px}
.mcta{margin-top:16px;display:flex;gap:10px;flex-wrap:wrap}
.mcta a,.mcta button{text-decoration:none;font-weight:700;font-size:14px;padding:10px 16px;
  border-radius:9px;border:1px solid var(--line);background:#fff;color:var(--ink);cursor:pointer}
.mcta a.primary{background:var(--green-dark);color:#fff;border-color:var(--green-dark)}
.field{margin-top:11px}
.field label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--muted)}
.field input,.field textarea{width:100%;margin-top:4px;padding:9px 11px;
  border:1px solid var(--line);border-radius:8px;font-size:14px;font-family:inherit}
.ok{background:#e8f6ed;border:1px solid #b6e0c4;color:#0f7a40;border-radius:9px;
  padding:12px;font-size:14px;font-weight:600;margin-top:12px;display:none}
.nores{color:var(--muted);font-size:14px;padding:8px 0}

/* ---------- Google ratings + Best-rated pages ---------- */
.grating{font-size:13px;font-weight:700;color:var(--gold);margin:-2px 0 10px}
.grating span{color:var(--muted);font-weight:600}

/* city-page CTA to the review-ranked page */
.bestbar{display:block;background:#fff8ee;border:1px solid #e0b87a;color:#7a5a28;
  border-radius:12px;padding:12px 16px;margin:14px 0 0;text-decoration:none;font-size:14px}
.bestbar:hover{box-shadow:0 6px 16px rgba(20,48,42,.08)}
.bestbar b{color:var(--green-dark)}

/* index "best-rated by city" links */
.bestgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:8px}
@media(max-width:560px){.bestgrid{grid-template-columns:1fr}}
.bestcard{background:#fff8ee;border:1px solid #e7c894;color:#7a5a28;border-radius:12px;
  padding:14px 16px;text-decoration:none;font-weight:700;font-size:14px}
.bestcard:hover{box-shadow:0 6px 16px rgba(20,48,42,.08)}

/* best-page methodology + attribution */
.methods{background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:14px 16px;font-size:13.5px;color:var(--muted);margin:14px 0 4px;line-height:1.6}
.methods b{color:var(--ink)}
.methods code{background:#eef3ee;padding:1px 5px;border-radius:5px;font-size:12.5px;color:var(--ink)}
.attribution{font-size:12px;color:var(--muted);margin-top:20px;padding-top:12px;border-top:1px solid var(--line)}

/* per-court detail page */
.cols{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:18px;align-items:start}
@media(max-width:760px){.cols{grid-template-columns:1fr}}
.col-side #map{height:300px}
.courtnotes{font-size:15px;color:var(--ink);margin-top:16px;line-height:1.6}
.srcline{font-size:12.5px;color:var(--muted);margin-top:12px}
.srcline a{word-break:break-all}
.nearby{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:8px}
@media(max-width:760px){.nearby{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.nearby{grid-template-columns:1fr}}
.nearcard{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:13px 15px;
  text-decoration:none;color:var(--ink);display:block}
.nearcard:hover{box-shadow:0 6px 16px rgba(20,48,42,.08)}
.nearcard b{font-size:14.5px;display:block}
.nearcard span{font-size:12.5px;color:var(--muted);display:block;margin-top:3px}

/* ranked cards (review-ranked best page) */
.ranked-grid{margin-top:16px}
.ranked{position:relative}
.rankno{position:absolute;top:-10px;left:-10px;width:34px;height:34px;border-radius:50%;
  background:var(--green-dark);color:#fff;font-weight:800;font-size:15px;z-index:1;
  display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px rgba(20,48,42,.25)}
.rscore{font-size:12px;color:var(--muted);font-weight:600;margin-top:7px}

/* ---------- photo banners (cards + detail), padelcourtsfinder-style ---------- */
.cardphoto{height:150px;background:#e9efe9;background-size:cover;background-position:center;
  display:flex;align-items:center;justify-content:center}
.detailphoto{height:210px;border-radius:14px;margin-top:14px;background:#e9efe9;background-size:cover;
  background-position:center;display:flex;align-items:center;justify-content:center;border:1px solid var(--line)}
.phletter{font-weight:800;color:rgba(255,255,255,.45);font-size:54px;line-height:1;user-select:none}
.detailphoto .phletter{font-size:84px}
.ph-indoor{background:linear-gradient(135deg,#3a7fc4,#1b4f86)}
.ph-outdoor{background:linear-gradient(135deg,#2bb56a,#0f7a40)}
.ph-both{background:linear-gradient(135deg,#2f9fb0,#155f7a)}
.ph-venue{background:linear-gradient(135deg,#9aa7a0,#6b776f)}

/* amenity icon chips */
.amenities{display:flex;flex-wrap:wrap;gap:7px;margin:11px 0 2px}
.am{display:inline-flex;align-items:center;gap:5px;background:var(--bg);border:1px solid var(--line);
  border-radius:999px;padding:4px 10px;font-size:12.5px;font-weight:600;color:var(--ink)}
.am i{font-style:normal;font-size:12.5px}
.hero .amenities{margin:12px 0 4px}

/* metro-hub hero search */
.hero-index .herosearch{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);
  border-radius:12px;padding:14px 16px;margin-top:16px;max-width:580px;box-shadow:0 3px 14px rgba(20,48,42,.06);font-size:18px}
.herosearch input{border:0;outline:0;font-size:16px;width:100%;background:transparent;color:var(--ink)}
.heroresults{display:none;max-width:580px;margin-top:7px;background:#fff;border:1px solid var(--line);
  border-radius:12px;overflow:hidden;box-shadow:0 8px 22px rgba(20,48,42,.10)}
.heroresults.on{display:block}
a.hres{display:block;padding:11px 15px;text-decoration:none;color:var(--ink);border-bottom:1px solid var(--line)}
a.hres:last-child{border-bottom:0}
a.hres:hover{background:var(--bg)}
.hres b{display:block;font-size:14.5px}
.hres span{font-size:12.5px;color:var(--muted)}
.hres.none{padding:11px 15px;color:var(--muted);font-size:13.5px}

/* popular cities pills */
.popcities{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.popcity{display:inline-flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);
  border-radius:999px;padding:8px 14px;text-decoration:none;color:var(--ink);font-weight:700;font-size:14px}
.popcity:hover{box-shadow:0 6px 16px rgba(20,48,42,.08)}
.popcity span{background:var(--green-dark);color:#fff;border-radius:999px;font-size:12px;padding:1px 9px;font-weight:700}

/* index/state: browse-by-state cards */
.statecard{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 16px;
  text-decoration:none;color:var(--ink);display:block}
.statecard:hover{box-shadow:0 6px 16px rgba(20,48,42,.08)}
.statecard b{font-size:15px;display:block}
.statecard span{font-size:12.5px;color:var(--muted);display:block;margin-top:3px}

/* ---------- detail page: sectioned padel-style layout ---------- */
.detail-sections{margin-top:6px}
.detail-sections section{margin-top:24px}
.detail-sections h2,.faqs h2,.explore h2{font-size:19px;margin-bottom:10px;letter-spacing:-.2px}
.detail-sections .about p{font-size:15px;line-height:1.65}
.detail-sections #map{height:340px}
.detail-sections .mfacts{margin-top:4px}
address.addr{font-style:normal;font-size:14.5px;margin-top:6px;color:var(--muted)}
.quickactions{display:flex;flex-wrap:wrap;gap:9px;margin:14px 0 6px}
.qa{display:inline-flex;align-items:center;gap:6px;background:var(--card);border:1px solid var(--line);
  border-radius:10px;padding:9px 15px;text-decoration:none;color:var(--ink);font-weight:700;font-size:14px}
.qa:hover{box-shadow:0 6px 16px rgba(20,48,42,.08)}
.qa.primary{background:var(--green-dark);color:#fff;border-color:var(--green-dark)}

/* FAQ (court / city / state) — also emitted as FAQPage schema */
.faqs{margin-top:24px}
.faq-item{border-top:1px solid var(--line);padding:13px 0}
.faq-item:last-child{border-bottom:1px solid var(--line)}
.faq-item h3{font-size:15px;margin-bottom:4px}
.faq-item p{font-size:14px;color:var(--muted);line-height:1.6}

/* explore-more internal links */
.explore{margin-top:24px}
.explore-links{list-style:none;display:flex;flex-wrap:wrap;gap:10px}
.explore-links a{display:inline-block;background:var(--bg);border:1px solid var(--line);border-radius:999px;
  padding:8px 14px;text-decoration:none;color:var(--green-dark);font-weight:600;font-size:13.5px}
.explore-links a:hover{box-shadow:0 6px 16px rgba(20,48,42,.08)}
