/*
Theme Name: PickleMap
Theme URI: https://picklemap.ph
Author: PickleMap.ph
Author URI: https://picklemap.ph
Description: Modern, sporty WordPress theme for the PickleMap.ph pickleball court directory. Works with the PickleMap Directory plugin to display courts and Free/Pro listings.
Version: 1.5.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: picklemap
*/

:root{
  --ink:#0f172a;--slate:#475569;--line:#e2e8f0;--bg:#f8fafc;
  --lime:#c4ff42;--lime-d:#a8e017;--teal:#0d9488;--teal-d:#0b7d73;
  --navy:#0b1f3a;--orange:#ff6a3d;--white:#fff;
  --shadow:0 10px 30px rgba(15,23,42,.10);--radius:16px;
}
*{box-sizing:border-box}
body{margin:0;font-family:"Segoe UI",system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--white);line-height:1.55}
a{text-decoration:none;color:inherit}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.btn{display:inline-flex;align-items:center;gap:8px;border:none;cursor:pointer;font-weight:700;border-radius:999px;padding:13px 26px;font-size:15px;transition:transform .15s ease,box-shadow .15s ease}
.btn:hover{transform:translateY(-2px)}
.btn-lime{background:var(--lime);color:var(--navy)}
.btn-teal{background:var(--teal);color:#fff}
.btn-orange{background:var(--orange);color:#fff}
.btn-ghost{background:transparent;border:2px solid rgba(255,255,255,.5);color:#fff}
.pill{display:inline-block;background:rgba(196,255,66,.18);color:var(--teal-d);font-weight:700;font-size:13px;letter-spacing:.4px;text-transform:uppercase;padding:6px 14px;border-radius:999px}
/* Higher-contrast pill on dark hero / dark sections */
.hero .pill,.how .pill,.loc-hero .pill{background:rgba(196,255,66,.16);color:#c4ff42;border:1px solid rgba(196,255,66,.45)}

/* TOP BAR */
.topbar{background:var(--navy);color:#cbd5e1;font-size:13px}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:38px}
.topbar a:hover{color:var(--lime)}
.topbar .soc span{margin-left:14px;cursor:pointer}

/* HEADER / NAV */
header.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:32px;height:74px}
.nav .logo{flex:0 0 auto}
nav.menu{margin:0 auto}
.logo{display:flex;align-items:center;gap:9px;font-weight:800;font-size:23px;color:var(--navy);letter-spacing:-.5px}
.logo .mark{width:30px;height:auto;flex:0 0 auto}
.logo b{color:var(--teal)}
.logo i{font-style:normal;font-size:14px;font-weight:700;color:#94a3b8;margin-left:1px}
nav.menu ul{display:flex;gap:30px;font-weight:600;font-size:15px;color:var(--slate);list-style:none;margin:0;padding:0}
nav.menu a{position:relative;padding:6px 0}
nav.menu a:hover{color:var(--teal)}
nav.menu .current-menu-item>a{color:var(--navy)}
nav.menu .current-menu-item>a::after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:3px;background:var(--lime);border-radius:3px}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-cta .login{font-weight:700;color:var(--navy)}
/* Mobile hamburger + menu */
.pmap-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.pmap-burger span{display:block;width:26px;height:3px;background:var(--navy);border-radius:3px;transition:transform .2s ease,opacity .2s ease}
.pmap-burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.pmap-burger.open span:nth-child(2){opacity:0}
.pmap-burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.pmap-mobile-menu{display:none}
.pmap-mobile-menu.open{display:block;border-top:1px solid var(--line);background:#fff;padding:8px 24px 22px}
.pmap-mobile-menu .pmm-list{list-style:none;margin:0;padding:0}
.pmap-mobile-menu .pmm-list li a{display:block;padding:13px 2px;font-weight:600;font-size:16px;color:var(--navy);border-bottom:1px solid var(--line)}
.pmap-mobile-menu .pmm-list li a:hover{color:var(--teal)}
.pmap-mobile-menu .pmm-cta{display:flex;flex-direction:column;gap:12px;margin-top:16px}
.pmap-mobile-menu .pmm-login{font-weight:700;color:var(--navy);text-align:center;padding:6px}
.pmap-mobile-menu .btn{justify-content:center}
@media(min-width:921px){.pmap-mobile-menu{display:none !important}}

/* HERO */
.hero{position:relative;color:#fff;overflow:hidden;background:linear-gradient(120deg,#0b2a4a 0%,#0d9488 100%)}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 85% 10%,rgba(196,255,66,.22),transparent 60%),radial-gradient(500px 260px at 10% 90%,rgba(255,106,61,.18),transparent 60%)}
.court-lines{position:absolute;right:-60px;top:50%;transform:translateY(-50%) rotate(8deg);width:520px;height:340px;border:3px solid rgba(255,255,255,.18);border-radius:8px;opacity:.5}
.court-lines::before{content:"";position:absolute;left:50%;top:0;bottom:0;width:3px;background:rgba(255,255,255,.18)}
.court-lines::after{content:"";position:absolute;left:14%;right:14%;top:50%;height:3px;background:rgba(255,255,255,.18)}
.hero .wrap{position:relative;padding:84px 24px 110px}
.hero h1{font-size:54px;line-height:1.08;font-weight:800;max-width:760px;letter-spacing:-1px;margin:14px 0 0}
.hero h1 span{color:var(--lime)}
.hero p.sub{margin-top:18px;font-size:19px;max-width:600px;color:#e2f3f0}
.stats{display:flex;gap:34px;margin-top:28px;flex-wrap:wrap}
.stats div b{font-size:28px;font-weight:800;color:var(--lime)}
.stats div span{display:block;font-size:13px;color:#cbeae6;text-transform:uppercase;letter-spacing:.5px}

/* SEARCH BAR */
.searchbar{position:relative;margin-top:38px;background:#fff;border-radius:18px;box-shadow:var(--shadow);padding:14px;display:grid;grid-template-columns:1.4fr 1fr 1fr auto;gap:10px;max-width:980px}
.field{display:flex;flex-direction:column;padding:6px 14px;border-right:1px solid var(--line)}
.field:last-of-type{border-right:none}
.field label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--slate)}
.field input,.field select{border:none;outline:none;font-size:15px;color:var(--ink);background:transparent;padding:4px 0;font-family:inherit}
.searchbar .btn{align-self:center;justify-content:center}
.tags{margin-top:16px;display:flex;gap:10px;flex-wrap:wrap;font-size:14px;align-items:center}
.tags span{color:#d7efeb}
.tags a{background:rgba(255,255,255,.12);padding:6px 14px;border-radius:999px;font-weight:600}
.tags a:hover{background:var(--lime);color:var(--navy)}

/* SECTION SHELL */
section.block{padding:80px 0}
.head{text-align:center;max-width:660px;margin:0 auto 46px}
.head h2{font-size:38px;font-weight:800;color:var(--navy);letter-spacing:-.5px;margin:14px 0 0}
.head p{margin-top:12px;color:var(--slate);font-size:17px}

/* FEATURED GRID */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:0 4px 14px rgba(15,23,42,.05);transition:transform .18s ease,box-shadow .18s ease}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card .photo{height:180px;position:relative;background-size:cover;background-position:center;background-color:#0d9488}
/* Deterministic sporty gradient placeholders (used when a court has no photo) */
.card .photo-name{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;padding:18px 22px;color:#fff;font-weight:800;font-size:21px;line-height:1.2;letter-spacing:-.3px;text-shadow:0 2px 10px rgba(0,0,0,.25)}
.card .photo-name .pn-ball{font-size:30px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.25))}
.pmap-grad-0{background:linear-gradient(135deg,#0d9488,#22d3ee)}
.pmap-grad-1{background:linear-gradient(135deg,#f97316,#facc15)}
.pmap-grad-2{background:linear-gradient(135deg,#6366f1,#22d3ee)}
.pmap-grad-3{background:linear-gradient(135deg,#0ea5e9,#14b8a6)}
.pmap-grad-4{background:linear-gradient(135deg,#ec4899,#f97316)}
.pmap-grad-5{background:linear-gradient(135deg,#16a34a,#a3e635)}
.badge{position:absolute;top:14px;left:14px;background:var(--lime);color:var(--navy);font-weight:800;font-size:12px;padding:5px 12px;border-radius:999px}
.badge.indoor{background:#fff;color:var(--teal-d)}
.card .verified-float{position:absolute;bottom:14px;left:14px}
.fav{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.9);display:grid;place-items:center;font-size:16px}
.card .body{padding:18px 20px 22px}
.card h3{font-size:19px;color:var(--navy);font-weight:800;margin:0}
.card h3 a:hover{color:var(--teal)}
.loc{display:flex;align-items:center;gap:6px;color:var(--slate);font-size:14px;margin-top:4px}
.meta{display:flex;gap:14px;margin-top:14px;font-size:13px;color:var(--slate);flex-wrap:wrap}
.meta b{color:var(--ink)}
.rate{display:inline-flex;align-items:center;gap:5px;font-weight:800;color:var(--ink)}
.rate .star{color:#f59e0b}
.card-stars{display:inline-flex;letter-spacing:1px}
.card-stars span{color:#d7dce3;font-size:14px}
.card-stars span.on{color:#f59e0b}
.rate b{font-weight:800;color:var(--ink)}
.rate .rev-n{color:var(--slate);font-weight:600}
.rate-none{display:inline-flex;align-items:center;gap:6px;color:#94a3b8;font-size:13px;font-weight:600}
.card .foot{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:15px;border-top:1px solid var(--line)}
.price{font-weight:800;color:var(--teal-d)}
.price small{font-weight:600;color:var(--slate)}
.view{font-weight:700;color:var(--navy);font-size:14px}
.view:hover{color:var(--teal)}
.center-cta{text-align:center;margin-top:44px}
.pmap-verified,.verified-tag{display:inline-flex;align-items:center;gap:4px;background:#e0f2fe;color:#0369a1;font-weight:800;font-size:12px;padding:3px 9px;border-radius:999px}
.book-btn{font-weight:700;font-size:13px;color:#fff;background:var(--teal);padding:7px 14px;border-radius:999px}

/* MAP */
.map{background:var(--bg)}
.map-grid{display:grid;grid-template-columns:340px 1fr;gap:0;border-radius:20px;overflow:hidden;box-shadow:var(--shadow);background:#fff}
.map-list{padding:24px;max-height:520px;overflow:auto}
.map-list h3{font-size:16px;text-transform:uppercase;letter-spacing:.5px;color:var(--slate);margin:0 0 16px}
.mrow{display:flex;gap:12px;padding:14px;border-radius:12px;cursor:pointer;align-items:flex-start}
.mrow:hover,.mrow.on{background:var(--bg)}
.mrow .pin{width:30px;height:30px;border-radius:50%;background:var(--teal);color:#fff;display:grid;place-items:center;font-size:13px;font-weight:800;flex:0 0 auto}
.mrow b{font-size:15px;color:var(--navy)}
.mrow span{font-size:13px;color:var(--slate)}
.map-canvas{position:relative;background:linear-gradient(rgba(13,148,136,.06),rgba(13,148,136,.06)),repeating-linear-gradient(0deg,#eef2f6 0 24px,#e6ecf2 24px 25px),repeating-linear-gradient(90deg,#eef2f6 0 24px,#e6ecf2 24px 25px);min-height:520px}
.map-canvas .pin-abs{position:absolute;transform:translate(-50%,-100%);text-align:center}
.map-canvas .pin-abs .dot{width:26px;height:26px;border-radius:50% 50% 50% 0;background:var(--orange);transform:rotate(-45deg);box-shadow:0 4px 10px rgba(0,0,0,.25);border:3px solid #fff;margin:0 auto}
.map-canvas .pin-abs.teal .dot{background:var(--teal)}
.map-canvas .pin-abs .lbl{margin-top:8px;background:#fff;font-size:12px;font-weight:700;color:var(--navy);padding:3px 9px;border-radius:8px;box-shadow:0 2px 6px rgba(0,0,0,.12);white-space:nowrap}
.map-tag{position:absolute;top:18px;left:18px;background:#fff;padding:8px 16px;border-radius:999px;font-weight:700;font-size:13px;color:var(--navy);box-shadow:0 2px 8px rgba(0,0,0,.12)}

/* HOW IT WORKS */
.how{background:var(--navy);color:#fff}
.how .head h2{color:#fff}
.how .head p{color:#bcd}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.step{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.10);border-radius:var(--radius);padding:30px 26px}
.step .num{width:46px;height:46px;border-radius:12px;background:var(--lime);color:var(--navy);font-weight:800;font-size:20px;display:grid;place-items:center}
.step h3{margin:16px 0 8px;font-size:20px}
.step p{color:#bcd;font-size:15px;margin:0}

/* SUBMIT / PRICING */
.submit-sec{background:var(--bg)}
.tiers,.pmap-tiers{display:grid;grid-template-columns:1fr 1fr;gap:26px;max-width:840px;margin:0 auto}
.tier{background:#fff;border:1px solid var(--line);border-radius:20px;padding:30px 28px;position:relative;display:flex;flex-direction:column}
.tier.pro{border:2px solid var(--teal);box-shadow:var(--shadow)}
.tier .ribbon{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--lime);color:var(--navy);font-weight:800;font-size:12px;letter-spacing:.5px;text-transform:uppercase;padding:6px 16px;border-radius:999px}
.tier .tname{font-size:15px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--slate)}
.tier.pro .tname{color:var(--teal-d)}
.tier .tprice{font-size:40px;font-weight:800;color:var(--navy);margin:8px 0 2px}
.tier .tprice small{font-size:16px;font-weight:600;color:var(--slate)}
.tier .tsub{color:var(--slate);font-size:14px;margin-bottom:20px}
.tier ul{list-style:none;flex:1;margin:0;padding:0}
.tier li{display:flex;gap:10px;align-items:flex-start;padding:8px 0;font-size:15px;color:var(--ink)}
.tier li .ic{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-weight:800;font-size:12px;flex:0 0 auto;margin-top:2px}
.tier li .yes{background:#dcfce7;color:#16a34a}
.tier li .no{background:#f1f5f9;color:#94a3b8}
.tier li.muted{color:#94a3b8}
.tier .btn{width:100%;justify-content:center;margin-top:22px}

/* FOOTER */
footer.site{background:#081627;color:#9fb3c8;padding:60px 0 26px;font-size:14px}
.fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px}
footer.site h4{color:#fff;font-size:15px;margin-bottom:14px;letter-spacing:.4px}
footer.site a{display:block;padding:5px 0}
footer.site a:hover{color:var(--lime)}
footer.site ul{list-style:none;margin:0;padding:0}
footer.site li{margin:0;list-style:none}
.footer-logo{display:flex;align-items:center;gap:9px;color:#fff;font-weight:800;font-size:21px;margin-bottom:12px}
.footer-logo .mark{width:28px;height:auto}
.footer-logo b{color:var(--lime)}
.footer-logo i{font-style:normal;font-size:13px;font-weight:700;color:#6b8299}
.footer-brand{border-top:1px solid rgba(255,255,255,.08);margin-top:40px;padding-top:26px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.ms-brand{display:inline-flex;align-items:center;gap:9px;text-decoration:none}
.ms-mark{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,#6366f1,#0d9488);color:#fff;font-weight:800;font-size:17px;display:grid;place-items:center;box-shadow:0 2px 8px rgba(0,0,0,.25)}
.ms-text{color:#fff;font-weight:800;font-size:17px;letter-spacing:-.3px}
.ms-text b{color:#a3e635;font-weight:800}
.ms-tag{color:#6b8299;font-size:13px}
.copy{margin-top:18px;padding-top:18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:#6b8299}
footer.site .copy a{display:inline;padding:0}

/* FEATURED BADGES */
.card .card-featured{position:absolute;top:12px;left:12px;z-index:2;background:var(--lime);color:#0b2a4a;font-weight:800;font-size:12px;letter-spacing:.3px;padding:5px 11px;border-radius:999px;box-shadow:0 3px 10px rgba(0,0,0,.18)}
.card{position:relative}
.cbadge.featured{background:var(--lime);color:#0b2a4a;font-weight:800}

/* NEAR ME */
.nearme-cta{margin-top:22px}
#pmap-near-btn{font-size:17px;cursor:pointer;border:none}
#pmap-near-btn:disabled{opacity:.6;cursor:wait}
.nearme-status{margin-top:12px;color:#dbe6f2;font-size:14px;min-height:18px}
.nearme-card .body{padding:18px 20px}
.nearme-dist{display:inline-block;background:var(--lime);color:#0b2a4a;font-weight:800;font-size:12px;padding:4px 10px;border-radius:999px;margin-bottom:8px}
.nearme-card h3{margin:0 0 4px}
.nearme-card .loc{color:var(--slate);font-size:14px;margin-bottom:10px}

/* REGION CHIPS */
.region-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin:-8px 0 28px}
.region-chip{display:inline-flex;align-items:center;gap:6px;padding:10px 22px;border-radius:999px;background:#0b2a4a;color:#fff;font-weight:700;font-size:15px;text-decoration:none;border:1px solid rgba(255,255,255,.08);transition:transform .15s,background .15s}
.region-chip:hover{background:#0d9488;transform:translateY(-2px)}

/* BLOG / PICKLENEWS */
.post-card .photo{height:175px;display:block;border-radius:0}
.post-card .photo .photo-name{font-size:18px}
.post-date{color:#94a3b8;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;margin-bottom:6px}
.post-card h3{margin:0 0 8px}
.post-card .body p{color:var(--slate);font-size:15px;line-height:1.6;margin:0 0 12px}
.post-content{color:#334155;font-size:17px;line-height:1.75}
.post-content h2{color:#0b1f3a;font-size:26px;margin:30px 0 12px;font-weight:800}
.post-content h3{color:#0b1f3a;font-size:21px;margin:24px 0 10px;font-weight:800}
.post-content p{margin:0 0 17px}
.post-content ul,.post-content ol{margin:0 0 17px 22px}
.post-content li{margin-bottom:7px}
.post-content a{color:var(--teal-d);font-weight:600}
.post-content img{border-radius:12px;margin:8px 0}
.post-content blockquote{border-left:4px solid var(--lime);background:var(--bg);padding:14px 18px;color:#475569;font-style:italic;margin:0 0 18px;border-radius:0 8px 8px 0}
.post-content strong{color:#0b1f3a}

/* LOCATION (taxonomy) PAGES */
.loc-hero{background:linear-gradient(120deg,#0b2a4a 0%,#0d9488 100%);color:#fff;padding:48px 0 40px}
.loc-hero .crumbs{font-size:13px;font-weight:600;color:rgba(255,255,255,.85);margin-bottom:16px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.loc-hero .crumbs a{color:rgba(255,255,255,.85)}
.loc-hero .crumbs a:hover{color:var(--lime)}
.loc-hero .crumbs em{font-style:normal;color:#fff}
.loc-hero h1{font-size:40px;font-weight:800;letter-spacing:-.5px;margin:0}
.loc-hero p{margin:10px 0 0;font-size:17px;color:#e2f3f0}
.loc-other{margin-top:40px;border-top:1px solid var(--line);padding-top:26px}
.loc-other h3{font-size:16px;text-transform:uppercase;letter-spacing:.5px;color:var(--slate);margin:0 0 14px}
.loc-chips{display:flex;flex-wrap:wrap;gap:10px}
.loc-chips a{background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:8px 16px;font-weight:600;color:var(--navy);font-size:14px}
.loc-chips a:hover{border-color:var(--teal);color:var(--teal-d)}
.loc-chips a span{color:var(--slate);font-weight:700;margin-left:2px}
.loc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.loc-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px 20px;text-align:center;transition:transform .15s ease,box-shadow .15s ease}
.loc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.loc-card .loc-pin{font-size:24px}
.loc-card strong{display:block;color:var(--navy);font-size:17px;margin:6px 0 2px}
.loc-card .loc-num{color:var(--slate);font-size:13px}
@media(max-width:920px){.loc-grid{grid-template-columns:repeat(3,1fr)}.loc-hero h1{font-size:32px}}
@media(max-width:560px){.loc-grid{grid-template-columns:repeat(2,1fr)}}

/* COURTS ARCHIVE — FILTER BAR */
.court-filter{display:grid;grid-template-columns:1.6fr 1fr 1fr auto;gap:10px;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 4px 14px rgba(15,23,42,.05);padding:14px;margin-bottom:16px}
.court-filter .cf-field{display:flex;flex-direction:column;padding:6px 14px;border-right:1px solid var(--line)}
.court-filter .cf-field:last-of-type{border-right:none}
.court-filter label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--slate)}
.court-filter input,.court-filter select{border:none;outline:none;font-size:15px;color:var(--ink);background:transparent;padding:5px 0;font-family:inherit}
.court-filter .btn{align-self:center;justify-content:center}
.cf-count{color:var(--slate);font-size:14px;margin:0 0 26px;padding-left:4px}
@media(max-width:760px){
  .court-filter{grid-template-columns:1fr 1fr}
  .court-filter .cf-grow{grid-column:1 / -1}
  .court-filter .cf-field{border-right:none;border-bottom:1px solid var(--line)}
}

/* SINGLE COURT — HERO */
.chero{position:relative;color:#fff;background:linear-gradient(135deg,#0b2a4a,#0d9488);background-size:cover;background-position:center}
.chero.has-photo{background-color:#0b1f3a}
.chero-inner{padding:54px 24px 60px;position:relative}
.crumbs{font-size:13px;font-weight:600;color:rgba(255,255,255,.85);margin-bottom:22px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.crumbs a{color:rgba(255,255,255,.85)}
.crumbs a:hover{color:var(--lime)}
.crumbs em{font-style:normal;color:#fff}
.chero-badges{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.cbadge{background:rgba(255,255,255,.18);color:#fff;font-weight:800;font-size:12px;letter-spacing:.4px;padding:5px 12px;border-radius:999px;backdrop-filter:blur(4px)}
.cbadge.verified{background:#e0f2fe;color:#0369a1}
.cbadge.pro{background:var(--lime);color:var(--navy)}
.chero h1{font-size:44px;font-weight:800;letter-spacing:-1px;margin:0;line-height:1.05;max-width:820px}
.chero-loc{margin-top:10px;font-size:16px;color:#e2f3f0}

/* SINGLE COURT — BODY */
.court-wrap{padding:46px 0 80px;background:var(--white)}
.court-layout{display:grid;grid-template-columns:1fr 340px;gap:40px;align-items:start}
.court-main h2.csec-title{font-size:22px;color:var(--navy);font-weight:800;margin:30px 0 14px}
.court-main h2.csec-title:first-child{margin-top:0}
.cchips{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:8px}
.cchip{background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:9px 16px;font-size:14px;font-weight:600;color:var(--ink)}
.court-about{color:var(--slate);font-size:16px;line-height:1.7}
.court-about p{margin:0 0 14px}
.court-map-box{height:320px;border-radius:16px;overflow:hidden;border:1px solid var(--line);box-shadow:0 4px 14px rgba(15,23,42,.05)}
.court-addr{margin-top:12px;color:var(--slate);font-size:15px}

/* SINGLE COURT — SIDEBAR */
.court-side{position:sticky;top:96px}
.cside-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px;box-shadow:var(--shadow)}
.cside-rate{font-size:30px;font-weight:800;color:var(--teal-d);margin-bottom:16px}
.cside-rate small{font-size:15px;font-weight:600;color:var(--slate)}
.cside-rate-muted{font-size:18px;color:var(--slate)}
.cbtn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;border:none;cursor:pointer;font-weight:700;border-radius:999px;padding:14px 22px;font-size:15px;margin-bottom:12px;transition:transform .15s ease}
.cbtn:hover{transform:translateY(-2px)}
.cbtn-teal{background:var(--teal);color:#fff}
.cbtn-lime{background:var(--lime);color:var(--navy)}
.cside-facts{list-style:none;margin:18px 0 0;padding:18px 0 0;border-top:1px solid var(--line)}
.cside-facts li{display:flex;gap:10px;align-items:flex-start;padding:7px 0;font-size:14px;color:var(--ink)}
.cside-facts li span{flex:0 0 auto;width:18px;text-align:center}
.cside-verified{margin-top:16px;background:#e0f2fe;color:#0369a1;font-weight:700;font-size:13px;text-align:center;padding:9px;border-radius:10px}
.cside-back{display:inline-block;margin-top:18px;font-weight:700;color:var(--navy);font-size:14px}
.cside-back:hover{color:var(--teal)}
@media(max-width:860px){
  .court-layout{grid-template-columns:1fr}
  .court-side{position:static}
  .chero h1{font-size:34px}
}

@media(max-width:920px){
  .grid,.steps{grid-template-columns:repeat(2,1fr)}
  .searchbar{grid-template-columns:1fr 1fr}
  .map-grid,.court-detail-grid{grid-template-columns:1fr}
  .tiers,.pmap-tiers{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr 1fr}
  .hero h1{font-size:40px}
  nav.menu,.nav-cta .login,.nav-add{display:none}
  .pmap-burger{display:flex}
}
@media(max-width:768px){
  .topbar{font-size:12px}
  .topbar .soc{display:none}
  .topbar .wrap{justify-content:center}
  .topbar .wrap > div:first-child{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
  .nav{height:64px}
}
@media(max-width:560px){
  .grid,.steps,.searchbar,.fgrid{grid-template-columns:1fr}
  .hero h1{font-size:32px}
  .hero .wrap{padding:54px 24px 70px}
}
