
:root{
  --primary:#1a4a3a;--primary-hover:#102d24;
  --accent:#00A878;--accent-hover:#007d5a;--accent-text:#1a4a3a;
  --text:#1a1a2e;--text-muted:#5a6476;
  --bg:#f8f9fc;--card-bg:white;--border:#e2e8f0;
  --radius:10px;--shadow:0 2px 16px rgba(0,0,0,.09);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Segoe UI',system-ui,sans-serif;color:var(--text);background:var(--bg);line-height:1.6;}
.container{max-width:1140px;margin:0 auto;padding:0 1.25rem;}
a{color:inherit;text-decoration:none;}
.site-header{background:white;border-bottom:3px solid var(--accent);box-shadow:var(--shadow);position:sticky;top:0;z-index:100;}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:.65rem 1.25rem;max-width:1140px;margin:0 auto;}
.site-logo{font-size:1.25rem;font-weight:900;color:var(--primary);}
.site-logo .flash{color:var(--accent);font-size:1.4rem;}
nav ul{display:flex;list-style:none;gap:1.4rem;}
nav a{font-size:.88rem;font-weight:600;color:var(--text-muted);}
nav a:hover{color:var(--primary);}
.btn{display:inline-flex;align-items:center;gap:.35rem;padding:.6rem 1.25rem;border-radius:8px;font-weight:700;font-size:.88rem;transition:all .2s;border:none;cursor:pointer;}
.btn-primary{background:var(--primary);color:white;}
.btn-primary:hover{background:var(--primary-hover);}
.btn-accent{background:var(--accent);color:white;}
.btn-accent:hover{background:var(--accent-hover);}
.btn-wa{background:#25d366;color:white;}
.btn-outline{background:transparent;color:var(--primary);border:2px solid var(--primary);}
.btn-sm{padding:.4rem .85rem;font-size:.8rem;}
.btn-lg{padding:.85rem 1.65rem;font-size:.95rem;}

/* HERO */
.hero{background:linear-gradient(135deg,#1a4a3a 0%,#2a6e55 60%,#102d24 100%);color:white;padding:4rem 0 3rem;}
.hero h1{font-size:clamp(1.8rem,3.5vw,2.7rem);font-weight:900;line-height:1.2;margin-bottom:.5rem;}
.hero h1 em{color:var(--accent);font-style:normal;}
.hero-sub{font-size:1rem;opacity:.9;max-width:560px;margin-bottom:1.5rem;}
.hero-badges{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:1.5rem;}
.hero-badge{background:rgba(0,168,120,.15);border:1px solid rgba(0,168,120,.4);color:#a8ffdf;border-radius:999px;padding:.25rem .75rem;font-size:.78rem;font-weight:700;}
.search-bar{display:flex;gap:.5rem;max-width:520px;margin-bottom:1.75rem;}
.search-bar input{flex:1;padding:.75rem 1rem;border-radius:8px;border:none;font-size:.95rem;outline:none;}
.search-bar button{background:var(--accent);color:white;border:none;padding:.75rem 1.3rem;border-radius:8px;font-weight:700;cursor:pointer;}

/* STATS BAR */
.stats-bar{background:var(--accent);padding:.65rem 0;}
.stats-inner{display:flex;justify-content:center;gap:2.5rem;flex-wrap:wrap;}
.stat{text-align:center;font-size:.84rem;font-weight:700;color:white;}

/* CARDS */
.directory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.1rem;margin-top:1.5rem;}
.biz-card{background:white;border:1.5px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow);transition:transform .18s,border-color .18s;}
.biz-card:hover{transform:translateY(-3px);border-color:var(--accent);}
.biz-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.65rem;}
.biz-name{font-size:.97rem;font-weight:800;color:var(--primary);}
.biz-badge{font-size:.7rem;font-weight:700;border-radius:999px;padding:.2rem .6rem;white-space:nowrap;}
.badge-verified{background:#e8f5e9;color:#2e7d32;}
.badge-featured{background:#fff3e0;color:#e65100;}
.biz-cats{font-size:.76rem;color:var(--text-muted);margin-bottom:.4rem;}
.biz-address{font-size:.82rem;color:var(--text-muted);margin-bottom:.5rem;}
.biz-stars{color:#f59e0b;font-size:.85rem;}
.biz-footer{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border);}

/* PAGE LAYOUT */
.page-layout{display:grid;grid-template-columns:2fr 1fr;gap:2rem;margin-top:1.5rem;}
.page-content{}
.page-sidebar{}
.sidebar-card{background:white;border:1.5px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow);margin-bottom:1.1rem;}
.contact-box{background:linear-gradient(135deg,#1a4a3a,#2a6e55);color:white;border-radius:var(--radius);padding:1.5rem;margin-bottom:1.1rem;}
.contact-box h3{color:var(--accent);font-size:.95rem;margin-bottom:.75rem;}
.contact-row{display:flex;gap:.65rem;align-items:flex-start;padding:.55rem 0;border-bottom:1px solid rgba(255,255,255,.1);}
.contact-row:last-child{border-bottom:none;}
.contact-icon{font-size:1.1rem;}

/* BREADCRUMB */
.breadcrumb{font-size:.82rem;color:var(--text-muted);margin-bottom:1rem;}
.breadcrumb a{color:var(--text-muted);}
.breadcrumb .sep{margin:0 .4rem;}

/* FAQ */
.faq-section{margin-top:2rem;}
.faq-item{border:1.5px solid var(--border);border-radius:var(--radius);margin-bottom:.55rem;background:white;}
.faq-question{width:100%;background:none;border:none;padding:.9rem 1.1rem;text-align:left;font-size:.9rem;font-weight:700;color:var(--primary);cursor:pointer;display:flex;justify-content:space-between;}
.faq-answer{padding:0 1.1rem .9rem;font-size:.86rem;color:var(--text-muted);display:none;}
.faq-answer.open{display:block;}

/* INTERNAL LINKS BOX */
.internal-links-box{background:#edfaf5;border-left:4px solid var(--primary);border-radius:0 var(--radius) var(--radius) 0;padding:1rem 1.25rem;margin-top:1.75rem;}
.internal-links-box h3{font-size:.88rem;font-weight:800;color:var(--primary);margin-bottom:.5rem;}
.internal-links-box ul{list-style:none;display:flex;flex-direction:column;gap:.35rem;}
.internal-links-box a{font-size:.85rem;color:var(--primary);font-weight:600;}

/* BEST-OF TABLE */
.best-of-table{width:100%;border-collapse:collapse;margin-top:1rem;font-size:.88rem;}
.best-of-table th{background:var(--primary);color:white;padding:.65rem .75rem;text-align:left;font-size:.78rem;}
.best-of-table td{padding:.6rem .75rem;border-bottom:1px solid var(--border);}
.best-of-table tr:nth-child(even) td{background:#f8f9fc;}
.rank-num{font-weight:900;font-size:1rem;}
.rank-num.gold{color:#007d5a;}
.rank-num.silver{color:#607d8b;}
.rank-num.bronze{color:#8d6e63;}

/* SECTION */
.section{padding:3rem 0;}
.section-title{font-size:1.5rem;font-weight:900;color:var(--primary);margin-bottom:.3rem;}
.section-sub{color:var(--text-muted);font-size:.9rem;margin-bottom:1.75rem;}

/* FOOTER */
.site-footer{background:#102d24;color:rgba(255,255,255,.8);padding:2.5rem 0 1rem;}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:1.5rem;margin-bottom:1.75rem;}
.footer-col h4{color:var(--accent);font-size:.88rem;font-weight:800;margin-bottom:.65rem;}
.footer-col ul{list-style:none;}
.footer-col li{padding:.2rem 0;font-size:.83rem;}
.footer-col a:hover{color:white;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:.85rem;font-size:.8rem;color:rgba(255,255,255,.45);text-align:center;}

/* STICKY MOBILE */
.sticky-cta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:999;background:var(--primary);padding:.55rem 1rem;gap:.65rem;box-shadow:0 -3px 12px rgba(0,0,0,.3);}
@media(max-width:768px){.sticky-cta{display:flex;justify-content:center;} nav ul{display:none;} .page-layout{grid-template-columns:1fr;} .directory-grid{grid-template-columns:1fr;}}
