/* =====================================================================
   WorldRankList — stylesheet
   Brand: green (#16a34a family), Plus Jakarta Sans, mobile-app aesthetic
   ===================================================================== */

:root{
  --green:        #16a34a;
  --green-dark:   #15803d;
  --green-deep:   #14532d;
  --green-tint:   #f0fdf4;
  --green-line:   #dcfce7;
  --gold:         #f59e0b;
  --ink:          #0f172a;
  --muted:        #64748b;
  --line:         #e2e8f0;
  --bg:           #f8fafc;
  --white:        #ffffff;
  --red:          #dc2626;
  --radius:       14px;
  --radius-sm:    10px;
  --shadow:       0 1px 3px rgba(15,23,42,.06), 0 6px 24px rgba(15,23,42,.05);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:1080px;margin:0 auto;padding:0 20px}

/* ---------- top bar ---------- */
.nav{
  background:var(--white);
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:50;
}
.nav .container{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px}
.brand .logo{
  width:32px;height:32px;border-radius:9px;background:var(--green);
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;
}
.nav-links{display:flex;align-items:center;gap:22px;font-size:14px;color:var(--muted);font-weight:500}
.nav-links a:hover{color:var(--green-dark)}
.btn{
  display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;
  padding:10px 18px;border-radius:var(--radius-sm);border:0;cursor:pointer;
  transition:transform .12s ease, background .15s ease;font-family:inherit;
}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--green);color:#fff}
.btn-primary:hover{background:var(--green-dark)}
.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--green);color:var(--green-dark)}

/* ---------- hero ---------- */
.hero{padding:64px 0 48px;text-align:center}
.pill{
  display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;
  color:var(--green-deep);background:var(--green-tint);border:1px solid var(--green-line);
  padding:6px 14px;border-radius:30px;margin-bottom:20px;
}
.hero h1{font-size:42px;font-weight:800;letter-spacing:-.02em;line-height:1.1;max-width:680px;margin:0 auto}
.hero p{color:var(--muted);font-size:17px;max-width:560px;margin:18px auto 30px}

/* ---------- search bar ---------- */
.searchbar{
  display:flex;gap:8px;max-width:620px;margin:0 auto;background:var(--white);
  border:1px solid var(--line);border-radius:var(--radius);padding:8px;box-shadow:var(--shadow);
}
.searchbar .field{flex:1;display:flex;align-items:center;gap:8px;padding:0 12px}
.searchbar select,.searchbar input{
  border:0;font-family:inherit;font-size:15px;color:var(--ink);width:100%;background:transparent;outline:none;
}
.searchbar .divider{width:1px;background:var(--line)}
.hero-stats{display:flex;justify-content:center;gap:28px;margin-top:26px;font-size:14px;color:var(--muted)}
.hero-stats b{color:var(--ink);font-weight:700}

/* ---------- section ---------- */
.section{padding:40px 0}
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.section-head h2{font-size:24px;font-weight:800;letter-spacing:-.01em}
.section-head .sub{color:var(--muted);font-size:14px}

/* ---------- leaderboard ---------- */
.board{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.board-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line)}
.board-head h3{font-size:16px;font-weight:700}
.board-head .meta{font-size:12px;color:var(--muted)}

.sponsored-tag{font-size:11px;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:.04em}
.row-sponsored{background:#fffbeb}

.rank-row{display:flex;align-items:center;gap:16px;padding:16px 20px;border-bottom:1px solid var(--line)}
.rank-row:last-child{border-bottom:0}
.rank-badge{
  width:34px;height:34px;border-radius:9px;flex-shrink:0;color:#fff;font-weight:700;
  display:flex;align-items:center;justify-content:center;font-size:15px;background:var(--muted);
}
.rank-badge.r1{background:var(--green)}
.rank-badge.r2{background:#475569}
.rank-badge.r3{background:#94a3b8}
.rank-body{flex:1;min-width:0}
.rank-name{display:flex;align-items:center;gap:7px;font-weight:700;font-size:16px}
.verified{color:var(--green);font-size:16px}
.rank-meta{font-size:13px;color:var(--muted);margin-top:2px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.star{color:var(--gold)}
.move{font-weight:600;font-size:12px}
.move.up{color:var(--green)}
.move.down{color:var(--red)}
.move.flat{color:var(--muted)}

.score-block{text-align:right;flex-shrink:0;width:96px}
.score-num{font-size:18px;font-weight:800}
.score-num span{font-size:12px;color:var(--muted);font-weight:600}
.score-bar{height:5px;background:var(--line);border-radius:3px;margin-top:5px;overflow:hidden}
.score-bar i{display:block;height:100%;background:var(--green);border-radius:3px}

/* ---------- how it works ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.step{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:24px;text-align:center}
.step .ic{
  width:48px;height:48px;border-radius:12px;background:var(--green-tint);color:var(--green-dark);
  display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto 14px;
}
.step h4{font-size:16px;font-weight:700;margin-bottom:6px}
.step p{font-size:14px;color:var(--muted)}

/* ---------- categories ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.cat{
  display:flex;align-items:center;gap:12px;background:var(--white);border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:16px 18px;font-weight:600;font-size:15px;transition:all .15s ease;
}
.cat:hover{border-color:var(--green);color:var(--green-dark);transform:translateY(-2px)}
.cat .ic{color:var(--green);font-size:22px}

/* ---------- listing page ---------- */
.crumbs{font-size:13px;color:var(--muted);margin-bottom:14px}
.crumbs a{color:var(--green-dark);font-weight:600}
.crumbs span{color:var(--ink)}
.action-bar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:14px 18px;box-shadow:var(--shadow);margin-top:16px}
.action-bar .btn.liked{border-color:var(--green);color:var(--green-dark);background:var(--green-tint)}
.action-bar .btn.liked .ti-heart-filled{color:var(--red)}
.profile-head{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);display:flex;gap:24px;flex-wrap:wrap;align-items:center}
.profile-rank{transition:transform .12s ease}
a.profile-rank:hover{transform:translateY(-2px)}
.profile-rank{text-align:center;padding:0 24px;border-right:1px solid var(--line)}
.profile-rank .big{font-size:46px;font-weight:800;color:var(--green);line-height:1}
.profile-rank .lbl{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.breakdown{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:8px}
.bd-item .bd-top{display:flex;justify-content:space-between;font-size:13px;font-weight:600;margin-bottom:5px}
.bd-bar{height:7px;background:var(--line);border-radius:4px;overflow:hidden}
.bd-bar i{display:block;height:100%;background:var(--green);border-radius:4px}

.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}

/* about / details block */
.detail-grid{display:flex;flex-wrap:wrap;gap:14px 32px}
.detail{display:flex;flex-direction:column;gap:2px;font-size:14px}
.dl{font-size:12px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.03em}
.tags{display:flex;flex-wrap:wrap;gap:8px}
.tag{background:var(--green-tint);color:var(--green-deep);border:1px solid var(--green-line);font-size:13px;font-weight:600;padding:5px 12px;border-radius:20px}
.social-row{display:flex;gap:10px;flex-wrap:wrap}
.social{width:40px;height:40px;border-radius:10px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--ink);transition:all .15s ease}
.social:hover{border-color:var(--green);color:var(--green-dark);transform:translateY(-2px)}

/* ===================================================================
   Listing landing page (.lp-*) — hero + score gauge + sticky sidebar
   =================================================================== */
.lp{max-width:1120px;margin:0 auto;padding:24px 20px 0}
.lp-crumbs{font-size:13px;color:var(--muted);margin-bottom:16px}
.lp-crumbs a{color:var(--green-dark);font-weight:600}
.lp-crumbs a:hover{text-decoration:underline}
.lp-crumbs span{color:var(--ink)}

.lp-owner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;
  background:var(--green-tint);border:1px solid var(--green-line);color:var(--green-deep);
  border-radius:var(--radius);padding:12px 18px;margin-bottom:16px;font-weight:600;font-size:14px}

/* hero */
.lp-hero{position:relative;overflow:hidden;border-radius:24px;color:#fff;padding:34px;
  background:linear-gradient(135deg,#0f3d22 0%,#15803d 55%,#16a34a 100%);
  box-shadow:0 24px 60px rgba(16,163,74,.30)}
.lp-hero::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(820px 360px at 108% -30%, rgba(255,255,255,.20), transparent 60%),
             radial-gradient(620px 320px at -10% 120%, rgba(255,255,255,.10), transparent 55%)}
.lp-hero-grid{position:relative;display:grid;grid-template-columns:1fr auto;gap:30px;align-items:center}
.lp-id{display:flex;gap:18px;align-items:flex-start;min-width:0}
.lp-logo{width:74px;height:74px;border-radius:18px;flex-shrink:0;overflow:hidden;
  background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.28);
  display:flex;align-items:center;justify-content:center;font-size:33px;font-weight:800;color:#fff}
.lp-logo img{width:100%;height:100%;object-fit:cover}
.lp-name{font-size:31px;font-weight:800;line-height:1.12;letter-spacing:-.02em;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.lp-name .verified{color:#bbf7d0;font-size:24px}
.lp-meta{display:flex;gap:8px 18px;flex-wrap:wrap;align-items:center;margin-top:12px;font-size:14px;color:#dcfce7;font-weight:500}
.lp-meta .star{color:#fde68a}
.lp-meta a{color:#fff;text-decoration:underline;text-underline-offset:2px}
.lp-meta .move.up{color:#bbf7d0}
.lp-meta .move.down{color:#fecaca}
.lp-meta .move.flat{color:#cbe9d3}
.lp-addr{margin-top:8px;font-size:14px;color:#bbf7d0}
.lp-desc{margin-top:12px;max-width:580px;font-size:15px;line-height:1.6;color:#eafff0}

/* score gauge card */
.lp-score{background:#fff;color:var(--ink);border-radius:20px;padding:22px 28px;text-align:center;
  box-shadow:0 14px 36px rgba(0,0,0,.20);min-width:236px}
.lp-gauge{position:relative;width:152px;height:152px;margin:0 auto}
.lp-gauge svg{transform:rotate(-90deg)}
.lp-gauge .ring-prog{transition:stroke-dashoffset 1s ease}
.lp-gauge .gv{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.lp-gauge .num{font-size:40px;font-weight:800;line-height:1;color:var(--green-dark)}
.lp-gauge .den{font-size:12px;color:var(--muted);font-weight:700;margin-top:3px}
.lp-gauge .cap{font-size:10px;letter-spacing:.16em;color:var(--muted);font-weight:800;margin-top:5px}
.lp-rank{margin-top:18px;display:flex;align-items:center;justify-content:center;gap:12px}
.lp-rankbadge{display:inline-flex;align-items:center;gap:7px;font-size:24px;font-weight:800;color:#fff;
  background:var(--green);border-radius:14px;padding:8px 16px;box-shadow:0 6px 16px rgba(0,0,0,.14)}
.lp-rankbadge.top1{background:linear-gradient(135deg,#fbbf24,#d97706)}
.lp-rankbadge.top2{background:linear-gradient(135deg,#cbd5e1,#64748b)}
.lp-rankbadge.top3{background:linear-gradient(135deg,#e0a36a,#b45309)}
.lp-rankmeta{font-size:12px;color:var(--muted);text-align:left;line-height:1.4}
.lp-rankmeta a{color:var(--green-dark);font-weight:700}

/* action bar */
.lp-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin:18px 0 22px}
.lp-actions .btn{box-shadow:var(--shadow)}
.lp-actions .btn.liked{border-color:var(--green);color:var(--green-dark);background:var(--green-tint)}
.lp-actions .btn.liked .ti-heart-filled{color:var(--red)}

/* body layout */
.lp-main{display:grid;grid-template-columns:1fr 360px;gap:22px;align-items:start;padding-bottom:10px}
.lp-content{display:flex;flex-direction:column;gap:20px;min-width:0}
.lp-aside{position:sticky;top:84px;display:flex;flex-direction:column;gap:18px}
.lp-trust{background:linear-gradient(135deg,var(--green-tint),#fff);border:1px solid var(--green-line);
  border-radius:var(--radius);padding:18px;display:flex;gap:12px;align-items:flex-start}
.lp-trust .ic{color:var(--green);font-size:24px;flex-shrink:0}
.lp-trust b{display:block;font-size:14px;margin-bottom:2px}
.lp-trust p{font-size:13px;color:var(--muted);line-height:1.5}

@media(max-width:920px){
  .lp-hero-grid{grid-template-columns:1fr;gap:24px}
  .lp-score{justify-self:start;width:100%;max-width:340px}
  .lp-main{grid-template-columns:1fr}
  .lp-aside{position:static}
}
@media(max-width:560px){
  .lp-hero{padding:24px 20px;border-radius:18px}
  .lp-name{font-size:25px}
  .lp-logo{width:60px;height:60px;font-size:27px}
  .lp-score{padding:20px}
}
.review{border-bottom:1px solid var(--line);padding:14px 0}
.review:last-child{border-bottom:0}
.review .rh{display:flex;justify-content:space-between;font-weight:600;font-size:14px}

/* star rating picker (CSS-only, reversed row so hover fills left-to-right) */
.star-pick{display:inline-flex;flex-direction:row-reverse;gap:4px;font-size:26px;line-height:1}
.star-pick input{display:none}
.star-pick label{color:var(--line);cursor:pointer;transition:color .1s ease}
.star-pick input:checked ~ label,
.star-pick label:hover,
.star-pick label:hover ~ label{color:var(--gold)}

/* ---------- forms ---------- */
.form-group{margin-bottom:18px}
.form-group label{display:block;font-weight:600;font-size:14px;margin-bottom:6px}
.form-control{
  width:100%;padding:11px 14px;border:1px solid var(--line);border-radius:var(--radius-sm);
  font-family:inherit;font-size:15px;outline:none;transition:border .15s ease;
}
.form-control:focus{border-color:var(--green);box-shadow:0 0 0 3px var(--green-tint)}
.alert{padding:13px 16px;border-radius:var(--radius-sm);font-size:14px;margin-bottom:18px}
.alert-success{background:var(--green-tint);color:var(--green-deep);border:1px solid var(--green-line)}
.alert-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}

/* ---------- footer ---------- */
.site-footer{background:var(--green-deep);color:#cdeed7;margin-top:64px;font-size:14px}
.site-footer .container{padding-top:54px;padding-bottom:0}
.ft-top{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr 1fr;gap:34px;padding-bottom:42px}
.ft-brand .ft-logo{display:inline-flex;align-items:center;gap:10px;color:#fff;font-weight:800;font-size:19px}
.ft-brand .ft-logo .logo{width:34px;height:34px;border-radius:9px;background:var(--green);display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px}
.ft-brand p{margin:16px 0 18px;max-width:330px;color:#a7d6b8;line-height:1.65;font-size:13.5px}
.ft-badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.ft-badges span{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:#bbf7d0;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.13);padding:6px 11px;border-radius:20px}
.ft-social{display:flex;gap:10px}
.ft-social a{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:rgba(255,255,255,.08);color:#dcfce7;font-size:18px;transition:.15s ease}
.ft-social a:hover{background:var(--green);color:#fff;transform:translateY(-2px)}
.ft-col h4{color:#fff;font-size:13px;font-weight:800;margin:0 0 14px;text-transform:uppercase;letter-spacing:.05em}
.ft-col a{display:block;color:#a7d6b8;font-size:13.5px;padding:6px 0;transition:.15s ease}
.ft-col a:hover{color:#fff;padding-left:3px}
.ft-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;
  border-top:1px solid rgba(255,255,255,.12);padding:20px 0;font-size:13px;color:#9fd0b1}
.ft-principle{display:inline-flex;align-items:center;gap:7px;color:#bbf7d0;font-weight:600}
.ft-mini{display:flex;gap:18px}
.ft-mini a{color:#9fd0b1}
.ft-mini a:hover{color:#fff}
@media(max-width:900px){
  .ft-top{grid-template-columns:1fr 1fr 1fr;gap:26px}
  .ft-brand{grid-column:1 / -1}
}
@media(max-width:560px){
  .ft-top{grid-template-columns:1fr 1fr}
  .ft-bottom{flex-direction:column;align-items:flex-start}
}

/* ---------- simple content pages (about/contact/legal) ---------- */
.pg-hero{position:relative;overflow:hidden;color:#fff;padding:46px 0;
  background:linear-gradient(135deg,#0c3a20 0%,#15803d 60%,#16a34a 100%)}
.pg-hero::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(700px 300px at 108% -20%, rgba(255,255,255,.16), transparent 60%)}
.pg-hero .container{position:relative}
.pg-hero .crumbs2{font-size:13px;color:#bbf7d0;margin-bottom:8px}
.pg-hero .crumbs2 a{color:#fff;font-weight:600}
.pg-hero h1{font-size:32px;font-weight:800;letter-spacing:-.02em;margin:0}
.pg-hero p{color:#dcfce7;margin-top:8px;max-width:660px;font-size:15px;line-height:1.6}
.pg-body{max-width:840px;margin:0 auto;padding:40px 20px 14px}
.pg-prose h2{font-size:20px;color:var(--ink);margin:26px 0 10px;letter-spacing:-.01em}
.pg-prose h2:first-child{margin-top:0}
.pg-prose h3{font-size:16px;color:var(--ink);margin:20px 0 8px}
.pg-prose p,.pg-prose li{color:var(--text);line-height:1.75;font-size:15px}
.pg-prose ul{padding-left:20px;margin:10px 0}
.pg-prose li{margin-bottom:6px}
.pg-prose .updated{color:var(--muted);font-size:13px;margin-bottom:18px}

/* ---------- admin ---------- */
.admin-wrap{max-width:1000px;margin:30px auto;padding:0 20px}
.table{width:100%;border-collapse:collapse;background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.table th,.table td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--line);font-size:14px;vertical-align:middle}
.table th{background:var(--green-tint);color:var(--green-deep);font-weight:700}
.badge{font-size:12px;font-weight:700;padding:3px 10px;border-radius:20px;display:inline-block}
.badge.live{background:var(--green-tint);color:var(--green-deep)}
.badge.pending{background:#fef3c7;color:#92400e}
.badge.suspended,.badge.rejected{background:#fef2f2;color:#991b1b}
.badge.published{background:var(--green-tint);color:var(--green-deep)}

/* ---------- admin console (sidebar layout) ---------- */
.admin-top{background:linear-gradient(90deg,#0c3a20 0%,#15803d 100%);color:#fff;height:58px;display:flex;align-items:center;position:sticky;top:0;z-index:50;box-shadow:0 1px 0 rgba(0,0,0,.06)}
.admin-top .container{max-width:1280px;display:flex;align-items:center;justify-content:space-between;width:100%}
.admin-top .brand{color:#fff;font-size:16px}
.admin-top .brand .logo{background:rgba(255,255,255,.16)}
.admin-top a{color:#bbf7d0;transition:color .12s ease}
.admin-top a:hover{color:#fff}
.admin-shell{max-width:1280px;margin:0 auto;display:flex;gap:0;min-height:calc(100vh - 58px)}
.admin-side{width:244px;flex-shrink:0;display:flex;flex-direction:column;background:linear-gradient(180deg,#fff,#fafdfb);border-right:1px solid var(--line);padding:18px 14px}
.admin-nav{display:flex;flex-direction:column;gap:3px}
.admin-side-label{display:block;font-size:11px;font-weight:800;letter-spacing:.13em;text-transform:uppercase;color:#9aa7b6;padding:2px 12px 10px}
.admin-side a{position:relative;display:flex;align-items:center;gap:12px;padding:8px 11px;border-radius:12px;color:#5b6b7d;font-weight:600;font-size:14px;transition:background .14s ease,color .14s ease}
.admin-side a .ic{width:34px;height:34px;flex:0 0 34px;border-radius:9px;display:grid;place-items:center;font-size:18px;background:var(--bg);color:#7689a0;transition:background .14s ease,color .14s ease,box-shadow .14s ease,transform .14s ease}
.admin-side a:hover{background:var(--bg);color:var(--ink)}
.admin-side a:hover .ic{background:#fff;color:var(--green-dark);box-shadow:var(--shadow);transform:translateY(-1px)}
.admin-side a.active{background:var(--green-tint);color:var(--green-deep);font-weight:700}
.admin-side a.active .ic{background:var(--green);color:#fff;box-shadow:0 5px 12px rgba(22,163,74,.35)}
.admin-side a.active::before{content:"";position:absolute;left:-14px;top:9px;bottom:9px;width:3px;border-radius:0 4px 4px 0;background:var(--green)}

/* sidebar footer: admin profile + view site */
.admin-side-foot{margin-top:auto;padding-top:16px}
.admin-side-card{display:flex;align-items:center;gap:11px;background:var(--bg);border:1px solid var(--line);border-radius:13px;padding:10px 12px}
.admin-side-card .av{width:36px;height:36px;flex:0 0 36px;border-radius:10px;display:grid;place-items:center;font-weight:800;font-size:16px;color:#fff;background:linear-gradient(135deg,var(--green),var(--green-deep))}
.admin-side-card .nm{font-size:13.5px;font-weight:700;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.admin-side-card .rl{font-size:11px;color:var(--muted);font-weight:600;margin-top:1px}
.admin-side-view{display:flex;align-items:center;justify-content:center;gap:7px;margin-top:9px;padding:9px;border-radius:11px;font-size:12.5px;font-weight:700;color:var(--green-dark);background:var(--green-tint);border:1px solid var(--green-line);transition:background .12s ease,color .12s ease}
.admin-side-view:hover{background:var(--green);color:#fff;border-color:var(--green)}
.admin-main{flex:1;padding:26px;min-width:0}
.admin-main h1{font-size:22px;font-weight:800;margin-bottom:4px}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:18px 0}
.stat{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.stat .n{font-size:28px;font-weight:800;color:var(--green-dark)}
.stat .l{font-size:13px;color:var(--muted);font-weight:600;margin-top:2px}
.stat .sub{font-size:12px;color:var(--muted);margin-top:6px}
.btn-sm{padding:6px 10px;font-size:12px}
.btn-danger{background:var(--red);color:#fff}
.btn-danger:hover{background:#b91c1c}
.inline-form{display:inline-flex;gap:6px;flex-wrap:wrap;align-items:center}
@media(max-width:880px){
  .admin-shell{flex-direction:column}
  .admin-side{width:100%;flex-direction:row;align-items:center;border-right:0;border-bottom:1px solid var(--line);padding:10px 14px}
  .admin-nav{flex-direction:row;flex-wrap:wrap;gap:6px;width:100%}
  .admin-side a{padding:7px 10px}
  .admin-side a .ic{width:28px;height:28px;flex:0 0 28px;font-size:16px}
  .admin-side a.active::before{display:none}
  .admin-side-label,.admin-side-foot{display:none}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
}

/* ---------- admin locations page ---------- */
.loc-countries{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:12px;margin:16px 0}
.loc-c{background:#fff;border:1px solid var(--line);border-radius:13px;padding:14px 16px;display:flex;align-items:center;gap:12px;transition:transform .12s ease,border-color .12s ease,box-shadow .12s ease}
.loc-c:hover{border-color:var(--green);transform:translateY(-2px);box-shadow:var(--shadow)}
.loc-c.active{border-color:var(--green);background:var(--green-tint)}
.loc-c .flag{font-size:26px;line-height:1}
.loc-c .n{font-weight:800;font-size:19px;color:var(--green-dark);line-height:1}
.loc-c .l{font-size:12.5px;font-weight:600;color:var(--ink);margin-top:2px}
.loc-c.all{background:linear-gradient(135deg,var(--green-deep),var(--green));border:0}
.loc-c.all .n,.loc-c.all .l{color:#fff}
.loc-chips{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 18px}
.loc-chip{font-size:13px;padding:6px 12px;border-radius:20px;border:1px solid var(--line);background:#fff;font-weight:600;color:var(--muted);transition:all .12s ease}
.loc-chip:hover{border-color:var(--green);color:var(--green-dark)}
.loc-chip.active{background:var(--green);color:#fff;border-color:var(--green)}
.loc-chip .c{opacity:.7;font-weight:700}
.table tr.grp td{background:var(--green-tint);color:var(--green-deep);font-weight:700;font-size:12.5px;letter-spacing:.02em}
details.loc-add{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);margin:16px 0;overflow:hidden}
details.loc-add>summary{cursor:pointer;padding:14px 18px;font-weight:700;font-size:14px;list-style:none;display:flex;align-items:center;gap:8px;color:var(--green-dark)}
details.loc-add>summary::-webkit-details-marker{display:none}
details.loc-add[open]>summary{border-bottom:1px solid var(--line)}
details.loc-add .body{padding:18px}

/* ===================================================================
   Home landing page (.hm-*)
   =================================================================== */
.hm-hero{position:relative;overflow:hidden;color:#fff;padding:72px 0 110px;
  background:linear-gradient(135deg,#0c3a20 0%,#15803d 58%,#16a34a 100%)}
.hm-hero::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(820px 420px at 110% -10%, rgba(255,255,255,.18), transparent 60%),
             radial-gradient(680px 360px at -10% 120%, rgba(255,255,255,.10), transparent 55%)}
.hm-hero .container{position:relative;z-index:2}

/* Calm premium hero background: flowing aurora light + faint dot texture.
   GPU-only transforms/opacity, no busy moving objects. */
.hm-hero-fx{position:absolute;inset:0;z-index:1;overflow:hidden;pointer-events:none}
.hm-aurora{position:absolute;border-radius:50%;filter:blur(72px);opacity:.55;mix-blend-mode:screen;will-change:transform}
.hm-aurora.a1{width:46vw;height:46vw;min-width:420px;min-height:420px;top:-16%;right:-6%;
  background:radial-gradient(circle,rgba(134,239,172,.85),transparent 62%);animation:hmDrift1 26s ease-in-out infinite}
.hm-aurora.a2{width:40vw;height:40vw;min-width:360px;min-height:360px;bottom:-22%;left:-8%;
  background:radial-gradient(circle,rgba(45,212,191,.6),transparent 62%);animation:hmDrift2 32s ease-in-out infinite}
.hm-aurora.a3{width:32vw;height:32vw;min-width:300px;min-height:300px;top:14%;left:34%;
  background:radial-gradient(circle,rgba(255,255,255,.42),transparent 60%);animation:hmDrift3 38s ease-in-out infinite}
.hm-aurora.a4{width:30vw;height:30vw;min-width:280px;min-height:280px;bottom:-6%;right:24%;
  background:radial-gradient(circle,rgba(110,231,183,.5),transparent 60%);animation:hmDrift1 30s ease-in-out infinite reverse}
@keyframes hmDrift1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-5%,6%) scale(1.12)}}
@keyframes hmDrift2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(6%,-5%) scale(1.15)}}
@keyframes hmDrift3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(4%,5%) scale(.9)}}
/* faint static dot texture for depth (no motion) */
.hm-noise{position:absolute;inset:0;opacity:.4;
  background-image:radial-gradient(rgba(255,255,255,.10) 1px,transparent 1.4px);background-size:24px 24px;
  -webkit-mask-image:radial-gradient(120% 120% at 70% 20%, #000 30%, transparent 75%);
  mask-image:radial-gradient(120% 120% at 70% 20%, #000 30%, transparent 75%)}
@media(prefers-reduced-motion:reduce){.hm-aurora{animation:none}}

.hm-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hm-pill{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.28);color:#eafff0;padding:7px 16px;border-radius:30px;
  font-size:13px;font-weight:600;margin-bottom:22px}
.hm-h1{font-size:48px;font-weight:800;line-height:1.07;letter-spacing:-.025em;margin:0}
.hm-h1 .accent{color:#bbf7d0}
.hm-lead{font-size:18px;color:#dcfce7;margin:18px 0 26px;max-width:540px;line-height:1.6}
.hm-hero .searchbar{max-width:560px;margin:0}
.hm-trustline{margin-top:18px;font-size:13px;color:#bbf7d0;display:flex;gap:20px;flex-wrap:wrap}
.hm-trustline span{display:inline-flex;align-items:center;gap:6px}

/* hero spotlight card (real top-3) */
.hm-card{background:#fff;color:var(--ink);border-radius:20px;box-shadow:0 28px 64px rgba(0,0,0,.30);overflow:hidden}
.hm-card-head{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:var(--green-tint);border-bottom:1px solid var(--green-line)}
.hm-card-head b{font-size:14px;color:var(--green-deep)}
.hm-card-head .tag{font-size:11px;color:var(--green-dark);font-weight:700;display:inline-flex;align-items:center;gap:5px}
.hm-card .rank-row{padding:14px 18px}

/* stats strip overlapping the hero */
.hm-stats{max-width:1080px;margin:-44px auto 0;position:relative;z-index:3;padding:0 20px}
.hm-statbar{display:grid;grid-template-columns:repeat(4,1fr);background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);overflow:hidden}
.hm-stat{display:flex;align-items:center;gap:16px;padding:22px 26px;border-right:1px solid var(--line)}
.hm-stat:last-child{border-right:0}
.hm-stat .ic{width:54px;height:54px;flex:0 0 54px;display:grid;place-items:center;border-radius:50%;background:var(--green-tint);color:var(--green-dark);font-size:24px}
.hm-stat .n{font-size:28px;font-weight:800;color:var(--ink);line-height:1.05;letter-spacing:-.02em}
.hm-stat .l{font-size:13px;color:var(--muted);font-weight:700;margin-top:3px}

/* sections */
.hm-sec{padding:66px 0}
.hm-sec.alt{background:var(--white);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.hm-head{text-align:center;margin-bottom:38px}
.hm-h2{font-size:32px;font-weight:800;letter-spacing:-.02em}
.hm-sub{color:var(--muted);max-width:580px;margin:10px auto 0;font-size:16px;line-height:1.6}

/* signals grid */
.hm-signals{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.hm-sig{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px;position:relative;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}
.hm-sig:hover{transform:translateY(-3px);border-color:var(--green);box-shadow:var(--shadow)}
.hm-sig .ic{width:46px;height:46px;border-radius:12px;background:var(--green-tint);color:var(--green-dark);
  display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:14px}
.hm-sig h4{font-size:16px;font-weight:700}
.hm-sig p{font-size:13.5px;color:var(--muted);margin-top:6px;line-height:1.55}
.hm-sig .pts{position:absolute;top:22px;right:22px;font-weight:800;color:var(--green);font-size:14px}
.hm-sig .pts span{color:var(--muted);font-weight:600;font-size:11px}
.hm-sig .wbar{height:6px;background:var(--line);border-radius:4px;margin-top:14px;overflow:hidden}
.hm-sig .wbar i{display:block;height:100%;background:linear-gradient(90deg,var(--green),var(--green-dark));border-radius:4px}

/* principle / trust band */
.hm-band{position:relative;overflow:hidden;color:#cdefd6;padding:84px 0;
  background:radial-gradient(circle at 16% 122%,rgba(34,229,114,.18),transparent 40%),radial-gradient(circle at 86% -8%,rgba(25,196,99,.16),transparent 44%),linear-gradient(135deg,#041b14,#06291d 55%,#05201a)}
.hm-band .band-glow{position:absolute;left:-12%;right:-12%;bottom:-260px;height:360px;border-radius:50%;border-top:2px solid rgba(52,238,133,.22);box-shadow:0 0 70px rgba(34,229,114,.18);pointer-events:none}
.hm-band .container{position:relative;text-align:center}
.hm-band .eyebrow{display:inline-block;color:#4ade80;font-size:13px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;margin-bottom:14px}
.hm-band h2{color:#fff;font-size:clamp(32px,4vw,48px);font-weight:800;max-width:760px;margin:0 auto;letter-spacing:-.03em;line-height:1.05}
.hm-band .lead{max-width:660px;margin:18px auto 0;font-size:16.5px;line-height:1.7;color:rgba(255,255,255,.66)}
.hm-band .pts3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:46px;text-align:left}
.hm-p3{background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:30px;backdrop-filter:blur(6px);transition:transform .2s ease,border-color .2s ease,background .2s ease}
.hm-p3:hover{transform:translateY(-3px);border-color:rgba(52,238,133,.35);background:rgba(255,255,255,.065)}
.hm-p3 .ic{width:52px;height:52px;display:grid;place-items:center;border-radius:15px;background:rgba(25,196,99,.18);color:#76ffa7;font-size:24px;margin-bottom:22px}
.hm-p3 .ic.warm{background:rgba(245,200,75,.16);color:#f7d8a0}
.hm-p3 b{color:#fff;display:block;margin-bottom:10px;font-size:19px;letter-spacing:-.01em}
.hm-p3 p{font-size:14.5px;line-height:1.6;color:rgba(255,255,255,.6)}

/* two-path audience cards */
.hm-paths{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.aud{position:relative;overflow:hidden;min-height:300px;border-radius:24px;padding:38px;
  display:grid;grid-template-columns:1.18fr .82fr;gap:20px;align-items:center;box-shadow:0 14px 40px rgba(15,23,42,.08)}
.aud.light{background:linear-gradient(135deg,#ffffff,#e9f7ef);border:1px solid var(--green-line)}
.aud.dark{color:#fff;border:0;background:radial-gradient(circle at 86% 14%,rgba(25,196,99,.45),transparent 36%),linear-gradient(135deg,#0a4d31,#052a1d)}
.aud-ic{width:62px;height:62px;display:grid;place-items:center;border-radius:50%;font-size:26px;background:var(--green-tint);color:var(--green-dark);margin-bottom:20px}
.aud.dark .aud-ic{background:rgba(255,255,255,.12);color:#fff}
.aud h3{margin:0 0 12px;font-size:29px;line-height:1.12;letter-spacing:-.03em;font-weight:800;color:var(--ink)}
.aud.dark h3{color:#fff}
.aud p{margin:0 0 24px;color:var(--muted);font-size:15px;line-height:1.6;max-width:340px}
.aud.dark p{color:rgba(255,255,255,.78)}
.aud .btn-primary{background:var(--green);color:#fff}
.aud-lightbtn{background:#fff;color:var(--green-deep);box-shadow:0 12px 26px rgba(0,0,0,.16)}
.aud-lightbtn:hover{background:#eafff1}
/* illustrations */
.aud-illus{position:relative;align-self:stretch;min-height:170px}
.search-illus .ph,.search-illus .ph2{position:absolute;border-radius:18px;background:#fff;border:1px solid #d7f0e1;box-shadow:0 16px 36px rgba(15,23,42,.10)}
.search-illus .ph{width:150px;height:96px;right:54px;top:26px}
.search-illus .ph2{width:128px;height:84px;right:84px;top:62px;transform:rotate(-4deg);opacity:.92}
.search-illus .mag{position:absolute;right:24px;bottom:18px;width:78px;height:78px;display:grid;place-items:center;border-radius:50%;background:var(--green);color:#fff;font-size:32px;box-shadow:0 20px 36px rgba(17,161,83,.34)}
.chart-illus{display:flex;align-items:flex-end;justify-content:center;gap:12px;padding-bottom:6px}
.chart-illus .bar{position:relative;width:34px;border-radius:10px 10px 4px 4px;background:linear-gradient(180deg,#5dffa0,#11a153);box-shadow:0 0 26px rgba(84,255,151,.22)}
.chart-illus .bar b{position:absolute;top:-30px;right:-6px;padding:5px 11px;border-radius:10px;background:rgba(255,255,255,.16);color:#bbf7d0;font-weight:800;font-size:13px}

/* final cta band */
.hm-final{padding:34px 0 40px;background:linear-gradient(180deg,#effcf5,#f8fafc)}
/* the CTA already has its own bottom padding — drop the footer's top margin here */
.hm-final + .site-footer{margin-top:0}
.fin-card{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:22px;
  background:#fff;border:1px solid var(--green-line);border-radius:24px;padding:26px 32px;box-shadow:0 14px 40px rgba(15,23,42,.07)}
.fin-trophy{width:72px;height:72px;flex:0 0 72px;display:grid;place-items:center;border-radius:50%;background:linear-gradient(155deg,#22e572,#0a8a44);font-size:34px;line-height:1;box-shadow:0 16px 30px rgba(17,161,83,.30)}
.fin-card h2{margin:0;font-size:clamp(22px,2.2vw,27px);font-weight:800;letter-spacing:-.02em;color:var(--ink);white-space:nowrap}
.fin-card p{margin:6px 0 0;color:var(--muted);font-size:15.5px}
.fin-acts{display:flex;gap:10px;flex-wrap:wrap}
.fin-acts .btn{font-weight:800;min-height:48px;padding:0 20px;border-radius:12px;white-space:nowrap}
/* below ~1040px the buttons drop under the text, so the heading gets a full row */
@media(max-width:1040px){
  .fin-card{grid-template-columns:auto 1fr;column-gap:20px}
  .fin-card h2{white-space:normal}
  .fin-acts{grid-column:1 / -1;justify-content:flex-start;margin-top:8px}
}
.fin-acts .btn-ghost{background:#fff;border-color:var(--line);box-shadow:0 6px 16px rgba(15,23,42,.06)}
.fin-acts .btn-ghost:hover{border-color:var(--green)}

/* live leaderboard table — columns: Business | Category | Location | Score | Trend */
.lt{overflow:hidden;border:1px solid var(--line);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow);max-width:940px;margin:0 auto}
.lt-head,.lt-row{display:grid;grid-template-columns:2fr 1.2fr 1fr 1.3fr 88px;align-items:center;gap:14px}
.lt-head{padding:15px 22px;background:#f8fafc;border-bottom:1px solid var(--line);font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.lt-row{padding:15px 22px;border-bottom:1px solid var(--line);font-size:14px;color:#5e6f86;transition:background .12s ease}
.lt-row:last-child{border-bottom:0}
.lt-row:hover{background:#f7fdfa}
.lt-biz{display:flex;align-items:center;gap:12px;min-width:0}
.lt-rank{width:34px;height:34px;flex:0 0 34px;display:grid;place-items:center;border-radius:10px;background:var(--muted);color:#fff;font-weight:800;font-size:14px}
.lt-rank.r1{background:var(--green)}.lt-rank.r2{background:#475569}.lt-rank.r3{background:#94a3b8}
.lt-binfo{display:flex;flex-direction:column;min-width:0}
.lt-bname{display:flex;align-items:center;gap:6px;min-width:0}
.lt-bname a{color:var(--ink);font-weight:700;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lt-bname a:hover{color:var(--green-dark)}
.lt-bname .vf{flex:0 0 auto;color:var(--green);font-size:15px}
.lt-brate{display:flex;align-items:center;gap:6px;margin-top:3px;font-size:13px;font-weight:700;color:var(--ink)}
.lt-brate .ti-star-filled{color:var(--gold)}
.lt-brate small{color:var(--muted);font-weight:600;font-size:13px}
.lt-score{position:relative;padding-bottom:11px}
.lt-score b{color:var(--ink);font-size:18px;font-weight:800}
.lt-score small{color:var(--muted);font-weight:700}
.lt-score .bar{position:absolute;left:0;right:18px;bottom:0;height:5px;border-radius:9px;background:var(--line);overflow:hidden}
.lt-score .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--green),var(--green-dark));border-radius:9px}
.lt-trend{font-weight:800;display:inline-flex;align-items:center;gap:5px}
.lt-trend.up{color:var(--green-dark)}.lt-trend.down{color:var(--red)}.lt-trend.flat{color:#9aa7b6}
@media(max-width:760px){
  .lt-head,.lt-row{grid-template-columns:1.5fr 1fr 78px}
  .lt-head span:nth-child(3),.lt-head span:nth-child(5),.lt-row>span:nth-child(3),.lt-row>span:nth-child(5){display:none}
}

@media(max-width:920px){
  .hm-hero-grid{grid-template-columns:1fr;gap:36px}
  .hm-statbar{grid-template-columns:repeat(2,1fr)}
  .hm-stat:nth-child(2){border-right:0}
  .hm-signals{grid-template-columns:repeat(2,1fr)}
  .hm-band .pts3{grid-template-columns:1fr}
  .hm-paths{grid-template-columns:1fr}
  .fin-card{grid-template-columns:auto 1fr;gap:16px}
  .fin-acts{grid-column:1 / -1;margin-top:4px}
}
@media(max-width:560px){
  .hm-hero{padding:52px 0 96px}
  .hm-h1{font-size:34px}
  .hm-h2,.hm-final h2{font-size:26px}
  .hm-statbar{grid-template-columns:1fr}
  .hm-stat{border-right:0;border-bottom:1px solid var(--line)}
  .hm-stat:last-child{border-bottom:0}
  .hm-signals{grid-template-columns:1fr}
  .aud{grid-template-columns:1fr;padding:28px}
  .aud-illus{display:none}
  .fin-card{grid-template-columns:1fr;text-align:center;justify-items:center}
  .fin-acts{justify-content:center}
}

/* ===================================================================
   Account / form pages (.acct-*) — gradient header + tidy cards
   =================================================================== */
.acct-hero{position:relative;overflow:hidden;color:#fff;padding:42px 0 70px;
  background:linear-gradient(135deg,#0c3a20 0%,#15803d 60%,#16a34a 100%)}
.acct-hero::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(720px 320px at 108% -20%, rgba(255,255,255,.16), transparent 60%)}
.acct-hero .container{position:relative;display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap}
.acct-hero .crumbs2{font-size:13px;color:#bbf7d0;margin-bottom:8px}
.acct-hero .crumbs2 a{color:#fff;font-weight:600}
.acct-hero h1{font-size:30px;font-weight:800;letter-spacing:-.02em;line-height:1.12;margin:0}
.acct-hero .sub{color:#dcfce7;margin-top:8px;max-width:580px;font-size:15px;line-height:1.6}
.acct-hero .acts{display:flex;gap:8px;flex-wrap:wrap}
.acct-hero .acts .btn-ghost{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.3);color:#fff}
.acct-hero .acts .btn-ghost:hover{background:rgba(255,255,255,.24)}
.acct-hero .acts .btn-light{background:#fff;color:var(--green-deep)}
.acct-hero .acts .btn-light:hover{background:#eafff0}

.acct-main{max-width:1080px;margin:-42px auto 0;position:relative;z-index:2;padding:0 20px 56px}

.acct-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.acct-stat{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:var(--shadow)}
.acct-stat .ic{float:right;font-size:20px;color:var(--green);opacity:.65}
.acct-stat .n{font-size:26px;font-weight:800;color:var(--green-dark);line-height:1}
.acct-stat .l{font-size:12.5px;color:var(--muted);font-weight:600;margin-top:5px}

/* dashboard business card */
.biz-card{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:22px;margin-bottom:16px}
.biz-top{display:flex;gap:16px;align-items:flex-start;flex-wrap:wrap}
.biz-thumb{width:54px;height:54px;border-radius:14px;flex-shrink:0;background:var(--green-tint);color:var(--green-dark);
  display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:800}
.biz-metrics{display:flex;gap:24px;text-align:center;margin-left:auto}
.biz-metrics .v{font-size:21px;font-weight:800;line-height:1}
.biz-metrics .v small{font-size:12px;color:var(--muted);font-weight:600}
.biz-metrics .k{font-size:11px;color:var(--muted);font-weight:600;margin-top:3px}
.biz-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px;border-top:1px solid var(--line);padding-top:14px}

/* settings / form two-column */
.acct-grid{display:grid;grid-template-columns:1fr 300px;gap:22px;align-items:start}
.acct-side{position:sticky;top:84px;display:flex;flex-direction:column;gap:16px}
.set-head{display:flex;gap:12px;align-items:center;margin-bottom:16px}
.set-head .ic{width:42px;height:42px;border-radius:11px;background:var(--green-tint);color:var(--green-dark);
  display:flex;align-items:center;justify-content:center;font-size:21px;flex-shrink:0}
.set-head h3{font-size:17px;font-weight:700;line-height:1.1}
.set-head .d{font-size:13px;color:var(--muted);margin-top:2px}

.info-card{background:linear-gradient(135deg,var(--green-tint),#fff);border:1px solid var(--green-line);border-radius:16px;padding:20px}
.info-card h4{font-size:15px;margin-bottom:10px}
.info-row{display:flex;justify-content:space-between;gap:10px;font-size:13.5px;padding:8px 0;border-bottom:1px dashed var(--green-line)}
.info-row:last-child{border-bottom:0}
.info-row .k{color:var(--muted)}
.info-row .vv{font-weight:600;text-align:right}

/* numbered flow (add-business aside) */
.flow{list-style:none}
.flow li{display:flex;gap:14px;padding-bottom:20px;position:relative}
.flow li:last-child{padding-bottom:0}
.flow li:not(:last-child)::before{content:"";position:absolute;left:16px;top:34px;bottom:2px;width:2px;background:var(--green-line)}
.flow .n{width:34px;height:34px;border-radius:50%;background:var(--green);color:#fff;font-weight:800;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px;position:relative;z-index:1}
.flow .t b{display:block;font-size:14px}
.flow .t p{font-size:13px;color:var(--muted);margin-top:2px;line-height:1.5}

@media(max-width:920px){
  .acct-stats{grid-template-columns:repeat(2,1fr)}
  .acct-grid{grid-template-columns:1fr}
  .acct-side{position:static}
  .biz-metrics{margin-left:0;width:100%;justify-content:flex-start}
}
@media(max-width:560px){
  .acct-hero{padding:34px 0 64px}
  .acct-hero h1{font-size:24px}
}

/* ---------- owner dashboard (polished) ---------- */
.acct-hero::after{content:"";position:absolute;left:-8%;bottom:-180px;width:420px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(134,239,172,.22),transparent 65%);pointer-events:none}
.dash-id{display:flex;align-items:center;gap:16px;position:relative;z-index:1}
.dash-id .avatar{width:62px;height:62px;flex:0 0 62px;border-radius:18px;display:grid;place-items:center;font-size:26px;font-weight:800;color:#fff;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.28)}
.dash-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.dash-stat{background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:var(--shadow);display:flex;align-items:center;gap:14px;transition:transform .15s ease,box-shadow .15s ease}
.dash-stat:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(15,23,42,.08)}
.dash-stat .ic{width:46px;height:46px;flex:0 0 46px;display:grid;place-items:center;border-radius:13px;background:var(--green-tint);color:var(--green-dark);font-size:22px}
.dash-stat .n{font-size:25px;font-weight:800;color:var(--ink);line-height:1}
.dash-stat .l{font-size:12.5px;color:var(--muted);font-weight:600;margin-top:3px}

.dash-grid{display:grid;grid-template-columns:1fr 320px;gap:22px;align-items:start}
.dash-main{display:flex;flex-direction:column;gap:18px;min-width:0}
.dash-aside{position:sticky;top:84px;display:flex;flex-direction:column;gap:16px}

.bizc{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);overflow:hidden;transition:border-color .15s ease,transform .15s ease}
.bizc:hover{transform:translateY(-2px);border-color:var(--green-line)}
.bizc-top{display:flex;gap:16px;align-items:flex-start;padding:22px;flex-wrap:wrap}
.bizc-thumb{width:56px;height:56px;flex:0 0 56px;border-radius:15px;display:grid;place-items:center;font-size:24px;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--green),var(--green-deep))}
.bizc-idblock{flex:1;min-width:180px}
.bizc-name{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:800;color:var(--ink);flex-wrap:wrap;letter-spacing:-.01em}
.bizc-name .verified{color:var(--green);font-size:17px}
.bizc-metaline{color:var(--muted);font-size:13.5px;margin-top:5px}
.bizc-strength{margin-top:12px;max-width:280px}
.bizc-strength .lbl{display:flex;justify-content:space-between;font-size:12px;font-weight:700;color:var(--muted);margin-bottom:5px}
.bizc-strength .bar{height:6px;border-radius:9px;background:var(--line);overflow:hidden}
.bizc-strength .bar i{display:block;height:100%;border-radius:9px;background:linear-gradient(90deg,var(--green),var(--green-dark))}
.bizc-score{text-align:right;min-width:118px}
.bizc-score .sv{font-size:28px;font-weight:800;color:var(--green-dark);line-height:1}
.bizc-score .sv span{font-size:13px;color:var(--muted);font-weight:600}
.bizc-score .sk{font-size:11px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-top:4px}
.bizc-pending{margin:0 22px 16px;font-size:13px;color:#92400e;background:#fef3c7;border:1px solid #fde68a;border-radius:11px;padding:9px 13px}
.bizc-metrics{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line)}
.bizc-metrics .m{padding:15px 22px;border-right:1px solid var(--line);text-align:center}
.bizc-metrics .m:last-child{border-right:0}
.bizc-metrics .mv{font-size:19px;font-weight:800;color:var(--ink);line-height:1}
.bizc-metrics .mv small{font-size:12px;color:var(--muted);font-weight:600}
.bizc-metrics .mk{font-size:11.5px;color:var(--muted);font-weight:600;margin-top:3px}
.bizc-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:14px 22px;border-top:1px solid var(--line);background:#fafdfb}

/* Leads = the main action of a listing — deliberately the standout button */
.btn-leads{
  display:inline-flex;align-items:center;gap:9px;
  font-size:15px;font-weight:800;letter-spacing:.01em;
  padding:12px 22px;border-radius:12px;border:0;color:#fff;
  background:linear-gradient(135deg,#10b981 0%,#0d9488 55%,#0f766e 100%);
  box-shadow:0 8px 22px rgba(13,148,136,.34);
  transition:transform .14s ease,box-shadow .14s ease,filter .14s ease;
}
.btn-leads i{font-size:19px}
.btn-leads:hover{transform:translateY(-2px);filter:saturate(1.1);box-shadow:0 12px 28px rgba(13,148,136,.46)}
.btn-leads .lead-n{
  display:inline-flex;align-items:center;font-size:11.5px;font-weight:800;line-height:1;
  color:#7c2d12;background:#fbbf24;border-radius:20px;padding:4px 9px;margin-left:2px;
  box-shadow:0 2px 6px rgba(0,0,0,.18);
}

.dash-tips,.dash-links{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow)}
.dash-tips{background:linear-gradient(135deg,var(--green-tint),#fff);border-color:var(--green-line);padding:22px}
.dash-tips h4{font-size:15px;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.dash-tips ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.dash-tips li{display:flex;gap:9px;font-size:13.5px;color:var(--ink);align-items:flex-start;line-height:1.45}
.dash-tips li i{color:var(--green);font-size:17px;margin-top:1px;flex-shrink:0}
.dash-cta{background:linear-gradient(135deg,#14532d,#16a34a);color:#fff;border-radius:16px;padding:24px;text-align:center;box-shadow:var(--shadow)}
.dash-cta .ic{width:50px;height:50px;border-radius:14px;background:rgba(255,255,255,.16);display:grid;place-items:center;font-size:24px;margin:0 auto 12px}
.dash-cta h4{font-size:17px;margin-bottom:6px}
.dash-cta p{font-size:13px;color:#dcfce7;margin-bottom:16px;line-height:1.5}
.dash-cta .btn{background:#fff;color:var(--green-deep);width:100%;justify-content:center;font-weight:700}
.dash-links{padding:8px}
.dash-links a{display:flex;align-items:center;gap:11px;padding:11px 14px;border-radius:10px;color:var(--ink);font-weight:600;font-size:14px}
.dash-links a:hover{background:var(--green-tint);color:var(--green-dark)}
.dash-links a i{color:var(--green);font-size:18px}

/* settings profile summary card */
.set-profile{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);overflow:hidden}
.set-profile .top{background:linear-gradient(135deg,var(--green-tint),#fff);padding:26px 24px;text-align:center;border-bottom:1px solid var(--line)}
.set-profile .av{width:74px;height:74px;border-radius:20px;margin:0 auto 14px;display:grid;place-items:center;font-size:30px;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--green),var(--green-deep));box-shadow:0 12px 26px rgba(22,163,74,.25)}
.set-profile .nm{font-size:18px;font-weight:800;color:var(--ink)}
.set-profile .em{font-size:13px;color:var(--muted);margin-top:3px;word-break:break-all}
.set-profile .vpill{display:inline-flex;align-items:center;gap:5px;margin-top:12px;padding:5px 13px;border-radius:20px;font-size:12px;font-weight:800}
.set-profile .vpill.ok{background:var(--green-tint);color:var(--green-dark)}
.set-profile .vpill.no{background:#fef3c7;color:#92400e}
.set-profile .rows{padding:10px 22px 18px}
.set-profile .prow{display:flex;justify-content:space-between;gap:10px;font-size:13.5px;padding:10px 0;border-bottom:1px dashed var(--line)}
.set-profile .prow:last-child{border-bottom:0}
.set-profile .prow .k{color:var(--muted)}
.set-profile .prow .v{font-weight:700;text-align:right}
/* section card header refinements (settings) */
.card .set-head .ic{box-shadow:0 6px 14px rgba(22,163,74,.12)}

@media(max-width:920px){
  .dash-grid{grid-template-columns:1fr}
  .dash-aside{position:static}
  .dash-stats{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:560px){
  .dash-stats{grid-template-columns:1fr}
  .bizc-metrics{grid-template-columns:1fr}
  .bizc-metrics .m{border-right:0;border-bottom:1px solid var(--line)}
  .bizc-metrics .m:last-child{border-bottom:0}
}

/* ===================================================================
   Add Business page (.ab-*) — stepper + sectioned form + sidebar
   =================================================================== */
.ab-wrap{max-width:1200px;margin:0 auto;padding:26px 20px 60px}
.ab-crumbs{font-size:13px;color:var(--muted);margin-bottom:10px}
.ab-crumbs a{color:var(--green-dark);font-weight:600}
.ab-title{font-size:30px;font-weight:800;letter-spacing:-.02em}
.ab-title + p{color:var(--muted);font-size:15px;margin-top:6px}

/* stepper */
.ab-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:22px 0 26px;
  background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:var(--shadow)}
.ab-step{display:flex;gap:12px;align-items:flex-start}
.ab-step .num{width:30px;height:30px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:14px;background:var(--green-tint);color:var(--green-dark);border:2px solid var(--green-line)}
.ab-step.on .num{background:var(--green);color:#fff;border-color:var(--green)}
.ab-step b{font-size:14px;display:block;line-height:1.2}
.ab-step span{font-size:12px;color:var(--muted)}

/* layout */
.ab-grid{display:grid;grid-template-columns:1fr 340px;gap:22px;align-items:start}
.ab-main{display:flex;flex-direction:column;gap:18px;min-width:0}
.ab-aside{position:sticky;top:84px;display:flex;flex-direction:column;gap:18px}

/* section card */
.ab-sec{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px;box-shadow:var(--shadow)}
.ab-sec h3{font-size:17px;font-weight:800}
.ab-sec .sub{color:var(--muted);font-size:13px;margin:2px 0 18px}
.ab-row{display:grid;gap:14px}
.ab-2{grid-template-columns:1fr 1fr}
.ab-3{grid-template-columns:1fr 1fr 1fr}
.ab-row .form-group{margin:0}
.charcount{font-size:11px;color:var(--muted);text-align:right;margin-top:4px}

/* phone group with code */
.ab-phone{display:flex;gap:8px}
.ab-phone .code{width:96px;flex-shrink:0}

/* social inputs with leading icon */
.ab-social{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ab-ico{position:relative}
.ab-ico>i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:18px}
.ab-ico .form-control{padding-left:38px}

/* hours */
.ab-hours{display:flex;gap:10px;align-items:center}
.ab-hours .form-control{flex:1;min-width:0}
.ab-hours .sep{color:var(--muted);font-weight:600;flex-shrink:0}

/* toggles */
.ab-checks{display:flex;flex-direction:column;gap:10px}
.ab-check{display:flex;align-items:center;gap:9px;font-size:14px;font-weight:600;cursor:pointer}
.ab-check input{width:16px;height:16px;accent-color:var(--green)}

/* submit */
.ab-submit{background:var(--green);color:#fff;font-weight:700;font-size:16px;width:100%;
  padding:15px;border-radius:12px;border:0;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}
.ab-submit:hover{background:var(--green-dark)}
.ab-agree{text-align:center;font-size:12px;color:var(--muted);margin-top:10px}
.ab-tip{background:#fffbeb;border:1px solid #fde68a;color:#92400e;border-radius:12px;padding:14px 18px;font-size:13.5px;margin-top:18px}

/* ----- sidebar cards ----- */
.ab-why{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:var(--shadow)}
.ab-why h4{font-size:16px;font-weight:800;margin-bottom:14px}
.ab-why .item{display:flex;gap:12px;margin-bottom:14px}
.ab-why .item:last-child{margin-bottom:0}
.ab-why .ic{width:38px;height:38px;border-radius:10px;flex-shrink:0;background:var(--green-tint);color:var(--green-dark);display:flex;align-items:center;justify-content:center;font-size:19px}
.ab-why b{font-size:14px;display:block}
.ab-why p{font-size:12.5px;color:var(--muted);line-height:1.5}

/* listing preview */
.ab-prev{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:var(--shadow)}
.ab-prev .ph{display:flex;gap:14px;align-items:flex-start}
.ab-prev .thumb{width:74px;height:74px;border-radius:12px;background:var(--bg);border:1px dashed var(--line);
  display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:24px;flex-shrink:0}
.ab-prev .pname{font-weight:800;font-size:16px}
.ab-prev .pmeta{font-size:12.5px;color:var(--muted);margin-top:3px}
.ab-prev .pstar{color:var(--gold);font-size:13px}
.ab-prev .pactions{display:flex;gap:6px;margin-top:14px}
.ab-prev .pactions .b{flex:1;text-align:center;font-size:12px;font-weight:600;border:1px solid var(--line);border-radius:8px;padding:7px 0;color:var(--ink)}
.ab-prev .ptags{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}
.ab-prev .ptag{font-size:11px;font-weight:700;background:var(--green-tint);color:var(--green-deep);border-radius:14px;padding:3px 9px}

.ab-tips,.ab-guide{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:var(--shadow)}
.ab-tips h4,.ab-guide h4{font-size:16px;font-weight:800;margin-bottom:12px}
.ab-tips li{display:flex;gap:9px;align-items:flex-start;font-size:13.5px;margin-bottom:9px;list-style:none}
.ab-tips li i{color:var(--green);font-size:16px;margin-top:1px}
.ab-guide .grp{margin-bottom:14px}
.ab-guide .grp:last-child{margin-bottom:0}
.ab-guide .lbl{font-size:13px;font-weight:700;display:flex;align-items:center;gap:7px}
.ab-guide .dot{width:9px;height:9px;border-radius:50%;display:inline-block}
.ab-guide .grp p{font-size:12.5px;color:var(--muted);margin-top:3px;padding-left:16px}

@media(max-width:980px){
  .ab-grid{grid-template-columns:1fr}
  .ab-aside{position:static}
  .ab-steps{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:560px){
  .ab-2,.ab-3,.ab-social{grid-template-columns:1fr}
  .ab-steps{grid-template-columns:1fr}
  .ab-title{font-size:24px}
}

/* ---------- responsive ---------- */
@media(max-width:760px){
  .hero h1{font-size:30px}
  .nav-links{display:none}
  .searchbar{flex-direction:column}
  .searchbar .divider{display:none}
  .steps,.cat-grid{grid-template-columns:1fr}
  .hero-stats{gap:16px;flex-wrap:wrap}
  .profile-rank{border-right:0;border-bottom:1px solid var(--line);padding:0 0 18px;width:100%}
  .breakdown{grid-template-columns:1fr}
}

/* =====================================================================
   Search experience  (pages/search.php)
   ===================================================================== */
.sx-hero{padding:60px 0 70px}
.sx-hero-inner{text-align:center;max-width:780px;margin:0 auto}
.sx-hero .hm-h1{font-size:44px}

/* the prominent search panel that floats on the hero */
.sx-search{background:#fff;border-radius:18px;box-shadow:0 28px 64px rgba(0,0,0,.28);padding:12px;max-width:760px;margin:26px auto 0}
.sx-form{display:grid;grid-template-columns:1.7fr 1fr 1fr auto;gap:10px;align-items:stretch}
.sx-field{display:flex;align-items:center;gap:10px;background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:0 14px;min-height:54px;transition:border-color .12s ease,box-shadow .12s ease}
.sx-field:focus-within{border-color:var(--green);box-shadow:0 0 0 3px var(--green-line);background:#fff}
.sx-field i{color:var(--muted);font-size:19px;flex:0 0 auto}
.sx-field input,.sx-field select{border:0;background:transparent;outline:none;font-family:inherit;font-size:15px;color:var(--ink);width:100%;font-weight:500}
.sx-field select{cursor:pointer}
.sx-form .btn{min-height:54px;justify-content:center;border-radius:12px;font-size:15px;padding-inline:22px}

/* quick chips under the search */
.sx-quick{display:flex;flex-wrap:wrap;gap:9px;justify-content:center;align-items:center;margin-top:22px}
.sx-quick .lbl{color:#bbf7d0;font-size:13px;font-weight:600;margin-right:2px}
.sx-qchip{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#eafff2;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);padding:7px 14px;border-radius:30px;transition:all .12s ease}
.sx-qchip:hover{background:#fff;color:var(--green-dark);border-color:#fff;transform:translateY(-1px)}
.sx-hero .hm-trustline{margin-top:24px}

/* results toolbar */
.sx-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:24px}
.sx-count{font-size:15px;color:var(--muted)}
.sx-count b{color:var(--ink);font-weight:800}
.sx-sort{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted);font-weight:600}
.sx-sort .seg{display:inline-flex;background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.sx-sort .seg a{padding:8px 14px;font-size:13px;font-weight:600;color:var(--muted);border-right:1px solid var(--line)}
.sx-sort .seg a:last-child{border-right:0}
.sx-sort .seg a:hover{color:var(--green-dark)}
.sx-sort .seg a.on{background:var(--green-tint);color:var(--green-dark)}

/* results / showcase grid */
.sx-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}
.sx-card{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:var(--shadow);transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}
.sx-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(15,23,42,.13);border-color:var(--green-line)}
.sx-ch{display:flex;align-items:center;gap:13px;padding-right:46px}
.sx-avatar{width:50px;height:50px;flex:0 0 50px;border-radius:14px;display:grid;place-items:center;font-size:22px;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--green),var(--green-deep))}
.sx-id{min-width:0;flex:1}
.sx-name{display:flex;align-items:center;gap:6px;font-weight:800;font-size:16.5px;letter-spacing:-.01em;color:var(--ink)}
.sx-name .verified{color:var(--green);font-size:16px;flex:0 0 auto}
.sx-card:hover .sx-name{color:var(--green-dark)}
.sx-cat{display:flex;align-items:center;gap:5px;font-size:13px;color:var(--muted);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sx-cat i{font-size:14px;flex:0 0 auto}
.sx-rank{position:absolute;top:18px;right:18px;font-size:12px;font-weight:800;color:var(--muted);background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:3px 9px}
.sx-rank.r1{color:var(--green-dark);background:var(--green-tint);border-color:var(--green-line)}
.sx-desc{font-size:13.5px;color:#5e6f86;margin:14px 0 0;line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.sx-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:13px}
.sx-tag{font-size:11.5px;font-weight:600;color:var(--green-deep);background:var(--green-tint);border:1px solid var(--green-line);padding:3px 9px;border-radius:20px}
.sx-foot{margin-top:auto;padding-top:16px}
.sx-metrics{display:flex;align-items:flex-end;justify-content:space-between;gap:10px}
.sx-rating{display:inline-flex;align-items:center;gap:5px;font-weight:700;font-size:14px;color:var(--ink)}
.sx-rating i{color:var(--gold)}
.sx-rating small{color:var(--muted);font-weight:600}
.sx-score{text-align:right;white-space:nowrap}
.sx-score b{font-size:18px;font-weight:800;color:var(--ink)}
.sx-score span{font-size:11px;color:var(--muted);font-weight:700}
.sx-scorebar{height:6px;border-radius:9px;background:var(--line);overflow:hidden;margin-top:11px}
.sx-scorebar i{display:block;height:100%;background:linear-gradient(90deg,var(--green),var(--green-dark));border-radius:9px}

/* empty / no-results state */
.sx-empty{text-align:center;background:#fff;border:1px solid var(--line);border-radius:18px;padding:54px 30px;box-shadow:var(--shadow)}
.sx-empty .ic{width:72px;height:72px;margin:0 auto 18px;border-radius:50%;display:grid;place-items:center;font-size:32px;background:var(--green-tint);color:var(--green-dark)}
.sx-empty h3{font-size:21px;font-weight:800;letter-spacing:-.01em}
.sx-empty p{color:var(--muted);margin:8px auto 22px;max-width:430px}

@media(max-width:720px){
  .sx-hero .hm-h1{font-size:32px}
  .sx-form{grid-template-columns:1fr 1fr;gap:8px}
  .sx-form .sx-field.kw,.sx-form .btn{grid-column:1/-1}
  .sx-toolbar{flex-direction:column;align-items:flex-start}
}
@media(max-width:560px){
  .sx-hero{padding:42px 0 56px}
  .sx-grid{grid-template-columns:1fr}
  .sx-sort .seg{width:100%}
  .sx-sort .seg a{flex:1;text-align:center}
}

/* =====================================================================
   Leaderboard  (pages/leaderboard.php)
   ===================================================================== */
.lb-hero{padding:58px 0 78px}
.lb-hero-inner{text-align:center;max-width:780px;margin:0 auto}
.lb-hero .hm-h1{font-size:42px}
.lb-switch{grid-template-columns:1fr 1fr auto}

/* podium (compact) */
.lb-podium{display:grid;grid-template-columns:1fr 1.1fr 1fr;gap:16px;align-items:end}
.lb-pod{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px 18px 16px;box-shadow:var(--shadow);text-align:center;transition:transform .15s ease,box-shadow .15s ease}
.lb-pod:hover{transform:translateY(-4px);box-shadow:0 18px 38px rgba(15,23,42,.13)}
.lb-pod.p1{order:2;padding-top:26px;border-color:#fde68a;background:linear-gradient(180deg,#fffdf4,#fff);box-shadow:0 16px 42px rgba(245,158,11,.18)}
.lb-pod.p2{order:1}
.lb-pod.p3{order:3}
.lb-crown{position:absolute;top:-13px;left:50%;transform:translateX(-50%);font-size:26px;color:#f59e0b;filter:drop-shadow(0 3px 6px rgba(245,158,11,.35))}

/* avatar with rank medal tucked into the corner — saves vertical space */
.lb-pavatar{position:relative;width:54px;height:54px;border-radius:15px;margin:0 auto 11px;display:grid;place-items:center;font-size:24px;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--green),var(--green-deep))}
.lb-pod.p1 .lb-pavatar{width:60px;height:60px;font-size:27px}
.lb-medal{position:absolute;top:-9px;right:-10px;width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-size:13px;font-weight:800;color:#fff;border:2.5px solid #fff;box-shadow:0 3px 8px rgba(0,0,0,.18)}
.lb-pod.p1 .lb-medal{width:28px;height:28px;font-size:14px;background:linear-gradient(135deg,#fbbf24,#d97706)}
.lb-pod.p2 .lb-medal{background:linear-gradient(135deg,#cbd5e1,#94a3b8)}
.lb-pod.p3 .lb-medal{background:linear-gradient(135deg,#e7a877,#b45309)}

.lb-pname{display:flex;align-items:center;justify-content:center;gap:5px;font-weight:800;font-size:16px;letter-spacing:-.01em;line-height:1.25;color:var(--ink)}
.lb-pod:hover .lb-pname{color:var(--green-dark)}
.lb-pname .verified{color:var(--green);font-size:15px;flex:0 0 auto}
.lb-prate{margin-top:5px;font-size:13px;font-weight:700;color:var(--ink)}
.lb-prate .ti-star-filled{color:var(--gold)}
.lb-prate small{color:var(--muted);font-weight:600}
.lb-ptags{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-top:10px}
.lb-ptags span{font-size:11px;font-weight:600;color:var(--green-deep);background:var(--green-tint);border:1px solid var(--green-line);padding:2px 9px;border-radius:20px}
.lb-pfoot{margin-top:auto;padding-top:13px}
.lb-pscore{font-size:27px;font-weight:800;letter-spacing:-.02em;line-height:1;color:var(--ink)}
.lb-pod.p1 .lb-pscore{font-size:31px}
.lb-pscore span{font-size:12px;color:var(--muted);font-weight:700;letter-spacing:0}
.lb-pbar{height:6px;border-radius:9px;background:var(--line);overflow:hidden;margin-top:9px}
.lb-pbar i{display:block;height:100%;border-radius:9px;background:linear-gradient(90deg,var(--green),var(--green-dark))}
.lb-pod.p1 .lb-pbar i{background:linear-gradient(90deg,#fbbf24,#d97706)}
.lb-pview{display:inline-flex;align-items:center;gap:5px;margin-top:12px;font-size:12.5px;font-weight:700;color:var(--green-dark);opacity:.82;transition:gap .15s ease,opacity .15s ease}
.lb-pod:hover .lb-pview{opacity:1;gap:8px}

/* section rows / headings */
.lb-secrow{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.lb-h3{font-size:17px;font-weight:800;letter-spacing:-.01em}
.lb-h3-sub{display:block;font-size:13px;color:var(--muted);font-weight:500;margin-top:2px}
.lb-earned{font-size:12.5px;color:var(--muted);display:inline-flex;align-items:center;gap:5px}

/* full-ranking table extras (reuses .lt) */
.lt-sub{margin-top:3px;font-size:13px;color:var(--muted);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:340px}
.lt-rate{font-weight:800;color:var(--ink)}
.lt-rate .ti-star-filled{color:var(--gold)}
.lt-rev{font-weight:700;color:#5e6f86}

/* cross-navigation (compact chip clouds) */
.lb-block{margin-bottom:30px}
.lb-block:last-child{margin-bottom:0}
.lb-block-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.lb-block-head h3{font-size:16px;font-weight:800;letter-spacing:-.01em}
.lb-block-head h3 span{color:var(--muted);font-weight:600}
.lb-allcities{font-size:13.5px;font-weight:700;color:var(--green-dark);display:inline-flex;align-items:center;gap:5px}
.lb-allcities:hover{gap:8px}
.lb-chips{display:flex;flex-wrap:wrap;gap:9px}
.lb-chips .loc-chip{display:inline-flex;align-items:center;gap:7px}
.lb-chips .loc-chip i{font-size:15px;color:var(--green);opacity:.85}
.lb-chips .loc-chip.active i{color:#fff;opacity:1}

@media(max-width:760px){
  .lb-hero .hm-h1{font-size:31px}
  .lb-switch{grid-template-columns:1fr}
}
@media(max-width:640px){
  .lb-podium{grid-template-columns:1fr;gap:12px}
  .lb-pod.p1,.lb-pod.p2,.lb-pod.p3{order:0;padding-top:20px}
  .lb-pod.p1{padding-top:26px}
}

/* =====================================================================
   Listing page — landing-page polish (aurora hero, chips, summaries)
   ===================================================================== */
.lp-hero{background:linear-gradient(135deg,#0c3a20 0%,#15803d 58%,#16a34a 100%)}
.lp-hero-fx{position:absolute;inset:0;z-index:1;overflow:hidden;pointer-events:none;border-radius:inherit}
.lp-hero-grid{z-index:2}

.lp-pill{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:700;color:#eafff2;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);padding:6px 13px;border-radius:30px;margin-bottom:14px;transition:background .12s ease}
.lp-pill:hover{background:rgba(255,255,255,.26)}
.lp-tagline{color:#eafff0;font-size:15px;margin-top:8px;font-weight:500}

.lp-stats{margin-top:15px;gap:9px}
.lp-stats>span{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);padding:6px 12px;border-radius:30px;font-weight:600;color:#eafff2;font-size:13.5px}
.lp-stats>span.star{color:#fde68a}
.lp-stats .lp-movechip{padding:0;background:none;border:0}
.lp-movechip .move{font-weight:700}
.lp-movechip .move.up{color:#bbf7d0}.lp-movechip .move.down{color:#fecaca}.lp-movechip .move.flat{color:#cbe9d3}

/* iconed card headers */
.lp-cardhead{display:flex;align-items:flex-start;gap:13px;margin-bottom:16px}
.lp-cardhead .hic{width:40px;height:40px;flex:0 0 40px;border-radius:12px;display:grid;place-items:center;background:var(--green-tint);color:var(--green-dark);font-size:21px}
.lp-cardhead h3{font-size:18px;font-weight:800;letter-spacing:-.01em;line-height:1.2}
.lp-cardhead .sub{font-size:13px;color:var(--muted);font-weight:500;margin-top:2px}

/* breakdown bars -> gradient */
.bd-bar i{background:linear-gradient(90deg,var(--green),var(--green-dark))}

/* sticky action bar */
.lp-actions{position:sticky;top:64px;z-index:30;margin:18px 0 22px;padding:11px 13px;border:1px solid var(--line);border-radius:14px;background:rgba(248,250,252,.9);-webkit-backdrop-filter:saturate(140%) blur(8px);backdrop-filter:saturate(140%) blur(8px);box-shadow:0 6px 20px rgba(15,23,42,.06)}
.lp-actions .btn{box-shadow:none}

/* review summary (average + distribution) */
.lp-revsum{display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:center;padding-bottom:18px;margin-bottom:8px;border-bottom:1px solid var(--line)}
.lp-revbig{text-align:center;padding-right:26px;border-right:1px solid var(--line)}
.lp-revbig .n{font-size:46px;font-weight:800;line-height:1;letter-spacing:-.02em;color:var(--ink)}
.lp-revbig .st{color:var(--gold);font-size:15px;margin-top:6px;letter-spacing:2px}
.lp-revbig .c{font-size:12px;color:var(--muted);margin-top:5px;font-weight:600}
.lp-revbars{display:flex;flex-direction:column;gap:7px}
.lp-revbar{display:flex;align-items:center;gap:11px}
.lp-revbar .k{width:36px;flex:0 0 36px;display:inline-flex;align-items:center;gap:3px;font-weight:700;color:var(--muted);font-size:12px}
.lp-revbar .k .ti-star-filled{color:var(--gold);font-size:13px}
.lp-revbar .tr{flex:1;height:8px;border-radius:6px;background:var(--line);overflow:hidden}
.lp-revbar .tr i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,#fbbf24,#f59e0b)}
.lp-revbar .v{width:22px;flex:0 0 22px;text-align:right;font-weight:700;color:var(--ink);font-size:13px}

@media(max-width:560px){
  .lp-revsum{grid-template-columns:1fr;gap:14px}
  .lp-revbig{border-right:0;border-bottom:1px solid var(--line);padding-right:0;padding-bottom:14px}
  .lp-actions{top:0;border-radius:0;margin-left:-20px;margin-right:-20px}
}

/* =====================================================================
   Admin dashboard — modern stat grid + moderation queue
   ===================================================================== */
.adash-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;margin-bottom:4px}
.adash-head h1{font-size:24px;font-weight:800;letter-spacing:-.02em}
.adash-sub{color:var(--muted);font-size:13.5px;margin-top:4px;max-width:560px;line-height:1.5}
.adash-runpill{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;color:var(--green-deep);background:var(--green-tint);border:1px solid var(--green-line);padding:8px 14px;border-radius:30px;white-space:nowrap}
.adash-runpill b{font-weight:800}
.adash-runpill.never{color:#92400e;background:#fef3c7;border-color:#fde68a}

/* stat cards */
.astat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:16px 0}
.astat{display:flex;align-items:center;gap:13px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:13px 15px;box-shadow:var(--shadow);transition:transform .14s ease,box-shadow .14s ease}
.astat:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(15,23,42,.09)}
.astat .ic{width:40px;height:40px;flex:0 0 40px;border-radius:11px;display:grid;place-items:center;font-size:21px}
.astat .tx{min-width:0}
.astat .n{font-size:24px;font-weight:800;letter-spacing:-.02em;line-height:1;color:var(--ink)}
.astat .l{font-size:13px;color:var(--ink);font-weight:700;margin-top:3px}
.astat .sub{font-size:11.5px;color:var(--muted);margin-top:2px;line-height:1.35}
.astat.green  .ic{background:var(--green-tint);color:var(--green-dark)}
.astat.teal   .ic{background:#ccfbf1;color:#0f766e}
.astat.amber  .ic{background:#ffedd5;color:#c2410c}
.astat.gold   .ic{background:#fef9c3;color:#a16207}
.astat.blue   .ic{background:#dbeafe;color:#1d4ed8}
.astat.violet .ic{background:#ede9fe;color:#6d28d9}
.astat.red    .ic{background:#fee2e2;color:#b91c1c}
.astat.attn{border-color:#fcd34d;background:linear-gradient(180deg,#fffbeb,#fff)}
.astat.attn.zero{border-color:var(--line);background:#fff}
.astat.attn.zero .ic{background:var(--green-tint);color:var(--green-dark)}
.astat.attn.zero .n{color:var(--green-dark)}

/* recompute strip */
.adash-recalc{display:flex;align-items:center;gap:16px;background:linear-gradient(120deg,var(--green-tint),#fff 70%);border:1px solid var(--green-line);border-radius:16px;padding:16px 20px;margin-bottom:24px}
.adash-recalc .ic{width:44px;height:44px;flex:0 0 44px;border-radius:12px;display:grid;place-items:center;font-size:22px;background:#fff;color:var(--green-dark);border:1px solid var(--green-line)}
.adash-recalc .tx{flex:1;min-width:0}
.adash-recalc .tx b{font-size:15px;font-weight:800;display:block}
.adash-recalc .tx p{font-size:12.5px;color:var(--muted);margin-top:2px}
.adash-recalc form{margin:0;flex:0 0 auto}

/* moderation queue */
.adash-qh{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:800;margin:6px 0 14px;letter-spacing:-.01em}
.adash-qh i{color:var(--green)}
.amod-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.amod-head{display:flex;align-items:center;gap:11px;margin-bottom:6px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.amod-head .ic{width:34px;height:34px;flex:0 0 34px;border-radius:10px;display:grid;place-items:center;font-size:18px}
.amod-head .ic.green{background:var(--green-tint);color:var(--green-dark)}
.amod-head .ic.gold{background:#fef9c3;color:#a16207}
.amod-head h4{flex:1;font-size:14.5px;font-weight:800;letter-spacing:-.01em}
.amod-badge{font-size:12px;font-weight:800;color:var(--green-dark);background:var(--green-tint);border:1px solid var(--green-line);padding:3px 11px;border-radius:20px;min-width:28px;text-align:center}
.amod-badge.zero{color:var(--muted);background:var(--bg);border-color:var(--line)}
.amod-empty{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13.5px;padding:18px 4px}
.amod-empty i{color:var(--green);font-size:18px}
.amod-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line)}
.amod-row:last-child{border-bottom:0}
.amod-info b{font-size:14px;font-weight:700}
.amod-info .sub{font-size:12px;color:var(--muted);margin-top:1px}
.amod-row-rev{flex-direction:column;align-items:stretch}
.amod-revtop{display:flex;justify-content:space-between;align-items:center;gap:10px}
.amod-info2{font-size:13.5px}
.amod-info2 .star{color:var(--gold);letter-spacing:1px}
.amod-info2 b{font-weight:700;margin-left:4px}
.amod-cmt{font-size:13px;color:var(--muted);margin-top:5px;line-height:1.5}
.amod-cmt span{font-weight:600;color:#5e6f86}

@media(max-width:1040px){.astat-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:760px){
  .amod-grid{grid-template-columns:1fr}
  .adash-recalc{flex-wrap:wrap}
}
@media(max-width:520px){.astat-grid{grid-template-columns:1fr 1fr}}

/* =====================================================================
   Auth pages — split-screen sign in / register (.auth-*)
   ===================================================================== */
.auth{padding:44px 20px 64px}
.auth-wrap{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:1.04fr .96fr;background:#fff;border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:0 30px 70px rgba(15,23,42,.13)}

/* left brand panel */
.auth-brand{position:relative;overflow:hidden;color:#fff;padding:50px 46px;display:flex;flex-direction:column;justify-content:center;
  background:linear-gradient(135deg,#0c3a20 0%,#15803d 60%,#16a34a 100%)}
.auth-brand>*{position:relative;z-index:2}
.auth-brand-fx{position:absolute;inset:0;z-index:1;overflow:hidden;pointer-events:none}
.auth-pill{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:700;color:#eafff2;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);padding:7px 14px;border-radius:30px;align-self:flex-start;margin-bottom:22px}
.auth-brand h2{font-size:31px;font-weight:800;letter-spacing:-.02em;line-height:1.12}
.auth-lead{color:#dcfce7;font-size:15px;line-height:1.6;margin:14px 0 26px;max-width:380px}
.auth-benefits{list-style:none;display:flex;flex-direction:column;gap:14px;margin:0 0 28px}
.auth-benefits li{display:flex;align-items:center;gap:12px;font-size:14.5px;font-weight:600;color:#f0fff6}
.auth-benefits .ic{width:36px;height:36px;flex:0 0 36px;border-radius:11px;display:grid;place-items:center;font-size:19px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.2);color:#bbf7d0}
.auth-trust{display:flex;flex-wrap:wrap;gap:9px}
.auth-trust span{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;color:#eafff2;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);padding:7px 13px;border-radius:30px}

/* right form panel */
.auth-form{display:flex;align-items:center;justify-content:center;padding:46px 42px}
.auth-card{width:100%;max-width:382px}
.auth-logo{display:inline-flex;align-items:center;gap:10px;font-weight:800;font-size:18px;color:var(--ink);margin-bottom:24px}
.auth-logo .logo{width:32px;height:32px;border-radius:9px;background:var(--green);display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px}
.auth-card h1{font-size:26px;font-weight:800;letter-spacing:-.02em}
.auth-sub{color:var(--muted);font-size:14px;margin:5px 0 22px}
.auth-lblrow{display:flex;justify-content:space-between;align-items:baseline}
.auth-lblrow a{font-size:12.5px;font-weight:700;color:var(--green-dark)}
.auth-lblrow a:hover{text-decoration:underline}

/* icon inputs + password toggle */
.auth-ip{position:relative}
.auth-ip>i{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:18px;pointer-events:none}
.auth-ip .form-control{padding-left:40px}
.auth-ip input[type=password]+.auth-toggle,.auth-ip .auth-toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:none;border:0;color:var(--muted);cursor:pointer;padding:7px;font-size:18px;line-height:0;border-radius:8px;transition:color .12s ease}
.auth-ip .auth-toggle:hover{color:var(--green-dark)}
.auth-ip:has(.auth-toggle) .form-control{padding-right:42px}

.auth-submit{width:100%;justify-content:center;margin-top:6px;font-size:15px;padding:12px}
.auth-alt{font-size:13.5px;color:var(--muted);margin-top:18px;text-align:center}
.auth-alt a{color:var(--green-dark);font-weight:700}
.auth-alt a:hover{text-decoration:underline}
.auth-demo{margin-top:16px;display:flex;align-items:center;gap:8px;justify-content:center;font-size:12px;color:var(--muted);background:var(--bg);border:1px dashed var(--line);border-radius:10px;padding:9px 12px}
.auth-demo i{color:var(--green-dark)}

@media(max-width:840px){
  .auth-wrap{grid-template-columns:1fr;max-width:440px}
  .auth-brand{display:none}
}
@media(max-width:480px){
  .auth{padding:24px 14px 44px}
  .auth-form{padding:32px 24px}
}

/* auth success/confirmation badge (forgot/reset/verify states) */
.auth-icon-badge{width:60px;height:60px;border-radius:50%;display:grid;place-items:center;font-size:30px;background:var(--green-tint);color:var(--green-dark);border:1px solid var(--green-line);margin-bottom:18px}
.auth-card .auth-submit[href]{text-decoration:none}

/* =====================================================================
   Admin businesses — filter tabs + enhanced moderation table (.atable)
   ===================================================================== */
/* safe global: subtle row hover for all admin tables (header uses th, unaffected) */
.table tr:hover td{background:#f7fdfa}

/* segmented filter tabs with counts */
.atabs{display:inline-flex;gap:4px;flex-wrap:wrap;margin:18px 0;background:#fff;border:1px solid var(--line);border-radius:13px;padding:6px;box-shadow:var(--shadow)}
.atab{display:inline-flex;align-items:center;gap:7px;padding:8px 13px;border-radius:9px;font-size:13.5px;font-weight:700;color:var(--muted);transition:background .12s ease,color .12s ease}
.atab:hover{background:var(--bg);color:var(--ink)}
.atab i{font-size:16px}
.atab.on{background:var(--green-tint);color:var(--green-dark)}
.atab .c{font-size:11px;font-weight:800;background:var(--bg);color:var(--muted);border-radius:20px;padding:1px 8px;min-width:22px;text-align:center}
.atab.on .c{background:#fff;color:var(--green-dark)}

/* enhanced table */
.atable-wrap{overflow-x:auto;border-radius:var(--radius)}
.atable{min-width:880px}
.atable thead th{font-size:12px;text-transform:uppercase;letter-spacing:.05em}
.atable .ta-rank{width:56px;font-weight:800;color:var(--muted)}
.atable td{vertical-align:middle}
.ta-biz{display:flex;align-items:center;gap:12px;min-width:0}
.ta-av{width:38px;height:38px;flex:0 0 38px;border-radius:10px;display:grid;place-items:center;font-weight:800;color:#fff;font-size:16px;background:linear-gradient(135deg,var(--green),var(--green-deep))}
.ta-binfo{min-width:0}
.ta-name{display:inline-flex;align-items:center;gap:6px;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.ta-name:hover{color:var(--green-dark)}
.ta-name .verified{color:var(--green);font-size:15px}
.ta-name .badge{font-size:10px;padding:2px 7px}
.ta-sub{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--muted);margin-top:3px;flex-wrap:wrap}
.ta-sub i{font-size:13px;opacity:.8}
.ta-score{display:flex;align-items:baseline;gap:3px}
.ta-score b{font-size:16px;font-weight:800}
.ta-score small{font-size:11px;color:var(--muted);font-weight:700}
.ta-bar{height:6px;width:96px;border-radius:6px;background:var(--line);overflow:hidden;margin-top:6px}
.ta-bar i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,var(--green),var(--green-dark))}
.atable .ta-act{white-space:nowrap}
.atable .inline-form{gap:6px}
.atable-empty{display:flex;align-items:center;justify-content:center;gap:8px;color:var(--muted);font-size:14px;padding:30px 0}
.atable-empty i{font-size:19px}

/* =====================================================================
   Admin sponsored — concept banner, lifecycle badges, slot table
   ===================================================================== */
/* slot lifecycle badges (extends .badge) */
.badge.live{background:var(--green-tint);color:var(--green-deep)}
.badge.scheduled{background:#dbeafe;color:#1d4ed8}
.badge.paused{background:#f1f5f9;color:#475569}
.badge.ended{background:#fef2f2;color:#991b1b}

/* concept banner — the separation is the product */
.spon-note{display:flex;gap:15px;align-items:flex-start;background:linear-gradient(120deg,var(--green-tint),#fff 72%);border:1px solid var(--green-line);border-radius:16px;padding:18px 20px;margin:16px 0 20px}
.spon-note .ic{width:46px;height:46px;flex:0 0 46px;border-radius:13px;display:grid;place-items:center;font-size:24px;background:#fff;color:var(--green-dark);border:1px solid var(--green-line)}
.spon-note .tx b{font-size:15px;font-weight:800;letter-spacing:-.01em}
.spon-note .tx p{font-size:13px;color:#5e6f86;margin-top:4px;line-height:1.55;max-width:760px}
.spon-note code{background:#eef2f6;border:1px solid var(--line);border-radius:5px;padding:1px 5px;font-size:12px;color:#475569}
.spon-tag{display:inline-block;font-size:10.5px;font-weight:800;color:var(--gold);background:#fffbeb;border:1px solid #fde68a;border-radius:5px;padding:1px 6px;vertical-align:middle}

.spon-stats{margin-bottom:20px}

/* create form */
.spon-create{margin-bottom:22px}
.spon-form{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end}

/* slot table extras */
.spon-av{background:linear-gradient(135deg,#8b5cf6,#6d28d9)}
.spon-pool{color:var(--green-dark);font-weight:600;display:inline-flex;align-items:center;gap:3px}
.spon-pool:hover{text-decoration:underline}
.spon-pool i{font-size:12px}
.spon-win{font-weight:700;font-size:13.5px;color:var(--ink);display:flex;align-items:center;gap:6px;white-space:nowrap}
.spon-win i{color:var(--muted)}
.spon-win-sub{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--muted);margin-top:3px}
.spon-win-sub i{font-size:13px}

/* =====================================================================
   Admin leads + reviews — concept banner, stars, message cells
   ===================================================================== */
/* generic concept banner (reused by leads + reviews) */
.anote{display:flex;gap:14px;align-items:flex-start;background:linear-gradient(120deg,var(--green-tint),#fff 72%);border:1px solid var(--green-line);border-radius:16px;padding:16px 20px;margin:16px 0 20px}
.anote .ic{width:44px;height:44px;flex:0 0 44px;border-radius:12px;display:grid;place-items:center;font-size:23px;background:#fff;color:var(--green-dark);border:1px solid var(--green-line)}
.anote .tx b{font-size:14.5px;font-weight:800;letter-spacing:-.01em}
.anote .tx p{font-size:12.5px;color:#5e6f86;margin-top:3px;line-height:1.6;max-width:800px}
.anote .badge{font-size:10.5px;padding:1px 7px;vertical-align:middle}

/* review star display */
.rstars{color:var(--gold);letter-spacing:1px;font-size:14px;white-space:nowrap}
.rstars .off{color:var(--line)}
.atable td .rstars + b{margin-left:5px;font-weight:800;color:var(--ink)}

/* clamped message cell (leads + reviews) */
.ta-msg{font-size:13px;color:#5e6f86;line-height:1.5;max-width:360px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* lead contact + status */
.lead-ct b{font-weight:700;font-size:14px}
.lead-ct span{display:inline-flex;align-items:center;gap:5px;color:var(--muted);font-size:12.5px;margin-top:3px}
.lead-ct span i{font-size:13px}
.lead-status{text-transform:capitalize}
.badge i{font-size:12px;vertical-align:-1px}

/* =====================================================================
   Admin categories (icon card grid) + users table extras
   ===================================================================== */
/* category add-form icon preview */
.catform{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end}
.icon-preview{width:46px;height:46px;flex:0 0 46px;border-radius:12px;display:grid;place-items:center;font-size:23px;background:var(--green-tint);color:var(--green-dark);border:1px solid var(--green-line)}

/* category cards */
/* compact list view */
.catlist{display:grid;grid-template-columns:repeat(auto-fill,minmax(258px,1fr));gap:8px}
.catrow{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:7px 10px;transition:border-color .12s ease,box-shadow .12s ease}
.catrow:hover{border-color:var(--green-line);box-shadow:var(--shadow)}
.catrow .cc-ic{width:30px;height:30px;flex:0 0 30px;border-radius:8px;display:grid;place-items:center;font-size:16px;background:var(--green-tint);color:var(--green-dark)}
.cr-info{flex:1;min-width:0;display:flex;flex-direction:column;line-height:1.18}
.cr-name{font-size:13px;font-weight:700;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cr-slug{font-size:10.5px;color:var(--muted);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.catrow .cc-count{flex:0 0 auto;font-size:11px;padding:2px 8px}
.catrow .cc-del{flex:0 0 auto;font-size:15px;padding:4px}
.cc-count{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;color:var(--green-dark);background:var(--green-tint);border:1px solid var(--green-line);border-radius:20px;padding:3px 10px}
.cc-count i{font-size:13px}
.cc-count.zero{color:var(--muted);background:var(--bg);border-color:var(--line)}
.cc-del{background:none;border:0;color:#cbd5e1;cursor:pointer;font-size:17px;padding:6px;border-radius:8px;line-height:0;transition:color .12s ease,background .12s ease}
.cc-del:hover{color:var(--red);background:#fef2f2}
.cc-del:disabled{color:#e5e9ef;cursor:not-allowed}
.cc-del:disabled:hover{background:none;color:#e5e9ef}

/* users table extras */
.ta-av.user-av{background:linear-gradient(135deg,#6366f1,#4338ca)}
.role-pill{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);background:var(--bg);border:1px solid var(--line);border-radius:20px;padding:1px 8px;vertical-align:middle}
.unverified-tag{font-size:11px;font-weight:700;color:#b45309;background:#fffbeb;border:1px solid #fde68a;border-radius:20px;padding:0 8px}
.u-phone,.u-joined{font-size:13px;color:var(--muted)}

/* admin users: search toolbar */
.users-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin:18px 0}
.users-toolbar .atabs{margin:0}
.user-search{position:relative;display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:11px;padding:0 12px;min-width:280px;box-shadow:var(--shadow);transition:border-color .12s ease,box-shadow .12s ease}
.user-search:focus-within{border-color:var(--green);box-shadow:0 0 0 3px var(--green-tint)}
.user-search>i{color:var(--muted);font-size:18px;flex:0 0 auto}
.user-search input{flex:1;border:0;outline:none;background:transparent;font-family:inherit;font-size:14px;padding:10px 0;color:var(--ink);min-width:0}
.user-search .clr{flex:0 0 auto;display:grid;place-items:center;color:var(--muted);font-size:16px;padding:4px;border-radius:7px;transition:color .12s ease,background .12s ease}
.user-search .clr:hover{color:var(--red);background:#fef2f2}
.users-results{font-size:13.5px;color:var(--muted);margin:-4px 0 14px}
.users-results b{color:var(--ink);font-weight:800}
@media(max-width:620px){.user-search{min-width:0;width:100%}}

/* admin users: bulk selection + checkboxes */
.chk-col{width:40px;text-align:center;padding-left:14px!important;padding-right:6px!important}
.chk-col input{width:16px;height:16px;cursor:pointer;accent-color:var(--green);vertical-align:middle}
.bulk-bar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;background:#fff;border:1px solid var(--line);border-radius:12px;padding:9px 14px;margin-bottom:14px;box-shadow:var(--shadow)}
.bulk-bar .bulk-count{font-size:13px;font-weight:600;color:var(--muted)}
.bulk-bar .bulk-count b{color:var(--ink);font-weight:800}
.bulk-bar .bulk-select{width:auto;min-width:168px;padding:9px 12px;font-size:13.5px;margin:0}
.bulk-bar .btn{margin-left:auto}
@media(max-width:620px){.bulk-bar .btn{margin-left:0}}

/* listing reviews: members-only gate */
.review-asline{display:inline-flex;align-items:center;gap:7px;font-size:13px;color:var(--muted);background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:7px 12px}
.review-asline i{font-size:16px;color:var(--green-dark)}
.review-asline b{color:var(--ink);font-weight:700}
.review-gate{display:flex;gap:14px;align-items:flex-start;background:linear-gradient(120deg,var(--green-tint),#fff 70%);border:1px solid var(--green-line);border-radius:14px;padding:18px 20px}
.review-gate .rg-ic{width:44px;height:44px;flex:0 0 44px;border-radius:12px;display:grid;place-items:center;font-size:22px;background:#fff;color:var(--green-dark);border:1px solid var(--green-line)}
.review-gate .rg-tx b{font-size:15px;font-weight:800;letter-spacing:-.01em}
.review-gate .rg-tx p{font-size:13px;color:#5e6f86;margin:3px 0 13px;line-height:1.5;max-width:420px}
.review-gate .rg-acts{display:flex;gap:9px;flex-wrap:wrap}

/* =====================================================================
   Owner lead inbox (account/leads.php)
   ===================================================================== */
.leads-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin:4px 0 16px}
.leads-head h3{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:800;letter-spacing:-.01em}
.leads-head h3 i{color:var(--green)}
.leads-hint{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:20px;padding:6px 12px}
.leads-hint i{color:var(--green-dark)}

.leads-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:16px}
.lead-card{position:relative;overflow:hidden;background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px 18px 16px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:13px;transition:transform .14s ease,box-shadow .14s ease}
.lead-card:hover{transform:translateY(-3px);box-shadow:0 14px 32px rgba(15,23,42,.10)}
.lead-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--line)}
.lead-card.s-new::before{background:linear-gradient(180deg,#fbbf24,#d97706)}
.lead-card.s-contacted::before{background:linear-gradient(180deg,#3b82f6,#2563eb)}
.lead-card.s-closed::before{background:#cbd5e1}

.lc-top{display:flex;align-items:center;gap:12px}
.lc-av{width:42px;height:42px;flex:0 0 42px;border-radius:12px;display:grid;place-items:center;font-weight:800;font-size:18px;color:#fff;background:linear-gradient(135deg,#6366f1,#4338ca)}
.lc-id{flex:1;min-width:0}
.lc-name{display:flex;align-items:center;gap:7px;font-weight:800;font-size:15.5px;letter-spacing:-.01em;flex-wrap:wrap}
.lc-name .badge{font-size:10.5px;padding:1px 8px}
.lc-name .badge i{font-size:12px}
.lc-date{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--muted);margin-top:3px}
.lc-tag{flex:0 0 auto;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;padding:4px 10px;border-radius:20px}
.lc-tag.new{color:#b45309;background:#fef3c7}
.lc-tag.contacted{color:#1d4ed8;background:#dbeafe}
.lc-tag.closed{color:#475569;background:#eef2f6}

.lc-phone{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:14px;color:var(--green-dark);width:fit-content}
.lc-phone:hover{text-decoration:underline}
.lc-phone.none{color:var(--muted);font-weight:600}
.lc-phone.none:hover{text-decoration:none}
.lc-phone i{font-size:17px}

.lc-msg{background:var(--bg);border:1px solid var(--line);border-radius:11px;padding:11px 13px;font-size:13.5px;color:#5e6f86;line-height:1.55}
.lc-msg .none{color:#9aa7b6;font-style:italic}

.lc-status{display:flex;align-items:center;gap:10px;margin-top:auto;flex-wrap:wrap}
.lc-status-lbl{font-size:12px;font-weight:700;color:var(--muted)}
.lc-seg{display:inline-flex;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.lc-seg button{border:0;background:#fff;padding:7px 14px;font-size:12.5px;font-weight:700;color:var(--muted);cursor:pointer;border-right:1px solid var(--line);font-family:inherit;transition:background .12s ease,color .12s ease}
.lc-seg button:last-child{border-right:0}
.lc-seg button:hover{background:var(--bg);color:var(--ink)}
.lc-seg button.on{background:var(--green);color:#fff}

.lead-empty{text-align:center;background:#fff;border:1px solid var(--line);border-radius:18px;padding:50px 28px;box-shadow:var(--shadow)}
.lead-empty .ic{width:66px;height:66px;margin:0 auto 16px;border-radius:18px;display:grid;place-items:center;font-size:30px;background:var(--green-tint);color:var(--green-dark)}
.lead-empty h3{font-size:19px;font-weight:800}
.lead-empty p{color:var(--muted);margin:8px auto 18px;max-width:420px;line-height:1.55}
@media(max-width:560px){.leads-grid{grid-template-columns:1fr}}
