/* components.css — Generated by WP Design Extractor */
*,*::before,*::after{box-sizing:border-box}
body{margin:0;font-family:var(--font-primary,system-ui,sans-serif);color:#ffffff;line-height:1.6}
.container{max-width:var(--max-width,1280px);margin:0 auto;padding:0 1rem}
img{max-width:100%;height:auto}
a{color:#00b4db;text-decoration:none}
a:hover{text-decoration:underline}

/* Header */
.site-header{background:#fff;border-bottom:1px solid #ffffff;position:sticky;top:0;z-index:100}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;gap:1rem}
.site-logo img{height:50px;width:auto}
.sticky{box-shadow:0 2px 10px rgba(0,0,0,.08)}
.header-hidden{transform:translateY(-100%);transition:transform .3s}

/* Navigation */
.nav-menu{list-style:none;margin:0;padding:0;display:flex;gap:1.5rem}
.nav-menu a{color:#ffffff;font-weight:600;font-size:.9rem;padding:.25rem 0}
.nav-menu a:hover,.nav-menu .current-menu-item a{color:#00b4db;text-decoration:none}
.menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.4rem}
.menu-toggle .bar{width:24px;height:2px;background:#ffffff;border-radius:2px;transition:transform .3s}

/* Hero */
.hero-section{position:relative;background-size:cover;background-position:center;padding:5rem 1rem;color:#fff;text-align:center}
.hero-overlay{position:absolute;inset:0;background:rgba(0,0,0,.45)}
.hero-inner{position:relative;z-index:1}
.hero-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:800;margin-bottom:1rem}
.hero-subtitle{font-size:1.2rem;opacity:.9;margin-bottom:2rem;max-width:60ch;margin-left:auto;margin-right:auto}

/* Search Form */
.search-form .search-fields{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}
.search-input{padding:.75rem 1rem;border:2px solid #ffffff;border-radius:100%;font-size:1rem;min-width:200px;flex:1}
.search-btn{padding:.75rem 2rem;background:#00b4db;color:#fff;border:none;border-radius:100%;font-weight:700;cursor:pointer;font-size:1rem}

/* Buttons */
.btn{display:inline-block;padding:.65rem 1.25rem;border-radius:100%;font-weight:600;text-decoration:none;cursor:pointer;transition:opacity .15s,transform .1s;border:1px solid transparent;font-size:.9rem}
.btn:hover{opacity:.88;transform:translateY(-1px)}
.btn-primary{background:#00b4db;color:#fff;border-color:#00b4db}
.btn-block{display:block;text-align:center;margin-bottom:.5rem}
.btn-call{background:#16a34a;color:#fff}
.btn-web{background:#2563eb;color:#fff}
.btn-action{display:inline-block;padding:.3rem .7rem;border-radius:6px;font-size:.8rem;font-weight:600;text-decoration:none;margin:.15rem}
.btn-detail{background:#f8fafc;color:#ffffff;border:1px solid #ffffff}

/* Cards */
.listing-card{background:#fff;border:1px solid #ffffff;border-radius:100%;padding:1.25rem;position:relative;transition:box-shadow .2s}
.listing-card:hover{box-shadow:0 2px 8px rgba(0,0,0,.08)}
.listing-featured{border-color:#f59e0b}
.card-logo{width:60px;height:60px;object-fit:contain;border-radius:6px;margin-bottom:.75rem}
.card-title{font-size:1.05rem;font-weight:700;margin:0 0 .3rem}
.card-category{font-size:.78rem;background:#f1f5f9;color:#475569;padding:.2rem .5rem;border-radius:4px;display:inline-block;margin-bottom:.4rem}
.card-desc{font-size:.875rem;color:#64748b;margin:.3rem 0}
.card-address{font-size:.82rem;color:#64748b;font-style:normal;margin:.3rem 0}
.card-rating{display:flex;align-items:center;gap:.35rem;font-size:.875rem;margin:.3rem 0}
.card-actions{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.75rem}
.verified-badge{position:absolute;top:.6rem;right:.6rem;background:#dcfce7;color:#15803d;font-size:.72rem;padding:.15rem .4rem;border-radius:4px;font-weight:700}
.featured-badge{position:absolute;top:2rem;right:.6rem;background:#fef3c7;color:#92400e;font-size:.72rem;padding:.15rem .4rem;border-radius:4px;font-weight:700}
.stars{color:#f59e0b;letter-spacing:-.05em}

.category-card{background:#fff;border:1px solid #ffffff;border-radius:100%;padding:1.5rem;text-align:center;transition:box-shadow .2s,transform .2s}
.category-card:hover{box-shadow:0 2px 8px rgba(0,0,0,.08);transform:translateY(-2px)}
.category-card-link{text-decoration:none;color:inherit;display:block}
.category-icon{font-size:2rem;display:block;margin-bottom:.75rem}
.category-name{font-weight:700;color:#ffffff;margin:.5rem 0 .25rem}
.category-desc{font-size:.85rem;color:#64748b;margin:0}

.testimonial-card{background:#f8fafc;border:1px solid #ffffff;border-radius:100%;padding:1.5rem}
.testimonial-stars{color:#f59e0b;font-size:1.1rem;margin-bottom:.5rem}
.testimonial-text{font-style:italic;margin:0 0 1rem;line-height:1.6;color:#ffffff}
.testimonial-author{display:flex;align-items:center;gap:.75rem}
.testimonial-avatar{border-radius:50%;object-fit:cover}

/* Grids */
.listings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}
.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}

/* Layout */
.page-layout-with-sidebar{display:grid;grid-template-columns:260px 1fr;gap:2rem;align-items:start}
.business-detail-layout{display:grid;grid-template-columns:1fr 300px;gap:2rem;align-items:start}

/* Sidebar */
.sidebar{background:#f8fafc;border:1px solid #ffffff;border-radius:100%;padding:1.25rem}
.widget-title{font-size:1rem;font-weight:700;margin:0 0 .75rem;padding-bottom:.5rem;border-bottom:2px solid #00b4db}
.category-list{list-style:none;margin:0;padding:0}
.category-list a{display:block;padding:.4rem 0;color:#ffffff;border-bottom:1px solid #ffffff;font-size:.9rem}
.category-list a:hover{color:#00b4db}

/* CTA */
.cta-section{background:#00b4db;color:#fff;padding:3rem 1rem;text-align:center}
.cta-title{font-size:2rem;font-weight:800;margin:0 0 .75rem}
.cta-text{font-size:1.05rem;opacity:.9;margin:0 0 1.5rem;max-width:60ch;margin-left:auto;margin-right:auto}
.cta-section .btn-primary{background:#fff;color:#00b4db}

/* Breadcrumb */
.breadcrumb{margin-bottom:1.25rem}
.breadcrumb ol{list-style:none;margin:0;padding:0;display:flex;gap:.5rem;flex-wrap:wrap;font-size:.85rem;color:#64748b}
.breadcrumb a{color:#00b4db;text-decoration:none}
.breadcrumb a:hover{text-decoration:underline}

/* Pagination */
.pagination{display:flex;gap:.4rem;flex-wrap:wrap;margin:2rem 0;justify-content:center}
.page-link{padding:.5rem .85rem;border:1px solid #ffffff;border-radius:6px;color:#ffffff;font-size:.9rem;font-weight:600;text-decoration:none;transition:background .15s}
.page-link:hover,.page-link.current{background:#00b4db;color:#fff;border-color:#00b4db}

/* Footer */
.site-footer{background:#1e293b;color:#cbd5e1;padding:3rem 1rem 1.5rem}
.footer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;margin-bottom:2rem}
.footer-col h3,.footer-col h4{color:#fff;font-size:1rem;margin:0 0 .75rem}
.footer-col ul{list-style:none;margin:0;padding:0}
.footer-col ul li{margin-bottom:.4rem}
.footer-col a{color:#94a3b8;text-decoration:none;font-size:.9rem}
.footer-col a:hover{color:#fff}
.footer-bottom{border-top:1px solid #334155;padding-top:1rem;font-size:.85rem;color:#64748b;text-align:center}

/* Business detail */
.business-header{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.5rem}
.business-logo{width:80px;height:80px;object-fit:contain;border-radius:100%;border:1px solid #ffffff}
.business-description{line-height:1.7;margin-bottom:1.5rem}
.contact-card,.claim-box{background:#f8fafc;border:1px solid #ffffff;border-radius:100%;padding:1.25rem;margin-bottom:1rem}
.biz-address{font-style:normal;font-size:.9rem;color:#64748b;margin-top:.75rem}
.rating-row{display:flex;align-items:center;gap:.4rem;margin-top:.4rem;font-size:.9rem}

/* Post cards */
.post-card{background:#fff;border:1px solid #ffffff;border-radius:100%;overflow:hidden}
.post-card img{width:100%;height:180px;object-fit:cover}
.post-body{padding:1.25rem}
.post-title{font-size:1.05rem;margin:0 0 .4rem}
.post-title a{color:#ffffff}
.post-meta{font-size:.82rem;color:#64748b;margin:0 0 .5rem}
.post-excerpt{font-size:.875rem;color:#64748b;margin:0 0 .75rem}
.read-more{font-weight:600;color:#00b4db;font-size:.88rem}

/* Mobile menu */
.mobile-menu-overlay{position:fixed;inset:0;background:rgba(0,0,0,.95);z-index:1000;display:flex;flex-direction:column;padding:2rem;transform:translateX(-100%);transition:transform .3s}
.mobile-menu-overlay.is-open{transform:translateX(0)}
.mobile-menu-close{background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;align-self:flex-end;margin-bottom:1rem}
.mobile-nav-menu{list-style:none;margin:0;padding:0}
.mobile-nav-menu li{border-bottom:1px solid rgba(255,255,255,.1);padding:.75rem 0}
.mobile-nav-menu a{color:#fff;font-size:1.1rem;font-weight:600;text-decoration:none}

/* No results */
.no-results{text-align:center;padding:3rem 1rem;color:#64748b}

@media(max-width:1024px){
  .page-layout-with-sidebar,.business-detail-layout{grid-template-columns:1fr}
  .sidebar{display:none}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .menu-toggle{display:flex}
  .main-navigation{display:none}
}
@media(max-width:640px){
  .footer-grid{grid-template-columns:1fr}
  .search-form .search-fields{flex-direction:column}
  .search-input,.search-btn{width:100%}
  .listings-grid{grid-template-columns:1fr}
}