*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Hiragino Sans',sans-serif;background:#f8fafc;color:#1e293b;line-height:1.6}
a{color:#6366f1;text-decoration:none}
a:hover{text-decoration:underline}

.header{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;padding:16px 20px;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.header-inner{max-width:1000px;margin:0 auto;display:flex;align-items:center;gap:12px}
.header-title{font-size:1.3rem;font-weight:800}
.header-subtitle{font-size:.75rem;opacity:.85}
.header-nav{margin-left:auto;display:flex;gap:12px}
.header-nav a{color:#fff;font-size:.85rem;opacity:.9}
.header-nav a:hover{opacity:1;text-decoration:none}

.container{max-width:1000px;margin:0 auto;padding:16px 20px}

/* Genre grid */
.genre-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin:16px 0}
.genre-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:16px 12px;text-align:center;cursor:pointer;transition:all .2s;text-decoration:none;color:#1e293b}
.genre-card:hover,.genre-card.active{border-color:#6366f1;background:#eef2ff;text-decoration:none}
.genre-name{font-size:.9rem;font-weight:600}
.genre-count{font-size:.7rem;color:#94a3b8;margin-top:2px}

/* Filter bar */
.filter-bar{background:#fff;border-bottom:1px solid #e2e8f0;padding:12px 20px;position:sticky;top:60px;z-index:90}
.filter-inner{max-width:1000px;margin:0 auto;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.filter-select{padding:8px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:.85rem;background:#fff;color:#374151}
.filter-select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px rgba(99,102,241,.15)}
.search-input{flex:1;min-width:200px;padding:8px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:.85rem}
.search-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px rgba(99,102,241,.15)}

/* School cards */
.school-list{display:flex;flex-direction:column;gap:12px;margin:16px 0}
.school-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px;transition:box-shadow .2s;cursor:pointer}
.school-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.08)}
.school-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}
.school-name{font-size:1rem;font-weight:700;color:#1e293b}
.school-genre-badge{display:inline-flex;align-items:center;gap:4px;background:#eef2ff;color:#6366f1;font-size:.75rem;font-weight:600;padding:3px 8px;border-radius:20px}
.school-info{font-size:.8rem;color:#64748b;display:flex;flex-wrap:wrap;gap:8px;margin:6px 0}
.school-info span::before{margin-right:3px}
.school-fee{font-size:.85rem;font-weight:600;color:#059669;margin-top:6px}
.school-rating{color:#f59e0b;font-size:.85rem}
.school-tags{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}
.tag{font-size:.7rem;padding:2px 8px;border-radius:12px;background:#f1f5f9;color:#64748b}
.tag-trial{background:#dcfce7;color:#16a34a}

/* Detail page */
.detail-header{background:#fff;border-radius:12px;padding:20px;margin-bottom:16px;border:1px solid #e2e8f0}
.detail-title{font-size:1.4rem;font-weight:800;margin-bottom:8px}
.detail-section{background:#fff;border-radius:12px;padding:20px;margin-bottom:16px;border:1px solid #e2e8f0}
.detail-section h3{font-size:1rem;font-weight:700;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid #eef2ff}
.info-grid{display:grid;grid-template-columns:100px 1fr;gap:8px;font-size:.85rem}
.info-label{color:#64748b;font-weight:600}
.info-value{color:#1e293b}

/* Reviews */
.review-card{background:#f8fafc;border-radius:8px;padding:12px;margin-bottom:8px}
.review-meta{font-size:.75rem;color:#94a3b8;margin-bottom:4px}
.review-stars{color:#f59e0b}
.review-text{font-size:.85rem;margin-top:6px}

/* Map */
#map,.map-container{height:350px;border-radius:12px;margin:16px 0;border:1px solid #e2e8f0}

/* Breadcrumb */
.breadcrumb{font-size:.8rem;color:#94a3b8;margin-bottom:12px}
.breadcrumb a{color:#6366f1}

/* Ad */
.ad-container{max-width:1000px;margin:12px auto;text-align:center}

/* Footer */
.footer{background:#1e293b;color:#94a3b8;padding:24px 20px;margin-top:40px;text-align:center;font-size:.8rem}
.footer a{color:#a5b4fc}
.footer-links{display:flex;gap:16px;justify-content:center;margin-bottom:8px}

/* Stats */
.stats-bar{display:flex;gap:16px;justify-content:center;padding:12px;background:#eef2ff;border-radius:8px;margin:12px 0;font-size:.85rem;color:#4f46e5;font-weight:600}

/* Loading */
.loading{text-align:center;padding:40px;color:#94a3b8}
.spinner{display:inline-block;width:32px;height:32px;border:3px solid #e2e8f0;border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Empty */
.empty{text-align:center;padding:60px 20px;color:#94a3b8}
.empty-icon{font-size:3rem;margin-bottom:12px}

/* Responsive */
@media(max-width:600px){
  .genre-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px}
  .genre-card{padding:12px 8px}
  .genre-icon{font-size:1.5rem}
  .filter-inner{flex-direction:column}
  .info-grid{grid-template-columns:90px 1fr}
  .header-nav{gap:8px}
  .stats-bar{flex-direction:column;gap:4px}
}
