:root{
  --color-text-primary: #0F1724;
  --color-bg: #F3F6F9;
  --color-surface: #FFFFFF;
  --color-surface-2: #F1F5F9;
  --color-accent: #0B60D6;
  --color-accent-2: #0F73F0;
  --color-positive: #16A34A;
  --color-muted: #6B7280;
  --color-border: rgba(15,23,36,0.06);

  --text-secondary: #475569;
  --text-muted: #6B7280;

  --space-xxs:4px;--space-xs:8px;--space-sm:12px;--space-md:20px;--space-lg:32px;--space-xl:48px;
  --radius-sm:10px;--radius-lg:18px;--radius-pill:9999px;
}

* {
  box-sizing: border-box;
}

html, body { 
  height:100%; 
  width:100%;
  overflow-x:hidden;
}

body{
  margin:0;
  background:linear-gradient(180deg, #F7F9FC 0%, var(--color-bg) 100%);
  color:var(--color-text-primary);
  font-family: Inter, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* Layout */
.app-header{background:#fff;box-shadow:0 6px 18px rgba(15,23,36,0.06);position:sticky;top:0;z-index:50;width:100%}
.header-inner{max-width:1200px;margin:0 auto;padding:8px 20px;display:flex;align-items:center;justify-content:space-between}
.brand a{display:inline-flex;align-items:center;gap:10px;color:var(--color-text-primary);font-weight:700;font-size:1.125rem;text-decoration:none}
.brand img{height:60px}
.main-nav{display:flex;align-items:center;gap:18px}
.main-nav a{color:var(--text-secondary);text-decoration:none;padding:8px 10px;border-radius:8px;white-space:nowrap}
.main-nav a:not(.btn-getlisted):hover{background:var(--color-surface-2);color:var(--color-text-primary)}
.btn-getlisted{background:linear-gradient(180deg,var(--color-accent),var(--color-accent-2));color:#fff !important;padding:10px 16px;border-radius:10px;border:0;box-shadow:0 6px 18px rgba(11,96,214,0.12);white-space:nowrap;transition:none}
.main-nav a.btn-getlisted:hover,
.main-nav a.btn-getlisted:focus,
.main-nav a.btn-getlisted:active{
  background:linear-gradient(180deg,var(--color-accent),var(--color-accent-2));
  color:#fff !important;
  box-shadow:0 6px 18px rgba(11,96,214,0.12);
  transform:none;
  filter:none;
}

.container{max-width:1100px;margin:0 auto;padding:var(--space-md);width:100%;box-sizing:border-box}

/* Ad-supported Layout */
.content-with-ads{display:grid;grid-template-columns:160px 1fr 160px;gap:20px;max-width:1920px;margin:0 auto;padding:0 20px}
.ad-sidebar{position:relative;min-height:600px}
.ad-sticky{position:sticky;top:90px;height:fit-content}
.ad-unit{background:#F8FAFC;border:1px solid var(--color-border);border-radius:8px;min-height:600px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.ad-unit:empty{display:none}
.ad-mobile{display:none}
.main-content-column{max-width:1100px;width:100%;margin:0 auto}
.main-content-column .container{padding:var(--space-md) 0}
.footer{text-align:center;padding:36px 20px;color:var(--text-muted);max-width:1920px;margin:0 auto}

/* Card component */
.card{background:#fff;border-radius:10px;padding:16px;box-shadow:0 2px 8px rgba(0,0,0,0.06);border:1px solid rgba(0,0,0,0.04)} 

/* Hero */
.hero{padding:16px 0 40px;background:linear-gradient(180deg, rgba(11,96,214,0.03) 0%, transparent 40%)}
.hero .kicker{color:var(--text-secondary);font-weight:600;margin-bottom:12px;text-transform:uppercase;font-size:0.85rem;letter-spacing:0.06em}
.hero h1{font-size:2.25rem;margin:0 0 8px;line-height:1.05}
.hero p.lead{color:var(--text-muted);margin:0 0 24px}

.search-rail{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.search-input-wrap{flex:1;min-width:280px;display:flex;align-items:center;background:#fff;border-radius:36px;padding:12px 16px;box-shadow:0 6px 20px rgba(15,23,36,0.06);border:1px solid var(--color-border);transition:border-color 0.2s ease}
.search-input-wrap:focus-within{border-color:var(--color-accent);box-shadow:0 6px 20px rgba(11,96,214,0.12)}
.search-input{flex:1;border:0;padding:8px 4px;font-size:1rem;border-radius:28px;background:transparent;color:#0F1724;min-width:0}
.search-input::placeholder{color:#9CA3AF;font-size:0.95rem}
.search-input:focus{outline:none}
.search-input::-webkit-search-cancel-button{display:none}
.search-submit{background:linear-gradient(180deg,var(--color-accent),var(--color-accent-2));color:#fff;border-radius:28px;padding:10px 18px;border:0;cursor:pointer;transition:transform 0.2s ease;font-weight:600;white-space:nowrap}
.search-submit:hover{transform:scale(1.02)}
.search-submit:focus{outline:2px solid var(--color-accent);outline-offset:2px}

/* Search dropdown */
.search-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,0.12);margin-top:8px;max-height:400px;overflow-y:auto;z-index:100}
.search-result-item{padding:14px 18px;cursor:pointer;border-bottom:1px solid #f0f0f0;transition:background 0.15s ease}
.search-result-item:last-child{border-bottom:none}
.search-result-item:hover, .search-result-item.highlighted{background:#f8fafc}
.search-result-item.highlighted{border-left:3px solid var(--color-accent)}
.search-result-item .result-name{font-weight:600;color:#0F1724;margin-bottom:4px}
.search-result-item .result-meta{font-size:0.85rem;color:#64748b}

/* Filter chips row */
.chips-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.chip{display:inline-flex;align-items:center;padding:8px 14px;border-radius:999px;background:#fff;border:1px solid var(--color-border);color:var(--text-secondary);cursor:pointer;box-shadow:0 2px 8px rgba(15,23,36,0.04)}
.chip .icon{margin-right:8px}
.chip.active{background:var(--color-accent);color:#fff;border-color:transparent;box-shadow:0 8px 24px rgba(11,96,214,0.12)}

/* Popular activities */
.activity-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px;margin-top:28px}
.activity-pill{display:flex;flex-direction:column;align-items:center;gap:8px;background:#fff;padding:16px 12px;border-radius:14px;box-shadow:0 6px 18px rgba(15,23,36,0.04);border:1px solid transparent;transition:all 0.2s ease;text-align:center}
.activity-pill:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(15,23,36,0.08);border-color:#0B60D6}
.activity-pill:focus{outline:2px solid var(--color-accent);outline-offset:2px}
.activity-pill .ico{width:40px;height:40px;border-radius:50%;background:var(--color-surface-2);display:flex;align-items:center;justify-content:center}

/* Featured listings grid */
.featured-grid{display:flex;flex-direction:column;gap:16px;margin-top:0}

/* Home page featured grid - show in grid layout */
.hero .featured-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:32px}

/* Listing cards matching reference */
.listing-card{background:#fff;border-radius:10px;padding:20px 22px 68px;position:relative;box-shadow:0 2px 8px rgba(0,0,0,0.06);border:1px solid rgba(0,0,0,0.04);transition:all 0.2s ease}
.listing-card:hover{box-shadow:0 6px 20px rgba(0,0,0,0.1);transform:translateY(-2px)}
.listing-card .card-head{display:flex;gap:16px;align-items:flex-start}
.listing-card .logo{width:60px;height:60px;min-width:60px;border-radius:50%;background:linear-gradient(135deg,#f0f4f8,#e2e8f0);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem;color:#475569;overflow:hidden;box-shadow:0 2px 6px rgba(0,0,0,0.05)}
.listing-card .info{flex:1;min-width:0}
.listing-card .title{font-weight:700;font-size:1.1rem;color:#0F1724;margin:0 0 8px;line-height:1.3}
.listing-card .sport{color:#0B60D6;font-size:0.9rem;font-weight:500;margin:0 0 6px}
.listing-card .address{color:#64748b;font-size:0.88rem;line-height:1.5;margin:0}
.listing-card .ages{margin-top:10px}
.badge{display:inline-flex;align-items:center;padding:5px 10px;border-radius:5px;font-size:0.75rem;background:#dcfce7;color:#16a34a;font-weight:500;margin-right:6px}
.card-cta{margin-top:16px;display:flex;align-items:center;justify-content:space-between}

/* Buttons and links */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:8px;border:0;background:var(--color-accent);color:#fff;cursor:pointer;text-decoration:none;transition:all 0.2s ease;box-sizing:border-box}
.btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(11,96,214,0.2)}
.btn:focus{outline:2px solid var(--color-accent);outline-offset:2px}
.btn-primary{display:inline-flex;align-items:center;justify-content:center;padding:12px 20px;border-radius:8px;border:0;background:#0B60D6;color:#fff;cursor:pointer;text-decoration:none;font-weight:600;transition:all 0.2s ease}
.btn-primary:hover{background:#0a56c2;transform:translateY(-1px);box-shadow:0 4px 12px rgba(11,96,214,0.3)}
.btn-primary:focus{outline:2px solid var(--color-accent);outline-offset:2px}
.btn-secondary{display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;color:#475569;cursor:pointer;text-decoration:none;font-weight:500;transition:all 0.2s ease;box-sizing:border-box}
.btn-secondary:hover{background:#f8fafc;border-color:#cbd5e1;color:#0F1724}
.btn-secondary:focus{outline:2px solid var(--color-accent);outline-offset:2px}

/* Contact page */
.contact-page{padding-bottom:48px}
.contact-hero{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:24px;align-items:center;padding:32px 0 20px}
.contact-hero-text h1{margin-bottom:10px}
.contact-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:0.85rem;font-weight:600;color:#0B60D6;text-transform:uppercase;letter-spacing:0.08em}
.contact-hero-card{background:#fff;border-radius:14px;padding:18px 20px;box-shadow:0 10px 30px rgba(15,23,36,0.08);border:1px solid rgba(15,23,36,0.06);display:grid;gap:12px}
.contact-hero-card strong{display:block;font-size:0.95rem;color:#0F1724;margin-bottom:2px}
.contact-hero-card p{margin:0;color:#64748b;font-size:0.9rem}
.contact-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:24px;align-items:start}
.contact-form-card{padding:22px 24px;border-radius:14px;box-shadow:0 12px 30px rgba(15,23,36,0.08)}
.contact-form-card .card-header{margin-bottom:18px}
.contact-form-card h2{margin:0 0 6px;font-size:1.3rem}
.contact-form-card p{margin:0;color:#64748b}
.contact-form{display:flex;flex-direction:column;gap:16px}
.contact-field label{display:block;margin-bottom:6px;font-weight:600;color:#0F1724}
.contact-field .search-input{width:100%;padding:10px 12px;border-radius:10px;border:1px solid #e2e8f0;box-shadow:0 1px 2px rgba(15,23,36,0.04)}
.contact-field .search-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px rgba(11,96,214,0.12)}
.contact-field textarea.search-input{resize:vertical;min-height:140px;font-family:inherit}
.required{color:#ef4444;margin-left:4px}
.field-error{color:#ef4444;font-size:0.85rem;margin-top:4px;display:block}
.char-count{color:#64748b;font-size:0.85rem;margin-top:4px;display:block}
.contact-success{padding:12px;background:#dcfce7;color:#16a34a;border-radius:10px;text-align:center;font-weight:600}
.contact-submit{width:100%;padding:14px;border-radius:10px;font-weight:600}
.contact-aside{display:flex;flex-direction:column;gap:16px}
.contact-aside-card{padding:18px 20px;border-radius:14px}
.contact-aside-card h3{margin:0 0 8px;font-size:1.05rem}
.contact-aside-card p{margin:0;color:#64748b}
.contact-aside-card ul{margin:0;padding-left:18px;color:#64748b;display:grid;gap:6px}

@media (max-width:980px){
  .contact-hero,
  .contact-layout{grid-template-columns:1fr}
  .contact-hero-card,
  .contact-aside{order:2}
}
.btn-outline{background:#fff;color:var(--color-text-primary);border:1px solid #e2e8f0;box-shadow:0 2px 4px rgba(0,0,0,0.04)}
.btn-outline:hover{border-color:var(--color-accent);color:var(--color-accent);background:#f8fafc;box-shadow:0 2px 8px rgba(11,96,214,0.12)}
.btn-viewall{background:transparent;color:var(--color-accent);border:1px solid transparent;padding:10px 14px;border-radius:8px;transition:all 0.2s ease}
.btn-viewall:hover{background:#f0f7ff}
.btn-viewall:focus{outline:2px solid var(--color-accent);outline-offset:2px}
.btn-clear-filters{background:transparent;color:#ef4444;border:1px solid #fecaca;padding:6px 12px;border-radius:6px;font-size:0.85rem;cursor:pointer;transition:all 0.2s ease}
.btn-clear-filters:hover{background:#fef2f2;border-color:#ef4444}
.btn-clear-filters:focus{outline:2px solid #ef4444;outline-offset:2px}

/* Remove underline globally for anchors inside app but preserve color rules set elsewhere */
.app-shell a{text-decoration:none}

/* Clickable listing tiles */
.listing-link{display:block;color:inherit;text-decoration:none}
.listing-link:hover .listing-card{transform:translateY(-6px);box-shadow:0 18px 36px rgba(15,23,36,0.12)}
.listing-card{transition:transform .18s ease,box-shadow .18s ease}

/* Filters sidebar matching reference */
.listings-layout aside:first-child .card{padding:20px;border-radius:8px;background:#fff;border:1px solid rgba(0,0,0,0.08);box-shadow:0 1px 3px rgba(0,0,0,0.06)}
.filters h4{font-size:1.1rem;font-weight:700;margin:0 0 16px;color:#0F1724}
.filter-section{margin-bottom:20px}
.filter-section:last-child{margin-bottom:0}
.filter-section strong{display:block;margin-bottom:10px;font-size:0.95rem;font-weight:600;color:#0F1724;cursor:pointer;user-select:none;display:flex;align-items:center;justify-content:space-between}
.filter-section strong::after{content:"▼";font-size:0.7rem;transition:transform 0.2s ease;color:#64748b}
.filter-section.collapsed strong::after{transform:rotate(-90deg)}
.filter-section > div{max-height:500px;overflow:hidden;transition:max-height 0.3s ease}
.filter-section.collapsed > div{max-height:0}
.listings-layout label{cursor:pointer;display:flex;align-items:center;gap:8px;padding:6px 0;font-size:0.9rem;color:#475569}
.listings-layout label:hover{color:#0F1724}
.listings-layout input[type="checkbox"]{width:18px;height:18px;cursor:pointer}
.listings-layout input[type="radio"]{width:18px;height:18px;cursor:pointer}

/* Details panel matching reference */
.details-panel{background:#fff;border-radius:10px;padding:24px;box-shadow:0 2px 8px rgba(0,0,0,0.06);border:1px solid rgba(0,0,0,0.04)}
.details-panel .details-header{display:flex;align-items:flex-start;gap:16px;padding-bottom:18px;margin-bottom:20px;border-bottom:1px solid #e2e8f0}
.details-panel .details-header .logo{width:68px;height:68px;min-width:68px;border-radius:50%;background:linear-gradient(135deg,#f0f4f8,#e2e8f0);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.4rem;color:#475569;overflow:hidden;box-shadow:0 2px 6px rgba(0,0,0,0.05)}
.details-panel h3{font-size:1.3rem;font-weight:700;margin:0 0 10px;color:#0F1724;line-height:1.3}
.details-panel .verified{display:inline-flex;align-items:center;padding:5px 12px;border-radius:6px;background:#dcfce7;color:#16a34a;font-size:0.8rem;font-weight:500}
.details-panel .verified::before{content:"✓ ";font-weight:700}
.details-panel h4{font-size:1.05rem;font-weight:700;margin:24px 0 12px;color:#0F1724}
.details-panel .contact-box{background:#f8fafc;border:1px solid #e2e8f0;padding:16px;border-radius:8px;margin-bottom:20px}
.details-panel .contact-box strong{display:block;font-size:1rem;font-weight:700;margin-bottom:12px;color:#0F1724}
.details-panel .contact-box .sport{color:#0B60D6;font-size:0.9rem;font-weight:500;display:block;margin-bottom:6px}
.details-panel .contact-box .address{color:#64748b;font-size:0.9rem;line-height:1.6;display:block;margin-bottom:14px}
.details-panel .contact-box .btn{background:#0B60D6;color:#fff;padding:10px 20px;border-radius:7px;text-decoration:none;display:inline-block;font-size:0.9rem;font-weight:600;transition:all 0.2s ease}
.details-panel .contact-box .btn:hover{background:#0a56c2;transform:translateY(-1px);box-shadow:0 4px 12px rgba(11,96,214,0.3)}
.details-panel p{color:#475569;font-size:0.95rem;line-height:1.7;margin:0 0 16px}
.details-panel .map{height:200px;border-radius:8px;background:#e2e8f0;border:1px solid #cbd5e1;display:flex;align-items:center;justify-content:center;color:#94a3b8;font-size:0.9rem;margin-top:20px}

/* Listings page grid matching reference */
.listings-layout{display:grid;grid-template-columns:260px 1fr 380px;gap:20px;margin-top:20px;align-items:start}
.listings-layout aside:first-child .card{position:sticky;top:90px}
.listings-layout aside:last-child .details-panel{position:sticky;top:90px}

/* View button matching reference with arrow */
.listing-card .card-foot{position:absolute;right:22px;bottom:20px}
.card-view{background:#0B60D6;color:#fff;padding:9px 20px 9px 16px;border-radius:7px;border:0;font-size:0.9rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:all 0.2s ease;box-shadow:0 2px 6px rgba(11,96,214,0.2)}
.card-view:hover{background:#0a56c2;transform:translateY(-1px);box-shadow:0 4px 12px rgba(11,96,214,0.3)}
.card-view::after{content:"→";font-size:1.2rem}

/* Ensure primary blue buttons have white text */
.btn{color:#fff}
.btn.btn-outline{color:var(--color-text-primary)}
.btn.btn-outline:hover{color:var(--color-accent)}

/* Footer / misc */
.footer{padding:36px 0;color:var(--text-muted);text-align:center}

/* Ads sidebars layout */
.page-with-ads{display:grid;grid-template-columns:160px 1fr 160px;gap:18px}
.ad-container{background:#F8FAFC;border:1px solid var(--color-border);border-radius:8px;padding:14px;color:var(--text-secondary)}

/* Accessibility */
:focus{outline:none}
.focus-visible:focus-visible{box-shadow:0 0 0 4px rgba(11,96,214,0.12);border-radius:6px}

/* Empty states */
.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}
.empty-icon{font-size:4rem;margin-bottom:16px;opacity:0.5}
.empty-state p{margin:8px 0;font-size:1rem}
.empty-state strong{color:var(--color-text-primary);font-size:1.1rem}
.empty-hint{font-size:0.9rem;opacity:0.8}

/* Directions button */
.btn-directions{display:inline-flex;align-items:center;justify-content:center;margin-top:8px;padding:10px 18px;border-radius:8px;background:#10b981;color:#fff;text-decoration:none;font-weight:500;transition:all 0.2s ease;box-sizing:border-box}
.btn-directions:hover{background:#059669;transform:translateY(-1px);box-shadow:0 4px 12px rgba(16,185,129,0.3)}
.btn-directions:focus{outline:2px solid #10b981;outline-offset:2px}

/* Close panel button */
.btn-close-panel{position:absolute;top:16px;right:16px;background:#f1f5f9;border:0;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 0.2s ease;z-index:10}
.btn-close-panel:hover{background:#e2e8f0;transform:scale(1.1)}
.btn-close-panel:focus{outline:2px solid var(--color-accent);outline-offset:2px}

/* Breadcrumbs */
.breadcrumbs{padding:16px 0;font-size:0.9rem;color:#64748b}
.breadcrumbs a{color:var(--color-accent);text-decoration:none}
.breadcrumbs a:hover{text-decoration:underline}
.breadcrumbs span{color:#0F1724;font-weight:500}

/* Individual listing detail page */
.listing-detail-page{margin-top:24px}
.listing-header-banner{background:#fff;border-radius:12px;padding:32px;margin-bottom:24px;display:flex;align-items:center;gap:24px;box-shadow:0 2px 8px rgba(0,0,0,0.06)}
.logo-large{width:96px;height:96px;min-width:96px;border-radius:50%;background:linear-gradient(135deg,#f0f4f8,#e2e8f0);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:2rem;color:#475569}
.listing-title-section h1{margin:0 0 12px;font-size:2rem}
.listing-meta{display:flex;flex-wrap:wrap;gap:8px}
.sport-badge{background:var(--color-accent);color:#fff;padding:6px 12px;border-radius:6px;font-size:0.9rem;font-weight:500}
.listing-content-grid{display:grid;grid-template-columns:1fr 350px;gap:24px}
.listing-main{display:flex;flex-direction:column;gap:20px}
.listing-main h2{margin:0 0 12px;font-size:1.3rem}
.listing-main .card{background:#fff;border-radius:10px;padding:20px;box-shadow:0 2px 8px rgba(0,0,0,0.06);border:1px solid rgba(0,0,0,0.04)}
.listing-sidebar{position:relative}
.listing-sidebar .card{background:#fff;border-radius:10px;padding:20px;box-shadow:0 2px 8px rgba(0,0,0,0.06);border:1px solid rgba(0,0,0,0.04)}
.listing-sidebar .contact-card h3{margin:0 0 16px;font-size:1.1rem}
.contact-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid #f1f5f9}
.contact-item:last-of-type{border-bottom:0}
.contact-item svg{color:#64748b}
.contact-item a{color:var(--color-accent);text-decoration:none;flex:1}
.contact-item a:hover{text-decoration:underline}
.address-line{display:flex;align-items:center;gap:12px;padding:12px;background:#f8fafc;border-radius:8px;margin-bottom:16px}
.address-line svg{color:#64748b;min-width:20px}
.address-line span{flex:1;word-break:break-word}
.map-embed{margin-top:16px}
.map-embed iframe{width:100%;max-width:100%}
.action-buttons{margin-top:16px;display:flex;flex-direction:column;gap:8px}
.btn-icon{background:transparent;border:0;padding:4px;cursor:pointer;opacity:0.6;transition:opacity 0.2s}
.btn-icon:hover{opacity:1}

/* Toast notifications */
.toast-container{position:fixed;top:20px;right:20px;z-index:9999;animation:slideInRight 0.3s ease}
.toast{background:#fff;border-radius:10px;padding:16px;box-shadow:0 8px 24px rgba(0,0,0,0.15);display:flex;align-items:center;gap:12px;min-width:300px;max-width:400px;border-left:4px solid #0B60D6}
.toast-success{border-left-color:#16a34a}
.toast-error{border-left-color:#ef4444}
.toast-warning{border-left-color:#f59e0b}
.toast-info{border-left-color:#0B60D6}
.toast-icon{font-size:1.5rem;line-height:1;min-width:24px;text-align:center}
.toast-success .toast-icon{color:#16a34a}
.toast-error .toast-icon{color:#ef4444}
.toast-warning .toast-icon{color:#f59e0b}
.toast-info .toast-icon{color:#0B60D6}
.toast-content{flex:1}
.toast-title{font-weight:600;color:#0F1724;margin-bottom:2px}
.toast-message{font-size:0.9rem;color:#64748b}
.toast-close{background:transparent;border:0;cursor:pointer;padding:4px;opacity:0.5;transition:opacity 0.2s}
.toast-close:hover{opacity:1}

@keyframes slideInRight{
  from{transform:translateX(400px);opacity:0}
  to{transform:translateX(0);opacity:1}
}

/* Skeleton loaders */
.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}
.skeleton-card{height:200px;border-radius:10px}
.skeleton-text{height:16px;border-radius:4px;margin-bottom:8px}
.skeleton-text.title{height:24px;width:70%}
.skeleton-text.short{width:40%}

@keyframes shimmer{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}

/* Responsive */
@media (max-width:1100px){
  .featured-grid{grid-template-columns:repeat(2,1fr)}
  .page-with-ads{grid-template-columns:1fr}
  .listings-layout{grid-template-columns:1fr;gap:12px}
  .listings-layout aside:first-child{order:1}
  .listings-layout main{order:2}
  .listings-layout aside:last-child{order:3;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.5);z-index:1000;display:none}
  .listings-layout aside:last-child.show{display:block}
  .listings-layout aside:last-child .details-panel{position:fixed;right:0;top:0;bottom:0;width:100%;max-width:500px;background:#fff;box-shadow:-4px 0 24px rgba(0,0,0,0.2);overflow-y:auto;animation:slideIn 0.3s ease}
}

@media (max-width:768px){
  .brand img{height:48px}
  .main-nav{gap:12px}
  .btn-getlisted{padding:8px 12px;font-size:0.9rem}
  .hero{padding:32px 0 24px}
  .hero .kicker{font-size:0.75rem}
  .listings-layout aside:first-child .card{padding:12px}
  .filters h4{font-size:1rem}
  .filter-section{margin-top:8px}
  .listing-card{padding:16px 18px 60px}
}

@media (max-width:640px){
  .header-inner{padding:6px 12px}
  .brand a{gap:6px;font-size:1rem}
  .brand img{height:32px;max-width:140px;object-fit:contain}
  .main-nav{gap:6px}
  .main-nav a{font-size:0.8rem;padding:6px 8px}
  .btn-getlisted{font-size:0.75rem;padding:6px 10px}
  .container{padding:10px 14px;width:100%}
  .card{padding:12px;border-radius:8px}
  .hero{padding:16px 0 20px}
  .hero .kicker{font-size:0.75rem;margin-bottom:8px}
  .hero h1{font-size:1.4rem;margin-bottom:8px;line-height:1.2}
  .hero p.lead{font-size:0.85rem;margin-bottom:16px}
  .hero .featured-grid{grid-template-columns:1fr;gap:14px;margin-top:20px}
  .featured-grid{grid-template-columns:1fr}
  .search-rail{flex-direction:row;width:100%;gap:8px;align-items:center;flex-wrap:nowrap}
  .search-input-wrap{flex:1;min-width:0;height:44px;padding:0 12px;display:flex;align-items:center}
  .search-input-wrap:focus-within{border-color:var(--color-accent)}
  .search-input{flex:1;width:100%;padding:0 4px;font-size:15px;height:auto;line-height:normal;min-width:0}
  .search-input::placeholder{color:#9CA3AF;font-size:13px}
  .search-submit{padding:10px 16px;font-size:0.85rem;font-weight:600;min-height:44px;border-radius:22px;flex-shrink:0}
  .activity-list{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:16px}
  .activity-pill{padding:14px 8px;border-radius:10px;min-height:80px}
  .activity-pill .ico{width:32px;height:32px}
  .chips-row{gap:6px;margin-top:12px}
  .chip{padding:6px 10px;font-size:0.8rem}
  .filter-section{margin-bottom:12px}
  .filter-section strong{font-size:0.9rem;padding:8px 0}
  .filters h4{font-size:0.95rem;margin-bottom:12px}
  .listings-layout aside:first-child .card{padding:12px}
  .listing-card{padding:12px 12px 52px}
  .listing-card .logo{width:48px;height:48px;min-width:48px;font-size:1rem}
  .listing-card .title{font-size:1rem}
  .listing-card .sport{font-size:0.85rem}
  .listing-card .address{font-size:0.8rem}
  .card-view{padding:7px 14px;font-size:0.8rem;border-radius:6px}
  
  /* Hide sidebar ads on mobile, show inline ads */
  .content-with-ads{grid-template-columns:1fr;padding:0 14px}
  .ad-sidebar{display:none}
  .ad-mobile{display:block;margin:16px 0}
  .ad-mobile-top{margin-top:0;margin-bottom:20px}
  .ad-mobile-bottom{margin-top:20px;margin-bottom:0}
  .ad-unit-mobile{background:#F8FAFC;border:1px solid var(--color-border);border-radius:8px;min-height:250px;max-height:300px;display:flex;align-items:center;justify-content:center;overflow:hidden}
  .ad-unit-mobile:empty{display:none}
  .main-content-column .container{padding:var(--space-md) 0}
  .card-foot{right:12px;bottom:12px}
  .details-panel{padding:14px}
  .listings-layout aside:last-child .details-panel{max-width:100%}
  input[type="text"],input[type="email"],textarea{font-size:16px !important;max-width:100%;width:100%}
  textarea{min-height:120px}
  .listing-card .card-head{gap:12px}
  
  /* Detail page mobile */
  .breadcrumbs{font-size:0.8rem;padding:12px 0}
  .listing-header-banner{flex-direction:column;padding:20px 16px;text-align:center}
  .logo-large{width:80px;height:80px;font-size:1.5rem}
  .listing-title-section h1{font-size:1.5rem;margin-bottom:8px}
  .listing-meta{justify-content:center}
  .sport-badge{font-size:0.85rem;padding:5px 10px}
  .listing-content-grid{grid-template-columns:1fr;gap:16px}
  .listing-main h2{font-size:1.1rem;margin-bottom:8px}
  .listing-main .card{padding:16px}
  .listing-sidebar .card{padding:16px}
  .listing-sidebar .contact-card h3{font-size:1rem;margin-bottom:12px}
  .contact-item{padding:10px 0;gap:8px}
  .address-line{padding:10px;font-size:0.9rem}
  .map-embed iframe{height:200px}
  .action-buttons{margin-top:12px}
  .btn-directions{width:100%;justify-content:center}
  
  /* Ensure everything fits within viewport */
  body, html, #app, .app-shell{max-width:100vw;overflow-x:hidden}
  img{max-width:100%;height:auto}
  .app-header{width:100%}
  
  /* Fix form inputs */
  input, textarea, select, button{max-width:100%;box-sizing:border-box}
  
  /* Prevent text overflow */
  h1,h2,h3,h4,h5,h6,p,span,div{word-wrap:break-word;overflow-wrap:break-word}
}

@keyframes slideIn{
  from{transform:translateX(100%)}
  to{transform:translateX(0)}
}

/* Accessibility - Skip to main content */
.skip-to-main{
  position:absolute;
  top:-40px;
  left:0;
  background:#0B60D6;
  color:#fff;
  padding:8px 16px;
  text-decoration:none;
  z-index:100;
  border-radius:0 0 4px 0;
  font-weight:600;
}
.skip-to-main:focus{
  top:0;
}

/* Print Styles */
@media print{
  .app-header, .main-nav, .btn-getlisted, .search-rail, .filter-section, .toast-container, footer, .btn, .card-view{display:none !important}
  body{background:#fff;color:#000}
  .listing-card, .details-panel{border:1px solid #000;page-break-inside:avoid}
  a{color:#000;text-decoration:underline}
  .container{max-width:100%;padding:0}
}

/* Focus visible for better keyboard navigation */
*:focus-visible{
  outline:3px solid #0B60D6;
  outline-offset:2px;
}
