/* ─── Reset & Base ───────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f1f1f1;--white:#fff;--black:#111;
  --gray:#888;--border:#e4e4e4;--radius:50px;
  --card-r:18px;--shadow:0 2px 16px rgba(0,0,0,.07);
}
html{font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--black);min-height:100vh;display:flex;flex-direction:column;line-height:1.5}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}

/* ─── Nav ────────────────────────────────────────────────────── */
.nav{background:var(--white);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:200}
.nav-wrap{max-width:1280px;margin:0 auto;padding:0 28px;height:64px;display:flex;align-items:center;gap:24px}
.logo{display:flex;align-items:center;gap:9px;font-weight:800;font-size:1.1rem;color:var(--black);flex-shrink:0}
.logo-box{width:34px;height:34px;background:var(--black);border-radius:9px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.85rem}
.nav-links{flex:1;display:flex;gap:4px}
.nav-a{padding:7px 13px;border-radius:9px;font-size:.88rem;font-weight:500;color:var(--gray);transition:all .15s}
.nav-a:hover,.nav-a.active{color:var(--black);background:var(--bg)}

/* ─── Buttons ────────────────────────────────────────────────── */
.btn-pill{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 20px;border-radius:var(--radius);font-size:.875rem;font-weight:600;cursor:pointer;border:none;transition:all .15s;white-space:nowrap}
.btn-dark{background:var(--black);color:#fff}
.btn-dark:hover{opacity:.82;color:#fff}
.btn-blue{background:#1a73e8;color:#fff}
.btn-blue:hover{background:#1557b0;color:#fff}
.btn-outline{background:var(--white);color:var(--black);border:1.5px solid var(--border)}
.btn-outline:hover{background:var(--black);color:#fff;border-color:var(--black)}
.btn-ghost{background:var(--bg);color:var(--black);border:1.5px solid var(--border)}
.btn-ghost:hover{background:var(--black);color:#fff;border-color:var(--black)}
.btn-sm{padding:6px 14px;font-size:.8rem}
.btn-full{width:100%}

/* ─── Hero ───────────────────────────────────────────────────── */
.hero{min-height:calc(100vh - 64px - 54px);display:flex;align-items:center;justify-content:center;padding:60px 24px}
.hero-wrap{max-width:700px;width:100%;text-align:center}
.hero-tag{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;font-weight:600;color:var(--gray);background:var(--white);border:1.5px solid var(--border);padding:5px 14px;border-radius:var(--radius);margin-bottom:28px}
.hero-h1{font-size:clamp(2.6rem,6vw,4.8rem);font-weight:900;letter-spacing:-2.5px;line-height:1.08;color:var(--black);margin-bottom:18px}
.hero-h1 em{color:#aaa;font-style:italic}
.hero-sub{font-size:1rem;color:var(--gray);line-height:1.7;max-width:540px;margin:0 auto 32px}
.hero-count{font-size:.82rem;color:#bbb;margin-top:14px}
.hero-empty{margin-top:28px;font-size:.9rem;color:var(--gray)}
.hero-empty a{color:var(--black);font-weight:600;border-bottom:1px solid var(--black)}

/* ─── Search Box ─────────────────────────────────────────────── */
.search-form{width:100%;max-width:660px;margin:0 auto}
.search-box{display:flex;align-items:center;background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);padding:6px 6px 6px 20px;box-shadow:var(--shadow);transition:border-color .2s,box-shadow .2s}
.search-box:focus-within{border-color:#ccc;box-shadow:0 4px 24px rgba(0,0,0,.11)}
.search-ico{color:#ccc;font-size:.9rem;flex-shrink:0}
.search-in{flex:1;border:none;outline:none;font-size:.95rem;font-family:inherit;padding:9px 14px;background:transparent;color:var(--black)}
.search-in::placeholder{color:#ccc}
.search-btn{background:var(--black);color:#fff;border:none;border-radius:var(--radius);padding:11px 26px;font-size:.9rem;font-weight:700;cursor:pointer;font-family:inherit;transition:opacity .15s;white-space:nowrap}
.search-btn:hover{opacity:.8}

/* ─── Category Chips ─────────────────────────────────────────── */
.cat-row{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-top:26px}
.cat-chip{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);padding:6px 16px;font-size:.8rem;font-weight:500;color:var(--gray);transition:all .15s;text-transform:capitalize}
.cat-chip:hover{background:var(--black);color:#fff;border-color:var(--black)}

/* ─── Results Bar ────────────────────────────────────────────── */
.results-bar{background:var(--white);border-bottom:1px solid var(--border);padding:14px 0}
.results-bar-wrap{max-width:1280px;margin:0 auto;padding:0 28px;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.search-form-sm{flex:1;min-width:220px}
.search-box-sm{display:flex;align-items:center;gap:8px;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);padding:6px 6px 6px 16px}
.search-box-sm i{color:#ccc;font-size:.85rem}
.search-box-sm input{flex:1;border:none;outline:none;font-size:.88rem;font-family:inherit;background:transparent;padding:5px 6px}
.search-box-sm button{background:var(--black);color:#fff;border:none;border-radius:var(--radius);padding:7px 16px;font-size:.82rem;font-weight:600;cursor:pointer;font-family:inherit}
.results-info{display:flex;align-items:center;gap:14px;font-size:.88rem;color:var(--gray);white-space:nowrap}
.clear-link{color:var(--gray);padding:5px 12px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:.8rem;font-weight:500;transition:all .15s}
.clear-link:hover{background:var(--black);color:#fff;border-color:var(--black)}

/* ─── Main Grid ──────────────────────────────────────────────── */
.main{flex:1;max-width:1280px;margin:40px auto;width:100%;padding:0 28px}

/* ─── Cards ──────────────────────────────────────────────────── */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}
.card{display:flex;flex-direction:column;background:var(--white);border:1.5px solid var(--border);border-radius:var(--card-r);padding:22px;text-decoration:none;color:var(--black);transition:border-color .15s,box-shadow .15s,transform .15s;cursor:pointer}
.card:hover{border-color:#ccc;box-shadow:0 6px 28px rgba(0,0,0,.1);transform:translateY(-3px)}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.card-icon{width:44px;height:44px;background:var(--bg);border-radius:11px;display:flex;align-items:center;justify-content:center;color:#777;font-size:1.05rem;transition:all .15s}
.card:hover .card-icon{background:var(--black);color:#fff}
.card-cat{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:#999;background:var(--bg);border-radius:20px;padding:3px 10px}
.card-name{font-size:1rem;font-weight:700;margin-bottom:8px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-addr,.card-web{font-size:.8rem;color:var(--gray);margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-addr i,.card-web i{margin-right:4px;font-size:.72rem}
.card-web{color:#555}
.card-foot{margin-top:auto;padding-top:16px;font-size:.82rem;font-weight:600;color:var(--gray);display:flex;align-items:center;gap:6px;transition:color .15s}
.card:hover .card-foot{color:var(--black)}

/* ─── Empty State ────────────────────────────────────────────── */
.empty{text-align:center;padding:90px 24px;color:var(--gray)}
.empty-ico{font-size:3.5rem;margin-bottom:20px}
.empty h3{font-size:1.4rem;color:var(--black);margin-bottom:8px}
.empty p{font-size:.9rem;margin-bottom:24px}

/* ─── Pagination ─────────────────────────────────────────────── */
.pager{display:flex;justify-content:center;gap:6px;margin-top:52px}
.pager-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--border);border-radius:11px;font-size:.88rem;color:var(--gray);background:var(--white);text-decoration:none;transition:all .15s;font-family:inherit;cursor:pointer}
.pager-btn:hover,.pager-btn.active{background:var(--black);color:#fff;border-color:var(--black)}

/* ─── Footer ─────────────────────────────────────────────────── */
.footer{margin-top:auto;background:var(--white);border-top:1px solid var(--border);height:54px}
.footer-wrap{max-width:1280px;margin:0 auto;padding:0 28px;height:100%;display:flex;align-items:center;justify-content:space-between;font-size:.8rem;color:var(--gray)}
.footer-logo{font-weight:700;color:var(--black)}
.footer-logo i{margin-right:5px}
.footer a{color:var(--gray)}

/* ─── Utilities ──────────────────────────────────────────────── */
.center-body{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}
.overflow-hidden{overflow:hidden}

/* ─── Login ──────────────────────────────────────────────────── */
.login-card{background:var(--white);border:1.5px solid var(--border);border-radius:20px;padding:48px 40px;width:360px;text-align:center;box-shadow:var(--shadow)}
.login-logo{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:28px}
.login-logo h2{font-size:1.3rem;font-weight:800}
.login-in{width:100%;border:1.5px solid var(--border);border-radius:var(--radius);padding:13px 20px;font-size:.95rem;font-family:inherit;outline:none;text-align:center;transition:border-color .2s}
.login-in:focus{border-color:var(--black)}
.login-back{display:block;margin-top:18px;font-size:.82rem;color:var(--gray)}

/* ─── Alerts ─────────────────────────────────────────────────── */
.alert-ok{background:#f0fdf4;border:1px solid #86efac;color:#166534;border-radius:12px;padding:14px 20px;font-size:.9rem;margin-bottom:20px}
.alert-err{background:#fef2f2;border:1px solid #fca5a5;color:#991b1b;border-radius:12px;padding:14px 20px;font-size:.9rem;margin-bottom:20px}

/* ─── Responsive ─────────────────────────────────────────────── */
@media(max-width:640px){
  .nav-links{display:none}
  .hero{padding:40px 18px;min-height:auto}
  .hero-h1{font-size:2.4rem;letter-spacing:-1.5px}
  .main{padding:0 16px;margin:28px auto}
  .grid{grid-template-columns:1fr}
  .results-bar-wrap{flex-direction:column;align-items:stretch}
  .footer-wrap span:last-child{display:none}
}
