/* === Directory Components === */

/* Breadcrumbs */
.breadcrumbs{padding:12px 0;font-size:.9rem;color:var(--muted)}
.breadcrumbs a{color:var(--text);text-decoration:none;font-weight:500}
.breadcrumbs a:hover{color:var(--accent);text-decoration:underline}
.breadcrumbs .sep{margin:0 8px;color:#ccc}

/* Search box */
.search-box{max-width:600px;margin:0 auto 40px;position:relative}
.search-box input{width:100%;padding:16px 20px 16px 48px;border:2px solid var(--border);border-radius:12px;font-size:1.05rem;background:#fff;color:var(--text);outline:none;transition:border-color .2s,box-shadow .2s}
.search-box input:focus{border-color:var(--accent);box-shadow:0 0 0 4px rgba(246,198,0,0.15)}
.search-box input::placeholder{color:#aaa}
.search-box .search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:1.2rem;color:#aaa;pointer-events:none}
.search-results{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--border);border-radius:0 0 12px 12px;box-shadow:0 8px 24px var(--shadow);max-height:320px;overflow-y:auto;z-index:50;display:none}
.search-results.active{display:block}
.search-results a{display:block;padding:12px 20px;text-decoration:none;color:var(--text);border-bottom:1px solid #f0f0f0;transition:background .15s}
.search-results a:hover{background:#fafafa}
.search-results a:last-child{border-bottom:none}
.search-results .result-city{font-weight:600}
.search-results .result-state{color:var(--muted);font-size:.85rem;margin-left:8px}
.search-no-results{padding:16px 20px;color:var(--muted);text-align:center}

/* States grid */
.states-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-top:28px}
.state-card{display:block;padding:20px;background:#fff;border:1px solid var(--border);border-radius:10px;text-decoration:none;color:var(--text);text-align:center;font-weight:600;font-size:1.05rem;transition:box-shadow .25s,transform .25s,border-color .25s}
.state-card:hover{box-shadow:0 8px 24px rgba(0,0,0,0.08);transform:translateY(-2px);border-color:var(--accent)}
.state-card .state-abbr{display:block;font-size:.8rem;color:var(--muted);font-weight:400;margin-top:4px}

/* City grid on state pages */
.cities-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;margin-top:28px}
.city-card{display:block;padding:24px;background:#fff;border:1px solid var(--border);border-radius:12px;text-decoration:none;color:var(--text);transition:box-shadow .25s,transform .25s,border-color .25s}
.city-card:hover{box-shadow:0 8px 24px rgba(0,0,0,0.08);transform:translateY(-2px);border-color:var(--accent)}
.city-card h3{font-size:1.15rem;margin-bottom:6px;color:var(--ink)}
.city-card .city-count{font-size:.9rem;color:var(--muted)}

/* Listing cards on city pages */
.listings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;margin-top:28px}
.listing-card{padding:24px;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 4px 16px var(--shadow);transition:box-shadow .25s,transform .25s;position:relative}
.listing-card:hover{box-shadow:0 10px 30px rgba(0,0,0,0.1);transform:translateY(-3px)}
.listing-card.featured{border-color:var(--accent);border-width:2px}
.listing-card h3{font-size:1.2rem;margin-bottom:8px;color:var(--ink)}
.listing-card h3 a{text-decoration:none;color:inherit}
.listing-card h3 a:hover{color:var(--accent)}
.listing-address{font-size:.9rem;color:var(--muted);margin-bottom:10px}
.listing-meta{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:12px}
.listing-rating{display:flex;align-items:center;gap:4px;font-weight:600;font-size:.95rem}
.listing-rating .stars{color:var(--accent)}
.listing-reviews{color:var(--muted);font-size:.85rem}
.listing-hours{font-size:.85rem;color:var(--muted)}

/* Service tags */
.service-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.service-tag{display:inline-block;padding:4px 10px;background:#f5f5f5;border:1px solid #eee;border-radius:6px;font-size:.8rem;color:var(--muted)}

/* Listing action buttons */
.listing-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.listing-actions a{font-size:.9rem}

/* Featured badge */
.badge-featured{display:inline-block;padding:4px 12px;background:var(--accent);color:var(--ink);font-size:.75rem;font-weight:700;border-radius:20px;text-transform:uppercase;letter-spacing:.04em;position:absolute;top:16px;right:16px}

/* Full listing page */
.listing-detail{max-width:800px;margin:0 auto}
.listing-detail h1{margin-bottom:8px}
.listing-detail .listing-meta{margin-bottom:20px}
.listing-detail .detail-section{margin-bottom:32px}
.listing-detail .detail-section h2{font-size:1.3rem;margin-bottom:12px;color:var(--ink)}

/* Contact card on listing detail */
.contact-card{padding:28px;background:#fafafa;border:1px solid var(--border);border-radius:12px;margin-bottom:32px}
.contact-card .phone-big{font-size:1.4rem;font-weight:700;color:var(--ink);display:block;margin-bottom:10px}
.contact-card .phone-big a{color:inherit;text-decoration:none}
.contact-card .phone-big a:hover{color:var(--accent)}

/* Quote form */
.quote-form{max-width:600px;margin:0 auto;padding:32px;background:#fafafa;border:1px solid var(--border);border-radius:12px}
.quote-form h3{font-size:1.2rem;margin-bottom:16px;color:var(--ink);text-align:center}
.quote-form label{display:block;font-size:.9rem;font-weight:600;color:var(--text);margin-bottom:6px}
.quote-form input,.quote-form select,.quote-form textarea{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:8px;font-size:.95rem;margin-bottom:16px;background:#fff;color:var(--text)}
.quote-form input:focus,.quote-form select:focus,.quote-form textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(246,198,0,0.12)}
.quote-form textarea{min-height:100px;resize:vertical}
.quote-form .btn{width:100%}

/* Affiliate card */
.affiliate-card{padding:20px;background:#fffef5;border:1px solid #f0e68c;border-radius:10px;margin-bottom:16px;display:flex;align-items:center;gap:16px}
.affiliate-card img{width:80px;height:80px;object-fit:contain;border-radius:8px;flex-shrink:0}
.affiliate-card .aff-info{flex:1}
.affiliate-card .aff-info h4{font-size:1rem;margin-bottom:4px;color:var(--ink)}
.affiliate-card .aff-info p{font-size:.85rem;color:var(--muted);margin-bottom:8px}
.affiliate-card .aff-link{font-size:.85rem;font-weight:600;color:var(--ink);text-decoration:none;padding:6px 14px;background:var(--accent);border-radius:6px;white-space:nowrap}
.affiliate-card .aff-link:hover{background:var(--accent-2)}

/* Featured highlight card (homepage) */
.featured-highlight{padding:32px;background:#fffef5;border:2px solid var(--accent);border-radius:14px;margin-top:36px}
.featured-highlight h3{font-size:1.3rem;margin-bottom:8px;color:var(--ink)}
.featured-highlight .fh-meta{display:flex;gap:16px;flex-wrap:wrap;align-items:center;margin-bottom:12px}

/* Responsive */
@media(max-width:768px){
  .states-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
  .listings-grid{grid-template-columns:1fr}
  .cities-grid{grid-template-columns:1fr}
  .affiliate-card{flex-direction:column;text-align:center}
  .affiliate-card img{width:60px;height:60px}
}
