*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#0a0a0a;--surface:#141414;--surface-hover:#1a1a1a;--border:#262626;
  --text:#f5f5f5;--muted:#a3a3a3;--accent:#84cc16;--accent-hover:#65a30d;
  --radius:12px;--radius-sm:8px;--radius-pill:100px;
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--accent-hover)}
img{max-width:100%;display:block}

/* Header */
.header{position:sticky;top:0;z-index:100;background:rgba(10,10,10,0.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between}
.logo{font-size:1.25rem;font-weight:800;letter-spacing:0.08em;color:var(--text)}
.logo span{color:var(--accent)}
.header-cta{font-size:0.8rem;font-weight:600;letter-spacing:0.05em;text-transform:uppercase;color:var(--accent);border:1px solid var(--accent);padding:6px 16px;border-radius:var(--radius-pill);transition:all 0.2s}
.header-cta:hover{background:var(--accent);color:#000}

/* Hero */
.hero{text-align:center;padding:80px 24px 32px;max-width:720px;margin:0 auto}
.hero h1{font-size:clamp(2.5rem,6vw,4rem);font-weight:900;letter-spacing:-0.02em;line-height:1.1;margin-bottom:24px}
.hero h1 em{font-style:normal;color:var(--accent)}
.hero-sub{color:var(--muted);font-size:1.1rem;margin-bottom:32px}

/* Stats bar */
.stats-bar{display:flex;justify-content:center;gap:24px;flex-wrap:wrap;padding:16px 24px 32px;max-width:900px;margin:0 auto}
.stat-item{text-align:center}
.stat-num{font-size:1.3rem;font-weight:800;color:var(--accent);display:block}
.stat-label{font-size:0.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.05em}
.stat-sep{color:#262626;font-size:1.4rem;align-self:center;user-select:none}

/* Search */
.search-wrap{max-width:560px;margin:0 auto 32px;position:relative}
.search-input{width:100%;padding:14px 20px 14px 48px;font-size:1rem;background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-pill);color:var(--text);outline:none;transition:border-color 0.2s}
.search-input:focus{border-color:var(--accent)}
.search-input::placeholder{color:#525252}
.search-icon{position:absolute;left:18px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:1.1rem;pointer-events:none}

/* Filter pills */
.filter-bar{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;padding:0 24px 32px;max-width:800px;margin:0 auto}
.filter-pill{padding:8px 18px;font-size:0.82rem;font-weight:600;letter-spacing:0.04em;text-transform:uppercase;border:1px solid var(--border);border-radius:var(--radius-pill);background:transparent;color:var(--muted);cursor:pointer;transition:all 0.2s;white-space:nowrap}
.filter-pill:hover,.filter-pill.active{background:var(--accent);color:#000;border-color:var(--accent)}

/* Controls bar */
.controls{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;max-width:1200px;margin:0 auto 16px;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.sort-select{background:var(--surface);color:var(--text);border:1px solid var(--border);padding:6px 12px;border-radius:var(--radius-sm);font-size:0.85rem;cursor:pointer}
.result-count{color:var(--muted);font-size:0.9rem}

/* Card grid */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;padding:0 24px 48px;max-width:1200px;margin:0 auto}
.studio-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;cursor:pointer;transition:all 0.2s;position:relative}
.studio-card:hover{background:var(--surface-hover);border-color:#333;transform:translateY(-2px)}
.card-rating{display:flex;align-items:center;gap:6px;margin-bottom:10px}
.stars{display:inline-flex;gap:1px}
.star{color:var(--accent);font-size:0.95rem}
.star.empty{color:#333}
.star.half{background:linear-gradient(90deg,var(--accent) 50%,#333 50%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.rating-num{font-weight:700;font-size:0.95rem}
.review-count{color:var(--muted);font-size:0.82rem}
.card-name{font-size:1.1rem;font-weight:700;margin-bottom:10px;line-height:1.3}
.format-pill{display:inline-block;background:var(--accent);color:#000;font-size:0.7rem;font-weight:700;letter-spacing:0.06em;padding:4px 12px;border-radius:var(--radius-pill);margin-bottom:10px}
.format-pill.secondary{background:transparent;color:var(--accent);border:1px solid var(--accent);margin-left:4px}
.card-location{color:var(--muted);font-size:0.88rem;margin-bottom:8px}
.card-vibes{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}
.vibe-pill{font-size:0.72rem;color:var(--muted);border:1px solid var(--border);padding:3px 10px;border-radius:var(--radius-pill)}
.franchise-badge{position:absolute;top:16px;right:16px;font-size:0.65rem;font-weight:700;letter-spacing:0.08em;color:var(--accent);border:1px solid var(--accent);padding:2px 8px;border-radius:var(--radius-pill);opacity:0.7}
.new-badge{font-size:0.78rem;font-weight:600;color:#525252;font-style:italic}

/* Claim CTA on cards */
.claim-card-link{display:block;margin-top:10px;font-size:0.75rem;color:#525252;transition:color 0.2s;text-decoration:none}
.claim-card-link:hover{color:var(--accent)}
.claim-modal-link{display:block;text-align:center;margin-top:20px;padding-top:16px;border-top:1px solid var(--border);font-size:0.85rem;color:var(--muted)}
.claim-modal-link:hover{color:var(--accent)}

/* Load more */
.load-more-wrap{text-align:center;padding:0 24px 64px}
.btn-load-more{padding:12px 36px;font-size:0.9rem;font-weight:600;letter-spacing:0.04em;text-transform:uppercase;border:2px solid var(--accent);border-radius:var(--radius-pill);background:transparent;color:var(--accent);cursor:pointer;transition:all 0.2s}
.btn-load-more:hover{background:var(--accent);color:#000}

/* Format grid section */
.format-section{padding:64px 24px;max-width:1200px;margin:0 auto;border-top:1px solid var(--border)}
.format-section h2{font-size:1.8rem;font-weight:800;letter-spacing:-0.01em;margin-bottom:32px;text-align:center}
.format-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.format-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;text-align:center;transition:all 0.2s;text-decoration:none;color:var(--text)}
.format-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.format-card h3{font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:0.05em;margin-bottom:6px}
.format-card .count{color:var(--accent);font-size:0.9rem;font-weight:600}

/* FAQ */
.faq-section{padding:64px 24px;max-width:800px;margin:0 auto;border-top:1px solid var(--border)}
.faq-section h2{font-size:1.8rem;font-weight:800;margin-bottom:32px;text-align:center}
.faq-item{border-bottom:1px solid var(--border);padding:20px 0}
.faq-q{font-weight:700;font-size:1rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.faq-q::after{content:'+';font-size:1.4rem;color:var(--accent);transition:transform 0.2s}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{color:var(--muted);font-size:0.92rem;line-height:1.7;max-height:0;overflow:hidden;transition:max-height 0.3s ease,padding 0.3s ease;padding-top:0}
.faq-item.open .faq-a{max-height:500px;padding-top:12px}

/* Modal */
.modal-overlay{display:none;position:fixed;inset:0;z-index:200;background:rgba(0,0,0,0.82);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);justify-content:center;align-items:flex-end;padding:0}
.modal-overlay.active{display:flex}
.modal-content{background:#1a1a1a;border-radius:20px 20px 0 0;padding:32px 28px 40px;width:100%;max-width:560px;max-height:85vh;overflow-y:auto;position:relative;animation:slideUp 0.3s ease}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-close{position:absolute;top:16px;right:20px;background:none;border:none;color:var(--muted);font-size:1.8rem;cursor:pointer;line-height:1}
.modal-close:hover{color:var(--text)}
.modal-rating{display:flex;align-items:center;gap:6px;margin-bottom:8px}
.modal-name{font-size:1.4rem;font-weight:800;margin-bottom:12px}
.modal-formats{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.modal-address{color:var(--muted);font-size:0.92rem;margin-bottom:8px}
.modal-phone{display:inline-block;color:var(--accent);font-size:0.92rem;margin-bottom:12px}
.modal-vibes{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.modal-hours{margin-bottom:20px}
.modal-hours h4{font-size:0.85rem;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;color:var(--muted);margin-bottom:8px}
.modal-hours table{width:100%;font-size:0.88rem}
.modal-hours td{padding:4px 0;border-bottom:1px solid var(--border)}
.modal-hours td:first-child{color:var(--muted);width:110px}
.modal-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.btn-accent{display:inline-block;padding:10px 24px;background:var(--accent);color:#000;font-weight:700;font-size:0.85rem;letter-spacing:0.04em;text-transform:uppercase;border-radius:var(--radius-pill);border:none;cursor:pointer;transition:background 0.2s;text-decoration:none;text-align:center}
.btn-accent:hover{background:var(--accent-hover);color:#000}
.btn-outline{display:inline-block;padding:10px 24px;border:1px solid var(--border);color:var(--text);font-weight:600;font-size:0.85rem;letter-spacing:0.04em;text-transform:uppercase;border-radius:var(--radius-pill);transition:all 0.2s;text-decoration:none;text-align:center}
.btn-outline:hover{border-color:var(--accent);color:var(--accent)}

/* Footer */
.footer{border-top:1px solid var(--border);padding:48px 24px;text-align:center}
.footer-links{display:flex;justify-content:center;gap:24px;margin-bottom:16px;flex-wrap:wrap}
.footer-links a{color:var(--muted);font-size:0.85rem;text-decoration:none}
.footer-links a:hover{color:var(--accent)}
.footer-copy{color:#525252;font-size:0.78rem}

/* Detail page */
.detail-wrap{max-width:720px;margin:0 auto;padding:32px 24px 64px}
.breadcrumb{display:flex;gap:8px;font-size:0.82rem;color:var(--muted);margin-bottom:24px;flex-wrap:wrap}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb .sep{color:#333}
.detail-header{margin-bottom:32px}
.detail-header h1{font-size:clamp(1.8rem,4vw,2.4rem);font-weight:900;margin-bottom:12px;line-height:1.15}
.detail-meta{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:16px}
.detail-address{color:var(--muted);font-size:0.95rem;margin-bottom:8px}
.detail-phone{color:var(--accent);font-size:0.95rem}
.detail-section{margin-bottom:32px}
.detail-section h2{font-size:1.1rem;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;color:var(--muted);margin-bottom:12px}
.detail-hours table{width:100%;max-width:400px}
.detail-hours td{padding:6px 0;border-bottom:1px solid var(--border);font-size:0.92rem}
.detail-hours td:first-child{color:var(--muted);width:120px}
.detail-actions{display:flex;flex-wrap:wrap;gap:12px;margin:32px 0}
.related-section{border-top:1px solid var(--border);padding-top:40px;margin-top:40px}
.related-section h2{font-size:1.4rem;font-weight:800;margin-bottom:24px}
.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}

/* Category page */
.cat-hero{text-align:center;padding:48px 24px 32px}
.cat-hero h1{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:900;letter-spacing:-0.02em;margin-bottom:12px}
.cat-hero p{color:var(--muted);font-size:1rem;max-width:600px;margin:0 auto}
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;padding:0 24px 48px;max-width:1200px;margin:0 auto}
.browse-other{padding:48px 24px;max-width:1200px;margin:0 auto;border-top:1px solid var(--border)}
.browse-other h2{font-size:1.4rem;font-weight:800;margin-bottom:20px;text-align:center}
.browse-links{display:flex;flex-wrap:wrap;justify-content:center;gap:10px}

/* Claim page */
.claim-wrap{max-width:640px;margin:0 auto;padding:64px 24px}
.claim-wrap h1{font-size:clamp(2rem,5vw,3rem);font-weight:900;margin-bottom:16px;line-height:1.1}
.claim-wrap .subtitle{color:var(--muted);font-size:1.1rem;margin-bottom:40px}
.benefit-list{list-style:none;margin-bottom:40px}
.benefit-list li{padding:12px 0;border-bottom:1px solid var(--border);font-size:1rem;display:flex;align-items:flex-start;gap:12px}
.benefit-list .icon{color:var(--accent);font-size:1.2rem;flex-shrink:0}
.claim-cta{text-align:center;margin-top:40px}

/* No results */
.no-results{text-align:center;padding:48px 24px;color:var(--muted)}
.no-results h3{font-size:1.2rem;margin-bottom:8px;color:var(--text)}

/* Claim detail link */
.claim-detail-link{display:inline-block;margin-top:24px;padding:10px 24px;border:1px solid var(--border);border-radius:var(--radius-pill);font-size:0.85rem;color:var(--muted);transition:all 0.2s}
.claim-detail-link:hover{border-color:var(--accent);color:var(--accent)}

/* Intel snippets on cards */
.card-intel{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}
.intel-chip{font-size:0.72rem;color:var(--muted);background:rgba(132,204,22,0.08);border:1px solid rgba(132,204,22,0.2);padding:3px 9px;border-radius:var(--radius-pill);white-space:nowrap}
.intel-chip.accent{color:var(--accent);border-color:rgba(132,204,22,0.4)}
.intro-badge{font-size:0.7rem;font-weight:600;color:#000;background:var(--accent);padding:2px 8px;border-radius:var(--radius-pill);white-space:nowrap}

/* Intel sections in modal/detail */
.intel-section{margin-bottom:16px}
.intel-section h4{font-size:0.82rem;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;color:var(--muted);margin-bottom:8px}
.intel-tags{display:flex;flex-wrap:wrap;gap:6px}
.intel-tag{font-size:0.78rem;color:var(--text);background:var(--surface);border:1px solid var(--border);padding:4px 12px;border-radius:var(--radius-pill)}
.intel-tag.equip{color:var(--accent);border-color:rgba(132,204,22,0.3)}
.pricing-block{font-size:0.88rem;color:var(--muted)}
.pricing-block .price-line{margin-bottom:4px}
.pricing-block .price-val{color:var(--text);font-weight:600}
.pricing-block .intro-line{color:var(--accent);font-weight:600}
.instructor-list{font-size:0.85rem;color:var(--muted);line-height:1.6}

/* Responsive */
@media(min-width:640px){
  .modal-overlay{align-items:center;padding:24px}
  .modal-content{border-radius:20px;max-height:80vh}
}
@media(max-width:640px){
  .card-grid,.cat-grid{grid-template-columns:1fr;padding:0 16px 48px}
  .hero{padding:48px 16px 24px}
  .filter-bar{padding:0 16px 24px}
  .controls{padding:12px 16px}
  .header{padding:0 16px}
  .stats-bar{gap:16px;padding:12px 16px 24px}
  .stat-sep{display:none}
}

/* Blog */
.blog-wrap{max-width:740px;margin:0 auto;padding:80px 24px 60px}
.blog-header{margin-bottom:48px}
.blog-header h1{font-size:2rem;font-weight:800;letter-spacing:-0.02em;margin-bottom:8px}
.blog-header p{color:var(--muted);font-size:1rem}
.blog-list{display:flex;flex-direction:column;gap:24px}
.blog-card{background:var(--surface);border:1px solid #333;border-radius:var(--radius);padding:28px 28px 24px;transition:border-color 0.2s,background 0.2s}
.blog-card:hover{border-color:var(--accent);background:var(--surface-hover)}
.blog-card a{color:inherit;text-decoration:none;display:block}
.blog-card h2{font-size:1.2rem;font-weight:700;margin-bottom:10px;line-height:1.35;color:var(--text)}
.blog-card .blog-meta{font-size:0.82rem;color:var(--muted);margin-bottom:14px;display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.blog-card .blog-meta span{color:var(--muted)}
.blog-card .blog-cat{font-size:0.72rem;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--accent);background:rgba(132,204,22,0.12);padding:3px 10px;border-radius:var(--radius-pill)}
.blog-card .blog-excerpt{color:var(--muted);font-size:0.92rem;line-height:1.55}
.blog-post-wrap{max-width:700px;margin:0 auto;padding:80px 24px 60px}
.blog-post-meta{font-size:0.85rem;color:var(--muted);margin-bottom:32px;display:flex;gap:12px;align-items:center}
.blog-post-meta .blog-cat{font-size:0.72rem;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--accent);background:rgba(132,204,22,0.1);padding:3px 10px;border-radius:var(--radius-pill)}
.blog-post-body h2{font-size:1.35rem;font-weight:700;margin:32px 0 12px;letter-spacing:-0.01em}
.blog-post-body h3{font-size:1.1rem;font-weight:600;margin:24px 0 8px;color:var(--text)}
.blog-post-body p{color:var(--muted);font-size:0.95rem;line-height:1.7;margin-bottom:16px}
.blog-post-body a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.blog-post-body a:hover{color:var(--accent-hover)}
.blog-post-body ul,.blog-post-body ol{color:var(--muted);font-size:0.95rem;line-height:1.7;margin:0 0 16px 24px}
.blog-post-body li{margin-bottom:6px}
.blog-post-body strong{color:var(--text);font-weight:600}
.blog-post-cta{margin-top:48px;padding:24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-align:center}
.blog-post-cta p{color:var(--muted);margin-bottom:12px;font-size:0.92rem}
.blog-post-cta a{display:inline-block;font-weight:600;font-size:0.88rem;color:var(--accent);border:1px solid var(--accent);padding:10px 24px;border-radius:var(--radius-pill);transition:all 0.2s}
.blog-post-cta a:hover{background:var(--accent);color:#000;text-decoration:none}
.blog-nav{margin-top:40px;padding-top:24px;border-top:1px solid var(--border)}
.blog-nav a{font-size:0.88rem;color:var(--accent)}
