/* =====================================================================
   peta.lk — Design System
   Brand: #00AEEF (Lotus Tower cyan) · #0F1923 (dark navy)
   Font : Plus Jakarta Sans
   ===================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

:root {
  --brand:       #00AEEF;
  --brand-d:     #0099D6;
  --brand-dd:    #0077A8;
  --brand-pale:  #E8F7FF;
  --brand-light: #99DEFF;
  --accent:      #FF5722;
  --accent-d:    #E64A19;
  --dark:        #111827;
  --dark-2:      #1F2937;
  --dark-3:      #374151;
  --grey-7:      #1F2937;
  --grey-5:      #6B7280;
  --grey-4:      #9CA3AF;
  --grey-2:      #E5E7EB;
  --grey-1:      #F5F7FA;
  --white:       #FFFFFF;
  --success:     #10B981;
  --success-bg:  #D1FAE5;
  --warning:     #F59E0B;
  --warning-bg:  #FEF3C7;
  --danger:      #EF4444;
  --danger-bg:   #FEE2E2;
  --info:        #3B82F6;
  --info-bg:     #DBEAFE;
  --border:      #E8EAED;
  --border-2:    #D4D8DE;
  --sh-sm: 0 1px 4px rgba(0,0,0,.07), 0 0 0 1px rgba(0,0,0,.03);
  --sh-md: 0 4px 16px rgba(0,0,0,.09), 0 1px 4px rgba(0,0,0,.05);
  --sh-lg: 0 8px 32px rgba(0,0,0,.11), 0 2px 8px rgba(0,0,0,.06);
  --sh-xl: 0 16px 52px rgba(0,0,0,.14), 0 4px 16px rgba(0,0,0,.07);
  --r1: 4px; --r2: 8px; --r3: 12px; --r4: 16px;
  --r5: 20px; --r6: 24px; --r7: 32px;
  --t: all .18s ease;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,sans-serif;
  font-size:15px;line-height:1.6;color:var(--grey-7);
  background:#FFFFFF;min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--brand-d);text-decoration:none;transition:var(--t)}
a:hover{color:var(--brand)}
img{max-width:100%;height:auto;display:block}
input,select,textarea,button{font-family:inherit}

.container{max-width:1240px;margin:0 auto;padding:0 16px}
@media(min-width:640px){.container{padding:0 24px}}
@media(min-width:1024px){.container{padding:0 32px}}

/* ── NAVBAR ─────────────────────────────────────────────────────────── */
.navbar{
  background:#fff;position:sticky;top:0;z-index:1000;
  box-shadow:0 1px 0 var(--border),0 2px 12px rgba(0,0,0,.06);
}
.navbar-inner{display:flex;align-items:center;height:67px;gap:12px}
.navbar-logo{flex-shrink:0}
.navbar-logo img{height:40px;width:auto}

.navbar-search{flex:1;max-width:440px;position:relative}
.navbar-search input{
  width:100%;height:38px;background:var(--grey-1);
  border:1.5px solid var(--border);border-radius:19px;
  color:var(--dark);padding:0 14px 0 38px;font-size:14px;transition:var(--t);
}
.navbar-search input::placeholder{color:var(--grey-4)}
.navbar-search input:focus{outline:none;background:#fff;border-color:var(--brand);box-shadow:0 0 0 3px rgba(0,174,239,.12)}
.nav-s-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--grey-4);pointer-events:none}
.search-dropdown{
  position:absolute;top:calc(100% + 6px);left:0;right:0;
  background:#fff;border-radius:var(--r3);box-shadow:var(--sh-xl);
  border:1px solid var(--border);overflow:hidden;z-index:200;display:none;
}
.search-dropdown a{
  display:flex;align-items:center;gap:8px;padding:10px 14px;
  font-size:13px;color:var(--grey-7);border-bottom:1px solid var(--border);transition:var(--t);
}
.search-dropdown a:last-child{border-bottom:none}
.search-dropdown a:hover{background:var(--brand-pale);color:var(--brand-d)}

.navbar-actions{display:flex;align-items:center;gap:6px;margin-left:auto;flex-shrink:0}
.nav-link{
  color:var(--grey-5);font-size:14px;font-weight:500;
  padding:6px 11px;border-radius:var(--r2);transition:var(--t);white-space:nowrap;
}
.nav-link:hover{color:var(--dark);background:var(--grey-1)}
.btn-post{
  background:var(--accent);color:#fff!important;font-weight:700;
  padding:7px 16px;border-radius:20px;font-size:13px;transition:var(--t);
  white-space:nowrap;box-shadow:0 2px 8px rgba(255,107,53,.28);
}
.btn-post:hover{background:var(--accent-d);transform:translateY(-1px);box-shadow:0 4px 14px rgba(255,107,53,.38)}

.user-menu{position:relative}
.user-av{
  width:36px;height:36px;border-radius:50%;
  background:linear-gradient(135deg,var(--brand),var(--brand-dd));
  color:#fff;font-weight:800;font-size:14px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;border:2px solid transparent;transition:var(--t);
}
.user-av:hover{border-color:var(--brand);box-shadow:0 0 0 3px rgba(0,174,239,.15)}
.user-drop{
  position:absolute;right:0;top:calc(100% + 10px);min-width:210px;
  background:#fff;border-radius:var(--r4);box-shadow:var(--sh-xl);
  border:1px solid var(--border);overflow:hidden;display:none;z-index:300;
}
.user-menu.open .user-drop{display:block}
.user-drop-head{
  padding:14px 16px;
  background:linear-gradient(135deg,var(--brand),var(--brand-dd));
  border-bottom:1px solid rgba(255,255,255,.15);
}
.user-drop-name{font-weight:700;font-size:14px;color:#fff}
.user-drop-role{
  display:inline-block;margin-top:4px;font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.5px;
  background:rgba(255,255,255,.22);color:#fff;padding:2px 8px;border-radius:20px;
}
.user-drop a{
  display:flex;align-items:center;gap:10px;padding:11px 16px;
  font-size:14px;color:var(--grey-7);border-bottom:1px solid var(--border);transition:var(--t);
}
.user-drop a:last-child{border-bottom:none}
.user-drop a:hover{background:var(--brand-pale);color:var(--brand-d)}
.user-drop a.dd-danger{color:var(--danger)}
.user-drop a.dd-danger:hover{background:var(--danger-bg)}

.hamburger{display:none;background:none;border:none;color:var(--grey-5);cursor:pointer;padding:6px;border-radius:var(--r2)}
@media(max-width:767px){
  .hamburger{display:flex;align-items:center}
  .navbar-search,.nav-link.hm{display:none}
}

.mob-menu{display:none;background:#fff;border-top:1px solid var(--border);box-shadow:0 8px 24px rgba(0,0,0,.08)}
.mob-menu.open{display:block}
.mob-search{padding:12px 16px;border-bottom:1px solid var(--border)}
.mob-search input{
  width:100%;height:42px;background:var(--grey-1);
  border:1.5px solid var(--border);border-radius:21px;
  color:var(--dark);padding:0 16px;font-size:14px;
}
.mob-search input:focus{outline:none;border-color:var(--brand)}
.mob-menu a{
  display:flex;align-items:center;gap:10px;padding:13px 20px;
  color:var(--grey-7);font-size:15px;
  border-bottom:1px solid var(--border);transition:var(--t);
}
.mob-menu a:hover{color:var(--brand-d);background:var(--brand-pale)}
.mob-menu a.mob-cta{color:var(--accent);font-weight:700}
.mob-menu a.mob-danger{color:var(--danger)}

/* ── HERO ────────────────────────────────────────────────────────────── */
.hero{
  background:linear-gradient(160deg,#083A56 0%,#0B5485 55%,#0A84C8 100%);
  padding:44px 0 40px;position:relative;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 80% at 90% 40%,rgba(0,174,239,.30) 0%,transparent 60%),
             radial-gradient(ellipse 50% 55% at 0% 100%,rgba(0,174,239,.18) 0%,transparent 55%),
             radial-gradient(ellipse 35% 45% at 5% 100%,rgba(255,107,53,.07) 0%,transparent 55%);
  pointer-events:none;
}
.hero-inner{
  display:grid;gap:32px;align-items:center;position:relative;z-index:1;
}
@media(min-width:900px){.hero-inner{grid-template-columns:1fr 1fr;gap:40px}}
.hero-left{}
.hero-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(0,174,239,.18);border:1px solid rgba(0,174,239,.3);
  color:var(--brand-light);font-size:12px;font-weight:600;
  padding:4px 12px;border-radius:20px;margin-bottom:16px;letter-spacing:.2px;
}
.hero h1{font-size:clamp(24px,5vw,44px);font-weight:800;color:#fff;line-height:1.12;margin-bottom:10px;letter-spacing:-.5px}
.hero h1 span{color:var(--brand)}
.hero-sub{color:rgba(255,255,255,.7);font-size:15px;margin-bottom:16px}
.hero-sub-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:20px}
.hero-colombo-btn{
  display:inline-flex;align-items:center;gap:8px;
  background:linear-gradient(135deg,#00C6FF,#0072FF);
  color:#fff;font-size:14px;font-weight:800;padding:10px 22px;
  border-radius:24px;border:none;text-decoration:none;
  box-shadow:0 4px 18px rgba(0,174,239,.45);
  transition:transform .18s,box-shadow .18s;white-space:nowrap;
  animation:colombo-pulse 2.8s ease-in-out infinite;
  letter-spacing:.2px;
}
.hero-colombo-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 6px 24px rgba(0,174,239,.6);
  color:#fff;
  animation:none;
}
@keyframes colombo-pulse{
  0%,100%{box-shadow:0 4px 18px rgba(0,174,239,.45)}
  50%{box-shadow:0 4px 28px rgba(0,174,239,.7),0 0 0 5px rgba(0,174,239,.12)}
}
.hero-bar{
  display:flex;background:#fff;
  border-radius:30px;overflow:hidden;
  box-shadow:0 8px 32px rgba(0,0,0,.3);
}
.hero-bar input{
  flex:1;height:52px;border:none;padding:0 20px;
  font-size:15px;color:var(--dark);font-family:inherit;min-width:0;
}
.hero-bar input:focus{outline:none}
.hero-bar input::placeholder{color:var(--grey-4)}
.hero-bar button{
  height:52px;padding:0 24px;background:var(--brand);color:#fff;
  font-weight:700;font-size:15px;border:none;cursor:pointer;transition:var(--t);white-space:nowrap;
}
.hero-bar button:hover{background:var(--brand-d)}
.hero-pills{display:flex;flex-wrap:wrap;gap:7px;margin-top:16px}
.hero-pills a{
  background:rgba(255,255,255,.12);color:rgba(255,255,255,.85);
  border:1px solid rgba(255,255,255,.22);padding:5px 13px;
  border-radius:20px;font-size:12px;font-weight:500;transition:var(--t);
}
.hero-pills a:hover{background:rgba(0,174,239,.2);color:#fff;border-color:rgba(0,174,239,.5)}
.hero-stats{display:flex;gap:20px;margin-top:24px;flex-wrap:wrap}
.hero-stat{color:rgba(255,255,255,.75);font-size:12px}
.hero-stat strong{color:#fff;font-size:20px;font-weight:800;display:block;letter-spacing:-.3px}

/* ── HERO DUAL CAROUSEL ──────────────────────────────────────────────── */
.hero-right{display:none}
@media(min-width:900px){.hero-right{display:flex;flex-direction:column;gap:12px}}

/* Two side-by-side panels */
.hero-dual{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.hero-panel{
  position:relative;overflow:hidden;border-radius:var(--r5);
  box-shadow:0 16px 48px rgba(0,0,0,.32);
}
.hero-panel-label{
  position:absolute;top:9px;left:11px;z-index:3;
  font-size:9px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;
  color:rgba(255,255,255,.9);
  background:rgba(0,0,0,.38);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  padding:4px 10px;border-radius:12px;pointer-events:none;
}

/* Ads panel (right) — hc-* classes */
.hc-wrap{overflow:hidden;position:relative}
.hc-track{display:flex;transition:transform .55s cubic-bezier(.4,0,.2,1);will-change:transform}
.hc-slide{
  min-width:100%;padding:24px 18px 20px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;min-height:292px;position:relative;overflow:hidden;
}
.hc-slide::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,.08);pointer-events:none}
.hc-slide-inner{position:relative;z-index:1}
.hc-icon{font-size:44px;margin-bottom:10px;filter:drop-shadow(0 4px 12px rgba(0,0,0,.25))}
.hc-cat{font-size:17px;font-weight:800;color:#fff;margin-bottom:4px;letter-spacing:-.2px;text-shadow:0 2px 8px rgba(0,0,0,.2)}
.hc-desc{font-size:12px;color:rgba(255,255,255,.8);margin-bottom:14px}
.hc-cta{
  display:inline-block;background:rgba(255,255,255,.2);backdrop-filter:blur(8px);
  border:1.5px solid rgba(255,255,255,.4);color:#fff;font-size:12px;font-weight:700;
  padding:7px 17px;border-radius:20px;transition:var(--t);text-decoration:none;
}
.hc-cta:hover{background:rgba(255,255,255,.32);color:#fff}
.hc-controls{display:flex;align-items:center;justify-content:center;gap:8px}
#hc-dots{display:flex;align-items:center;gap:6px}
.hc-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.25);border:none;cursor:pointer;padding:0;transition:var(--t)}
.hc-dot.on{background:#fff;width:20px;border-radius:3.5px}
.hc-arr{
  width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.15);
  border:1.5px solid rgba(255,255,255,.25);color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-size:13px;transition:var(--t);
}
.hc-arr:hover{background:rgba(255,255,255,.28)}

/* Shops panel (left) — hp-* classes */
.hp-track{display:flex;transition:transform .55s cubic-bezier(.4,0,.2,1);will-change:transform}
.hp-slide{
  min-width:100%;padding:24px 16px 20px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;min-height:292px;position:relative;overflow:hidden;
}
.hp-slide::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,.1);pointer-events:none}
.hp-shop-logo{
  width:62px;height:62px;border-radius:50%;
  border:2.5px solid rgba(255,255,255,.25);
  background:rgba(255,255,255,.13);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:10px;overflow:hidden;position:relative;z-index:1;flex-shrink:0;
}
.hp-shop-logo img{width:100%;height:100%;object-fit:cover}
.hp-shop-init{font-size:22px;font-weight:800;color:#fff}
.hp-ph-icon{font-size:40px;margin-bottom:9px;position:relative;z-index:1;filter:drop-shadow(0 3px 8px rgba(0,0,0,.22))}
.hp-name{font-size:14px;font-weight:800;color:#fff;margin-bottom:4px;letter-spacing:-.2px;text-shadow:0 2px 6px rgba(0,0,0,.25);position:relative;z-index:1;padding:0 6px;line-height:1.3}
.hp-sub{font-size:11px;color:rgba(255,255,255,.7);margin-bottom:13px;position:relative;z-index:1}

/* ── SECTIONS ────────────────────────────────────────────────────────── */
.section{padding:26px 0}
.sec-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.sec-title{font-size:18px;font-weight:800;color:var(--dark);letter-spacing:-.2px;display:flex;align-items:center;gap:7px}
.sec-link{font-size:13px;color:var(--brand-d);font-weight:600}
.sec-link:hover{color:var(--brand)}

/* ── CATEGORIES ──────────────────────────────────────────────────────── */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
@media(min-width:480px){.cat-grid{grid-template-columns:repeat(6,1fr)}}
@media(min-width:768px){.cat-grid{grid-template-columns:repeat(8,1fr)}}
@media(min-width:1024px){.cat-grid{grid-template-columns:repeat(10,1fr);gap:10px}}
.cat-item{
  display:flex;flex-direction:column;align-items:center;gap:5px;
  background:#fff;border:1px solid var(--border);border-radius:var(--r4);
  padding:13px 6px;text-align:center;transition:var(--t);cursor:pointer;
  box-shadow:var(--sh-sm);
}
.cat-item:hover{border-color:var(--brand);background:var(--brand-pale);transform:translateY(-2px);box-shadow:var(--sh-sm)}
.cat-icon{font-size:22px;line-height:1}
.cat-name{font-size:11px;font-weight:600;color:var(--grey-5);line-height:1.3}
.cat-item:hover .cat-name{color:var(--brand-dd)}

/* ── AD CARDS ────────────────────────────────────────────────────────── */
.ads-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media(min-width:480px){.ads-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:768px){.ads-grid{grid-template-columns:repeat(4,1fr)}}
@media(min-width:1024px){.ads-grid{grid-template-columns:repeat(5,1fr);gap:12px}}

.ad-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--r4);
  overflow:hidden;transition:var(--t);display:flex;flex-direction:column;position:relative;
  box-shadow:var(--sh-sm);
}
.ad-card:hover{border-color:var(--brand-light);box-shadow:var(--sh-lg);transform:translateY(-3px)}
.ad-img{aspect-ratio:4/3;overflow:hidden;background:var(--grey-1);position:relative}
.ad-img img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
.ad-card:hover .ad-img img{transform:scale(1.05)}
.ad-img-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--grey-2);font-size:30px}
.ad-badge-feat{position:absolute;top:7px;left:7px;background:var(--accent);color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px;text-transform:uppercase}
.ad-badge-shop{position:absolute;top:7px;right:7px;background:var(--brand);color:var(--dark);font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px}
.ad-body{padding:10px 12px;flex:1;display:flex;flex-direction:column}
.ad-title{font-size:13px;font-weight:600;color:var(--dark);line-height:1.4;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ad-price{font-size:16px;font-weight:800;color:var(--brand-dd);margin-top:auto;letter-spacing:-.2px}
.ad-loc{font-size:11px;color:var(--grey-4);display:flex;align-items:center;gap:3px;margin-top:5px}

/* ── SHOP CARDS ──────────────────────────────────────────────────────── */
.shops-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media(min-width:480px){.shops-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:768px){.shops-grid{grid-template-columns:repeat(4,1fr)}}
@media(min-width:1024px){.shops-grid{grid-template-columns:repeat(6,1fr)}}
.shop-card{background:#fff;border:1px solid var(--border);border-radius:var(--r4);overflow:hidden;transition:var(--t);box-shadow:var(--sh-sm)}
.shop-card:hover{border-color:var(--brand);box-shadow:var(--sh-md);transform:translateY(-2px)}
.shop-logo{width:100%;aspect-ratio:1;background:linear-gradient(145deg,var(--dark),var(--dark-2));display:flex;align-items:center;justify-content:center;overflow:hidden}
.shop-logo img{width:100%;height:100%;object-fit:cover}
.shop-init{font-size:34px;font-weight:800;color:var(--brand)}
.shop-body{padding:10px 12px}
.shop-name{font-size:13px;font-weight:700;color:var(--dark)}
.shop-city{font-size:11px;color:var(--grey-4);margin-top:3px}
/* Scroll row */
.shops-scroll{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}
.shops-scroll::-webkit-scrollbar{display:none}
.shop-sc{flex-shrink:0;width:155px;background:#fff;border:1px solid var(--border);border-radius:var(--r4);overflow:hidden;transition:var(--t);box-shadow:var(--sh-sm)}
.shop-sc:hover{border-color:var(--brand);box-shadow:var(--sh-md);transform:translateY(-2px)}
.shop-sc-logo{width:100%;height:96px;background:linear-gradient(145deg,var(--dark),var(--dark-2));display:flex;align-items:center;justify-content:center;overflow:hidden}
.shop-sc-logo img{width:100%;height:100%;object-fit:cover}

/* ── PAGE LAYOUT ─────────────────────────────────────────────────────── */
.page-layout{display:grid;gap:20px;padding:20px 0}
@media(min-width:1024px){.page-layout{grid-template-columns:240px 1fr}}
.sidebar{display:flex;flex-direction:column;gap:12px}
.sidebar-box{background:#fff;border:1px solid var(--border);border-radius:var(--r4);overflow:hidden;box-shadow:var(--sh-sm)}
.sidebar-title{font-size:11px;font-weight:700;color:var(--grey-5);padding:11px 15px;border-bottom:1px solid var(--border);background:#FAFBFD;text-transform:uppercase;letter-spacing:.6px}
/* Filter-specific form groups inside sidebar */
.sidebar-box .fg{margin-bottom:0;padding:12px 0;border-bottom:1px solid var(--border)}
.sidebar-box .fg:last-child{border-bottom:none;padding-bottom:4px}
.sidebar-box .fl{font-size:11px;font-weight:700;color:var(--grey-4);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.sidebar-box .fc{height:38px;font-size:13px}
.sidebar-box .btn{height:38px;font-size:13px;margin-top:14px}

/* ── FORMS ───────────────────────────────────────────────────────────── */
.form-box{background:#fff;border:1px solid var(--border);border-radius:var(--r5);overflow:hidden;margin-bottom:14px;box-shadow:var(--sh-sm)}
.form-box-head{padding:15px 20px;border-bottom:1px solid var(--border);background:#FAFBFD}
.form-box-title{font-size:15px;font-weight:700;color:var(--dark)}
.form-box-body{padding:20px}
.fg{margin-bottom:15px}
.fl{display:block;font-size:13px;font-weight:600;color:var(--grey-7);margin-bottom:5px}
.fl span{color:var(--grey-4);font-weight:400}
.fc{
  width:100%;height:42px;background:#fff;border:1.5px solid var(--border);
  border-radius:var(--r3);color:var(--dark);padding:0 12px;
  font-size:14px;font-family:inherit;transition:var(--t);
}
.fc:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(0,174,239,.14)}
.fc::placeholder{color:var(--grey-4)}
textarea.fc{height:auto;padding:10px 12px;resize:vertical;line-height:1.6}
select.fc{cursor:pointer}
.f-row{display:grid;gap:12px}
@media(min-width:480px){.f-row.c2{grid-template-columns:1fr 1fr}.f-row.c3{grid-template-columns:1fr 1fr 1fr}}

/* Radio cards */
.r-cards{display:flex;gap:8px;flex-wrap:wrap}
.r-card{flex:1;min-width:60px;border:1.5px solid var(--border);border-radius:var(--r3);padding:10px 6px;text-align:center;cursor:pointer;transition:var(--t);background:#fff}
.r-card input{display:none}
.r-card:hover{border-color:var(--brand-light);background:var(--brand-pale)}
.r-card.sel,.r-card:has(input:checked){border-color:var(--brand);background:var(--brand-pale)}
.r-card-icon{font-size:18px;margin-bottom:3px}
.r-card-label{font-size:11px;font-weight:600;color:var(--grey-5);line-height:1.2}
.r-card.sel .r-card-label,.r-card:has(input:checked) .r-card-label{color:var(--brand-dd)}

/* Checkbox cards */
.cb-cards{display:flex;flex-direction:column;gap:8px}
.cb-card{border:1.5px solid var(--border-2);border-radius:var(--r4);padding:12px 15px;cursor:pointer;transition:var(--t);display:flex;align-items:flex-start;gap:11px}
.cb-card:has(input:checked){border-color:var(--brand);background:var(--brand-pale)}
.cb-card input{margin-top:3px;accent-color:var(--brand);flex-shrink:0}
.cb-title{font-size:14px;font-weight:600;color:var(--dark)}
.cb-desc{font-size:12px;color:var(--grey-4);margin-top:2px}

/* Dropzone */
.dropzone{border:2px dashed var(--border-2);border-radius:var(--r4);padding:30px 16px;text-align:center;cursor:pointer;transition:var(--t)}
.dropzone:hover,.dropzone.drag-over{border-color:var(--brand);background:var(--brand-pale)}
.dz-icon{font-size:34px;color:var(--grey-4);margin-bottom:8px}
.dz-text{font-size:14px;color:var(--grey-4)}
.dz-text strong{color:var(--brand-d)}
.dz-hint{font-size:12px;color:var(--grey-4);opacity:.7;margin-top:4px}
.img-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:10px}
.img-item{position:relative;aspect-ratio:1;border-radius:var(--r2);overflow:hidden;border:1.5px solid var(--border)}
.img-item img{width:100%;height:100%;object-fit:cover}
.img-rm{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;cursor:pointer;border:none}
.img-main-badge{position:absolute;bottom:4px;left:4px;background:var(--brand);color:var(--dark);font-size:9px;font-weight:700;padding:2px 5px;border-radius:3px}

/* ── BUTTONS ─────────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  height:42px;padding:0 20px;border-radius:var(--r4);font-size:14px;
  font-weight:700;font-family:inherit;border:none;cursor:pointer;transition:var(--t);white-space:nowrap;
}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-primary{background:var(--brand);color:#fff}
.btn-primary:hover:not(:disabled){background:var(--brand-d);transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,174,239,.32);color:#fff}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover:not(:disabled){background:var(--accent-d);transform:translateY(-1px)}
.btn-dark{background:var(--dark);color:#fff}
.btn-dark:hover:not(:disabled){background:var(--dark-2)}
.btn-outline{background:transparent;color:var(--grey-7);border:1.5px solid var(--border-2)}
.btn-outline:hover:not(:disabled){border-color:var(--brand);color:var(--brand-d)}
.btn-success{background:var(--success);color:#fff}
.btn-danger{background:var(--danger);color:#fff}
.btn-xs{height:24px;padding:0 9px;font-size:11px;border-radius:var(--r2)}
.btn-sm{height:32px;padding:0 13px;font-size:12px;border-radius:var(--r3)}
.btn-lg{height:52px;padding:0 30px;font-size:16px;border-radius:var(--r5)}
.btn-full{width:100%}
.btn-icon{width:42px;padding:0}
.btn-icon.btn-sm{width:32px}

/* ── ALERTS ──────────────────────────────────────────────────────────── */
.alert{padding:12px 16px;border-radius:var(--r4);font-size:14px;margin-bottom:14px;display:flex;align-items:flex-start;gap:9px;border:1.5px solid transparent;line-height:1.5}
.alert-success{background:var(--success-bg);border-color:#6EE7B7;color:#065F46}
.alert-danger{background:var(--danger-bg);border-color:#FCA5A5;color:#991B1B}
.alert-warning{background:var(--warning-bg);border-color:#FCD34D;color:#92400E}
.alert-info{background:var(--brand-pale);border-color:var(--brand-light);color:var(--brand-dd)}
/* Keep old class names for backward compat */
/* ── Google OAuth button ──────────────────────────────────────── */
.btn-google{
  display:flex;align-items:center;justify-content:center;gap:10px;
  width:100%;padding:11px 16px;border:1.5px solid var(--grey-2);border-radius:var(--r3);
  background:#fff;color:var(--grey-7);font-size:14px;font-weight:600;
  text-decoration:none;transition:var(--t);cursor:pointer;margin-bottom:14px;
}
.btn-google:hover{background:#f8f9fa;border-color:#ccc;color:var(--dark)}
.auth-divider{display:flex;align-items:center;gap:10px;margin:14px 0;color:var(--grey-4);font-size:12px;font-weight:500}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--grey-2)}

.peta-alert{padding:12px 16px;border-radius:var(--r4);font-size:14px;margin-bottom:14px;display:flex;align-items:flex-start;gap:9px;border:1.5px solid transparent;line-height:1.5}
.peta-alert-success{background:var(--success-bg);border-color:#6EE7B7;color:#065F46}
.peta-alert-danger{background:var(--danger-bg);border-color:#FCA5A5;color:#991B1B}
.peta-alert-warning{background:var(--warning-bg);border-color:#FCD34D;color:#92400E}
.peta-alert-info{background:var(--brand-pale);border-color:var(--brand-light);color:var(--brand-dd)}

.flash-wrap{position:fixed;top:68px;right:16px;z-index:2000;display:flex;flex-direction:column;gap:8px;max-width:340px}
.flash-msg{background:#fff;border-radius:var(--r4);box-shadow:var(--sh-xl);padding:12px 16px;display:flex;align-items:flex-start;gap:10px;border-left:4px solid var(--success);animation:flash-in .22s ease}
.flash-msg.err{border-left-color:var(--danger)}
.flash-msg.warn{border-left-color:var(--warning)}
@keyframes flash-in{from{transform:translateX(110%);opacity:0}to{transform:translateX(0);opacity:1}}

/* ── BADGES ──────────────────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.badge-success,.status-published{background:var(--success-bg);color:#065F46}
.badge-pending,.status-pending{background:var(--warning-bg);color:#92400E}
.badge-draft,.status-draft{background:var(--grey-1);color:var(--grey-5)}
.badge-danger,.status-rejected,.status-danger{background:var(--danger-bg);color:#991B1B}
.badge-info,.status-info{background:var(--info-bg);color:#1E40AF}
.status-success{background:var(--success-bg);color:#065F46}
.status-warning{background:var(--warning-bg);color:#92400E}

/* ── CARD ────────────────────────────────────────────────────────────── */
.card{background:#fff;border:1px solid var(--border);border-radius:var(--r5);overflow:hidden;box-shadow:var(--sh-sm)}
.card-head,.card-header{padding:13px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:#FAFBFD}
.card-title{font-size:15px;font-weight:700;color:var(--dark)}
.card-body{padding:18px}

/* ── TABLE ───────────────────────────────────────────────────────────── */
.tbl{width:100%;border-collapse:collapse}
.tbl th{background:#FAFBFD;padding:9px 14px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--grey-5);text-align:left;border-bottom:1.5px solid var(--border);white-space:nowrap}
.tbl td{padding:11px 14px;font-size:13px;color:var(--grey-7);border-bottom:1px solid var(--border)}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:var(--grey-1)}
.tbl-wrap{overflow-x:auto}

/* ── AD DETAIL ───────────────────────────────────────────────────────── */
.gal{background:#fff;border:1px solid var(--border);border-radius:var(--r5);overflow:hidden;margin-bottom:14px;box-shadow:var(--sh-sm)}
.gal-main{position:relative;background:var(--grey-1);aspect-ratio:4/3;overflow:hidden}
.gal-main img{width:100%;height:100%;object-fit:contain}
.gal-nav{position:absolute;top:50%;transform:translateY(-50%);width:34px;height:34px;border-radius:50%;background:rgba(0,0,0,.45);color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;transition:var(--t)}
.gal-nav:hover{background:rgba(0,0,0,.7)}
.gal-prev{left:8px}.gal-next{right:8px}
.gal-count{position:absolute;bottom:8px;right:8px;background:rgba(0,0,0,.5);color:#fff;font-size:12px;padding:3px 9px;border-radius:20px}
.gal-thumbs{display:flex;gap:6px;padding:9px;overflow-x:auto;scrollbar-width:none}
.gal-thumbs::-webkit-scrollbar{display:none}
.gal-thumb{flex-shrink:0;width:62px;height:50px;border-radius:var(--r2);overflow:hidden;border:2px solid transparent;cursor:pointer;transition:var(--t)}
.gal-thumb img{width:100%;height:100%;object-fit:cover}
.gal-thumb.on{border-color:var(--brand)}

.price-card{background:#fff;border:1px solid var(--border);border-radius:var(--r5);padding:20px;position:sticky;top:68px;box-shadow:var(--sh-sm)}
.price-amount{font-size:28px;font-weight:800;color:var(--brand-dd);margin:8px 0;letter-spacing:-.5px}
.price-title{font-size:16px;font-weight:700;color:var(--dark);line-height:1.4;margin-bottom:12px}
.meta-pills{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:12px}
.meta-pill{background:var(--grey-1);color:var(--grey-5);border:1px solid var(--border);border-radius:20px;font-size:12px;font-weight:500;padding:3px 10px}
.meta-pill.blue{background:var(--brand-pale);color:var(--brand-dd);border-color:var(--brand-light)}
.con-btn{display:flex;align-items:center;justify-content:center;gap:8px;height:48px;border-radius:var(--r4);font-size:15px;font-weight:700;width:100%;margin-bottom:8px;transition:var(--t);text-decoration:none;cursor:pointer;border:none}
.con-order{background:var(--accent);color:#fff}
.con-order:hover{background:var(--accent-d);transform:translateY(-1px)}
.con-phone{background:#fff;color:var(--dark);border:2px solid var(--border-2)}
.con-phone:hover{border-color:var(--brand);color:var(--brand-d)}
.con-wa{background:#25D366;color:#fff}
.con-wa:hover{background:#20BD5A}

/* ── SHOP DETAIL ─────────────────────────────────────────────────────── */
.shop-hero-wrap{position:relative;border-radius:var(--r5);overflow:hidden;background:linear-gradient(135deg,var(--dark),var(--dark-2));height:210px;margin-bottom:18px}
@media(min-width:768px){.shop-hero-wrap{height:270px}}
.shop-hero-banner{width:100%;height:100%;object-fit:cover;opacity:.6}
.shop-hero-ov{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.8));padding:20px;display:flex;align-items:flex-end;gap:15px}
.shop-hero-logo{width:70px;height:70px;border-radius:var(--r4);border:3px solid rgba(255,255,255,.9);overflow:hidden;flex-shrink:0;background:var(--dark);display:flex;align-items:center;justify-content:center}
.shop-hero-logo img{width:100%;height:100%;object-fit:cover}
.shop-hero-name{font-size:20px;font-weight:800;color:#fff}
.shop-hero-city{font-size:13px;color:rgba(255,255,255,.65);margin-top:3px}

/* ── CHECKOUT ────────────────────────────────────────────────────────── */
.co-item{display:flex;gap:13px;align-items:flex-start;background:#fff;border:1px solid var(--border);border-radius:var(--r4);padding:14px;margin-bottom:14px;box-shadow:var(--sh-sm)}
.co-img{width:80px;height:66px;border-radius:var(--r3);overflow:hidden;flex-shrink:0;background:var(--grey-1)}
.co-img img{width:100%;height:100%;object-fit:cover}

/* ── STATS GRID ──────────────────────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media(min-width:480px){.stats-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:768px){.stats-grid{grid-template-columns:repeat(6,1fr)}}
.stat-box{background:#fff;border:1px solid var(--border);border-radius:var(--r4);padding:15px 10px;text-align:center;box-shadow:var(--sh-sm)}
.stat-box.hl{background:var(--brand-pale);border-color:var(--brand-light)}
.stat-n{font-size:24px;font-weight:800;color:var(--brand-dd);letter-spacing:-.5px}
.stat-l{font-size:11px;color:var(--grey-4);margin-top:3px;font-weight:500}

/* ── BANK DETAILS ────────────────────────────────────────────────────── */
.bank-box{background:var(--brand-pale);border:1.5px solid var(--brand-light);border-radius:var(--r4);padding:15px;margin-bottom:14px}
.bank-title{font-size:13px;font-weight:700;color:var(--brand-dd);margin-bottom:9px}
.bank-row{display:flex;gap:12px;margin-bottom:5px;font-size:13px}
.bank-label{font-weight:600;color:var(--grey-5);min-width:110px;flex-shrink:0}
.bank-val{color:var(--dark)}
.bank-acc{font-family:'Courier New',monospace;font-weight:800;font-size:15px;color:var(--brand-dd)}

/* ── TABS ────────────────────────────────────────────────────────────── */
.tabs{display:flex;border-bottom:2px solid var(--border);margin-bottom:14px;overflow-x:auto;scrollbar-width:none}
.tabs::-webkit-scrollbar{display:none}
.tab{padding:10px 17px;font-size:14px;font-weight:600;color:var(--grey-4);border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;margin-bottom:-2px;transition:var(--t);background:none;border-top:none;border-left:none;border-right:none;font-family:inherit}
.tab:hover{color:var(--dark)}
.tab.active{color:var(--brand-dd);border-bottom-color:var(--brand)}

/* ── ADMIN ───────────────────────────────────────────────────────────── */
.admin-wrap{display:flex;min-height:calc(100vh - 60px)}
.admin-side{width:220px;flex-shrink:0;background:var(--dark);padding:16px 0;border-right:1px solid rgba(255,255,255,.06)}
.admin-nav a{display:flex;align-items:center;gap:10px;padding:11px 18px;color:rgba(255,255,255,.55);font-size:14px;font-weight:500;transition:var(--t);border-left:3px solid transparent}
.admin-nav a:hover,.admin-nav a.on{color:#fff;background:rgba(255,255,255,.07);border-left-color:var(--brand)}
.admin-nav-sec,.admin-nav-section{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:rgba(255,255,255,.22);padding:13px 18px 4px}
.admin-body{flex:1;padding:22px;background:#F5F7FA;overflow:auto}
.admin-layout{display:flex;min-height:calc(100vh - 60px)}
.admin-sidebar{width:220px;flex-shrink:0;background:var(--dark);padding:16px 0;border-right:1px solid rgba(255,255,255,.06)}
.admin-nav a.active{color:#fff;background:rgba(255,255,255,.07);border-left-color:var(--brand)}
.stat-card{background:#fff;border:1.5px solid var(--grey-2);border-radius:var(--r3);padding:16px 18px}
.stat-number{font-size:28px;font-weight:800;color:var(--dark);line-height:1}
.stat-label{font-size:12px;color:var(--grey-5);margin-top:4px;font-weight:500}
@media(max-width:1023px){.admin-side,.admin-sidebar{display:none}.admin-body{padding:15px}}

/* ── FOOTER ──────────────────────────────────────────────────────────── */
.footer{background:var(--dark);border-top:1px solid rgba(255,255,255,.06);color:rgba(255,255,255,.5);padding:38px 0 22px;margin-top:44px}
.footer-grid{display:grid;gap:26px;grid-template-columns:1fr}
@media(min-width:600px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}}
.footer-logo{height:44px;width:auto;margin-bottom:12px}
.footer-desc{font-size:13px;line-height:1.8;max-width:230px}
.footer-col-title{font-size:11px;font-weight:700;color:rgba(255,255,255,.9);text-transform:uppercase;letter-spacing:.7px;margin-bottom:12px}
.footer-col a{display:block;color:rgba(255,255,255,.42);font-size:13px;margin-bottom:7px;transition:var(--t)}
.footer-col a:hover{color:var(--brand)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);margin-top:26px;padding-top:16px;display:flex;align-items:center;justify-content:space-between;font-size:12px;flex-wrap:wrap;gap:8px}

/* ── BOTTOM NAV (mobile) ─────────────────────────────────────────────── */
.bot-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--dark);border-top:1px solid rgba(255,255,255,.09);z-index:900;padding-bottom:env(safe-area-inset-bottom)}
@media(max-width:767px){.bot-nav{display:flex}}
@media(max-width:767px){body{padding-bottom:66px}}
.bot-nav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 4px;color:rgba(255,255,255,.38);font-size:10px;font-weight:600;transition:var(--t)}
.bot-nav a:hover,.bot-nav a.on{color:var(--brand)}
.bot-nav a.post-fab{position:relative;top:-10px}
.fab-circle{width:48px;height:48px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;box-shadow:0 4px 14px rgba(255,107,53,.45);transition:var(--t)}
.bot-nav a.post-fab:hover .fab-circle{background:var(--accent-d);transform:scale(1.08)}

/* ── HTMX ────────────────────────────────────────────────────────────── */
.htmx-indicator{opacity:0;transition:opacity .18s;display:flex;align-items:center;gap:6px}
.htmx-request .htmx-indicator,.htmx-indicator.htmx-request{opacity:1}
.spin{width:17px;height:17px;border:2.5px solid var(--brand-light);border-top-color:var(--brand);border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── FILTER DRAWER ───────────────────────────────────────────────────── */
.fd-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:1100}
.fd-bg.on{display:block}
.fd{position:fixed;bottom:0;left:0;right:0;background:#fff;border-radius:var(--r6) var(--r6) 0 0;z-index:1200;max-height:88vh;overflow-y:auto;transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);padding-bottom:env(safe-area-inset-bottom)}
.fd.on{transform:translateY(0)}
.fd-handle{width:38px;height:4px;background:var(--border-2);border-radius:2px;margin:11px auto 0}
.fd-head{padding:15px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.fd-title{font-size:16px;font-weight:700;color:var(--dark)}
.fd-body{padding:15px 18px}
.fd-foot{padding:11px 18px;border-top:1px solid var(--border);position:sticky;bottom:0;background:#fff}

/* ── BREADCRUMB ──────────────────────────────────────────────────────── */
.bc{display:flex;align-items:center;flex-wrap:wrap;gap:5px;font-size:12px;color:var(--grey-4);margin-bottom:14px}
.bc a{color:var(--grey-4)}.bc a:hover{color:var(--brand-d)}.bc-sep{color:var(--grey-2)}

/* ── EMPTY STATE ─────────────────────────────────────────────────────── */
.empty{text-align:center;padding:50px 18px;background:#fff;border-radius:var(--r5);border:1.5px dashed var(--border)}
.empty-icon{font-size:50px;margin-bottom:12px}
.empty-title{font-size:17px;font-weight:700;color:var(--dark);margin-bottom:5px}
.empty-text{font-size:14px;color:var(--grey-4)}

/* ── LOAD MORE ───────────────────────────────────────────────────────── */
.load-more{text-align:center;padding:22px 0}

/* ── SELL / CTA BANNER ───────────────────────────────────────────────── */
.sell-cta{
  background:linear-gradient(135deg,var(--brand) 0%,var(--brand-dd) 100%);
  border-radius:var(--r6);padding:44px 28px;text-align:center;
  position:relative;overflow:hidden;
}
.sell-cta::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 60% at 80% 20%,rgba(255,255,255,.12) 0%,transparent 60%);
  pointer-events:none;
}
.sell-cta-inner{position:relative;z-index:1}
.sell-cta h2{font-size:26px;font-weight:800;color:#fff;margin-bottom:9px;letter-spacing:-.3px}
.sell-cta p{color:rgba(255,255,255,.75);font-size:15px;margin-bottom:24px}
.btn-white{background:#fff;color:var(--brand-dd);font-weight:700}
.btn-white:hover:not(:disabled){background:var(--brand-pale);color:var(--brand-dd)}
.btn-ghost{background:rgba(255,255,255,.15);color:#fff;border:1.5px solid rgba(255,255,255,.35);font-weight:700}
.btn-ghost:hover:not(:disabled){background:rgba(255,255,255,.25);color:#fff}

/* ── MISSING TOKEN ALIASES ───────────────────────────────────────────── */
:root{
  --grey-mid:    var(--grey-5);
  --grey-light:  var(--grey-4);
  --brand-deeper:var(--brand-dd);
  --radius-xl:   var(--r6);
  --radius-md:   var(--r3);
  --radius-sm:   var(--r2);
}

/* ── FORM CARDS ──────────────────────────────────────────────────────── */
/* Used in ads/create, shops/setup, orders/checkout, payments */
.form-card{background:#fff;border:1px solid var(--border);border-radius:var(--r5);overflow:hidden;margin-bottom:16px;box-shadow:var(--sh-sm)}
.form-card-header{padding:13px 20px;border-bottom:1px solid var(--border);background:#FAFBFD;display:flex;align-items:center;justify-content:space-between}
.form-card-title{font-size:14px;font-weight:700;color:var(--dark)}
.form-card-body{padding:20px}

/* ── FORM ALIASES (mirrors .fg / .fl / .fc for templates using longer names) */
.form-group{margin-bottom:15px}
.form-label{display:block;font-size:13px;font-weight:600;color:var(--grey-7);margin-bottom:5px}
.form-label span{color:var(--grey-4);font-weight:400}
.form-control{
  width:100%;height:42px;background:#fff;border:1.5px solid var(--border);
  border-radius:var(--r3);color:var(--dark);padding:0 12px;
  font-size:14px;font-family:inherit;transition:var(--t);
}
.form-control:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(0,174,239,.14)}
.form-control::placeholder{color:var(--grey-4)}
textarea.form-control{height:auto;padding:10px 12px;resize:vertical;line-height:1.6}
select.form-control{cursor:pointer}
.form-row{display:grid;gap:12px}
@media(min-width:480px){.form-row.cols-2{grid-template-columns:1fr 1fr}.form-row.cols-3{grid-template-columns:1fr 1fr 1fr}}

/* ── CHECKBOX CARDS (shops/setup, orders/checkout) ───────────────────── */
.checkbox-cards{display:flex;flex-direction:column;gap:8px}
.checkbox-card{
  border:1.5px solid var(--border);border-radius:var(--r4);
  padding:13px 15px;cursor:pointer;transition:var(--t);
  display:flex;align-items:flex-start;gap:12px;background:#fff;
}
.checkbox-card:hover{border-color:var(--brand-light);background:var(--brand-pale)}
.checkbox-card:has(input:checked){border-color:var(--brand);background:var(--brand-pale)}
.checkbox-card input{margin-top:3px;accent-color:var(--brand);flex-shrink:0}
.checkbox-card-title{font-size:14px;font-weight:600;color:var(--dark)}
.checkbox-card-desc{font-size:12px;color:var(--grey-4);margin-top:2px}

/* ── RADIO CARDS (ads/create condition — different from .r-card) ─────── */
.radio-cards{display:flex;gap:8px;flex-wrap:wrap}
.radio-card{
  flex:1;min-width:80px;border:1.5px solid var(--border);border-radius:var(--r3);
  padding:10px 8px;text-align:center;cursor:pointer;transition:var(--t);background:#fff;
}
.radio-card input{display:none}
.radio-card:hover{border-color:var(--brand-light);background:var(--brand-pale)}
.radio-card.selected,.radio-card:has(input:checked){border-color:var(--brand);background:var(--brand-pale)}
.radio-card-icon{font-size:18px;margin-bottom:3px}
.radio-card-label{font-size:12px;font-weight:600;color:var(--grey-5)}
.radio-card.selected .radio-card-label,.radio-card:has(input:checked) .radio-card-label{color:var(--brand-dd)}

/* ── DROPZONE (ads/create — extended class names) ────────────────────── */
.dropzone-icon{font-size:36px;color:var(--grey-4);margin-bottom:8px}
.dropzone-text{font-size:14px;color:var(--grey-5)}
.dropzone-text strong{color:var(--brand-d)}
.dropzone-hint{font-size:12px;color:var(--grey-4);opacity:.75;margin-top:4px}

/* ── IMAGE PREVIEW GRID (ads/create) ─────────────────────────────────── */
.img-preview-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:12px}
.img-preview-item{position:relative;aspect-ratio:1;border-radius:var(--r2);overflow:hidden;border:1.5px solid var(--border)}
.img-preview-item img{width:100%;height:100%;object-fit:cover}
.img-preview-main{position:absolute;bottom:4px;left:4px;background:var(--brand);color:#fff;font-size:9px;font-weight:700;padding:2px 6px;border-radius:3px}
.img-preview-remove{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:50%;background:rgba(0,0,0,.55);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;cursor:pointer;border:none;line-height:1}

/* ── CHECKOUT ITEM (orders/checkout) ─────────────────────────────────── */
.checkout-item{display:flex;gap:13px;align-items:flex-start;background:#fff;border:1px solid var(--border);border-radius:var(--r4);padding:14px;margin-bottom:16px;box-shadow:var(--sh-sm)}
.checkout-item-img{width:80px;height:66px;border-radius:var(--r3);overflow:hidden;flex-shrink:0;background:var(--grey-1)}
.checkout-item-img img{width:100%;height:100%;object-fit:cover}
.checkout-item-title{font-size:14px;font-weight:600;color:var(--dark)}
.checkout-item-price{font-size:18px;font-weight:800;color:var(--brand-dd);margin-top:4px;letter-spacing:-.2px}
.checkout-item-shop{font-size:12px;color:var(--grey-4);margin-top:3px}

/* ── BANK DETAILS (payments/ad_payment) ─────────────────────────────── */
.bank-details{background:var(--brand-pale);border:1.5px solid var(--brand-light);border-radius:var(--r4);padding:16px;margin-bottom:16px}
.bank-details-title{font-size:13px;font-weight:700;color:var(--brand-dd);margin-bottom:10px;text-transform:uppercase;letter-spacing:.4px}
.bank-detail-row{display:flex;gap:12px;margin-bottom:6px;font-size:13px;align-items:baseline}
.bank-detail-label{font-weight:600;color:var(--grey-5);min-width:130px;flex-shrink:0;text-transform:capitalize}
.bank-detail-value{color:var(--dark)}
.bank-detail-account{font-family:'Courier New',monospace;font-weight:800;font-size:15px;color:var(--brand-dd)}

/* ── STATUS BADGE (alias for .badge, used in payments/ad_payment) ────── */
.status-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.status-badge.status-pending{background:var(--warning-bg);color:#92400E}
.status-badge.status-awaiting-payment{background:var(--info-bg);color:#1E40AF}
.status-badge.status-published{background:var(--success-bg);color:#065F46}
.status-badge.status-rejected{background:var(--danger-bg);color:#991B1B}
.status-badge.status-draft{background:var(--grey-1);color:var(--grey-5)}

/* ── SEARCH / SECTION HEADINGS (search.html uses different classes) ── */
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.section-title{font-size:17px;font-weight:800;color:var(--dark);letter-spacing:-.2px}

/* ── EMPTY STATE (alternate class names used in search.html) ────────── */
.empty-state{text-align:center;padding:50px 18px;background:#fff;border-radius:var(--r5);border:1.5px dashed var(--border)}
.empty-state-icon{font-size:50px;margin-bottom:12px}
.empty-state-title{font-size:17px;font-weight:700;color:var(--dark);margin-bottom:5px}
.empty-state-text{font-size:14px;color:var(--grey-4)}

/* ── COLOMBO MARKET SECTION ──────────────────────────────────────────── */
.colombo-badge{
  display:inline-block;font-size:11px;font-weight:600;
  background:linear-gradient(135deg,var(--brand),var(--brand-dd));
  color:#fff;padding:2px 9px;border-radius:20px;margin-left:8px;vertical-align:middle;
}
/* Scroll row — used in listing page filter bar */
.colombo-roads{
  display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;
  scrollbar-width:none;flex-wrap:wrap;margin-top:12px;
}
.colombo-roads::-webkit-scrollbar{display:none}
/* Grid — used on homepage to show all roads */
.colombo-roads-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(148px,1fr));
  gap:8px;margin-top:12px;
}
.croad-chip{
  display:inline-flex;align-items:center;justify-content:center;
  padding:7px 14px;border-radius:20px;font-size:12px;font-weight:600;
  background:#fff;border:1.5px solid var(--border);color:var(--grey-5);
  transition:var(--t);white-space:nowrap;text-align:center;
}
.croad-chip:hover{border-color:var(--brand);color:var(--brand-d);background:var(--brand-pale)}
.croad-chip.on{background:var(--brand);border-color:var(--brand);color:#fff}
.croad-chip.croad-all{background:var(--dark);border-color:var(--dark);color:#fff;font-weight:700;}
.croad-chip.croad-all:hover{background:var(--dark-2);color:#fff}
.croad-chip.croad-more{border-style:dashed}
.colombo-cats{
  display:flex;gap:8px;flex-wrap:wrap;padding-top:4px;
}
.colombo-cats a{
  display:inline-flex;align-items:center;gap:5px;
  font-size:12px;font-weight:600;color:var(--grey-5);
  background:var(--grey-1);border:1px solid var(--border);
  padding:6px 14px;border-radius:20px;transition:var(--t);
}
.colombo-cats a:hover{background:var(--brand-pale);color:var(--brand-d);border-color:var(--brand-light)}

/* ── PAGE HEADER ─────────────────────────────────────────────────────── */
.page-header{padding:20px 0 4px}
.page-title{font-size:22px;font-weight:800;color:var(--dark);letter-spacing:-.3px}
.page-sub{font-size:14px;color:var(--grey-5);margin-top:4px}
.page-wrap{max-width:680px}
.page-wrap-sm{max-width:560px}

/* ── UTILS ───────────────────────────────────────────────────────────── */
.text-brand{color:var(--brand-dd)}.text-muted{color:var(--grey-4)}.text-sm{font-size:13px}.text-xs{font-size:11px}
.fw-7{font-weight:700}.fw-8{font-weight:800}
.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}
.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}
.d-flex{display:flex}.ai-c{align-items:center}.jb{justify-content:space-between}.gap-8{gap:8px}.gap-12{gap:12px}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* ── COLOMBO FEATURED SHOPS GRID ─────────────────────────────────────── */
.colombo-feat-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:12px;
}
@media(min-width:480px){.colombo-feat-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:768px){.colombo-feat-grid{grid-template-columns:repeat(4,1fr)}}

.colombo-feat-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--r4);
  overflow:hidden;transition:var(--t);box-shadow:var(--sh-sm);
  display:flex;flex-direction:column;
}
.colombo-feat-card:hover{border-color:var(--brand);box-shadow:var(--sh-md);transform:translateY(-3px)}

.colombo-feat-logo{
  width:100%;height:120px;
  background:linear-gradient(145deg,var(--dark),var(--dark-2));
  display:flex;align-items:center;justify-content:center;overflow:hidden;
  position:relative;
}
@media(min-width:768px){.colombo-feat-logo{height:140px}}
.colombo-feat-logo img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
.colombo-feat-card:hover .colombo-feat-logo img{transform:scale(1.06)}

.colombo-feat-body{padding:11px 13px;flex:1}
.colombo-feat-name{font-size:13px;font-weight:700;color:var(--dark);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.colombo-feat-road{font-size:11px;color:var(--brand-dd);font-weight:600;margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.colombo-feat-open{font-size:10px;color:var(--success);font-weight:600;margin-top:5px}

.colombo-more-head{
  display:flex;align-items:center;justify-content:space-between;
  margin:18px 0 10px;font-size:13px;font-weight:700;color:var(--dark);
}
.colombo-more-head a{font-size:12px;color:var(--brand-d);font-weight:600}
.colombo-more-head a:hover{color:var(--brand)}

/* ── MOBILE CORE FIXES ───────────────────────────────────────────────── */
/* Using clip (not hidden) so position:fixed navbar/bottom-nav still anchors correctly */
html{overflow-x:clip}
body{overflow-x:clip}
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}

/* ── MOBILE — HERO ───────────────────────────────────────────────────── */
@media(max-width:640px){
  .hero{padding:28px 0 24px}
  .hero-sub-row{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:16px}
  .hero-bar input{height:48px;font-size:14px}
  .hero-bar button{height:48px;padding:0 18px;font-size:14px}
  .hero-pills{gap:6px}
  .hero-pills a{padding:5px 11px;font-size:11px}
  .hero-stats{gap:14px;margin-top:18px}
  .hero-stat strong{font-size:17px}
}

/* ── MOBILE — CATEGORY GRID ──────────────────────────────────────────── */
@media(max-width:479px){
  .cat-item{padding:11px 4px}
  .cat-icon{font-size:20px}
  .cat-name{font-size:10px}
}

/* ── MOBILE — FORMS ──────────────────────────────────────────────────── */
@media(max-width:479px){
  .f-row.c2,.f-row.c3{grid-template-columns:1fr}
  .form-row.cols-2,.form-row.cols-3{grid-template-columns:1fr}
  .r-cards{flex-direction:column}
  .r-card{min-width:unset;flex:none}
}

/* ── MOBILE — AD DETAIL PRICE CARD ──────────────────────────────────── */
@media(max-width:1023px){
  .price-card{position:static}
}

/* ── MOBILE — BOTTOM NAV SAFE AREA ──────────────────────────────────── */
@media(max-width:767px){
  .footer{margin-bottom:0}
  main{padding-bottom:0}
}

/* ── SHOP LISTING — COLOMBO PAGE BANNER ──────────────────────────────── */
.colombo-page-banner{
  background:linear-gradient(135deg,#0C1E30 0%,#0A3349 55%,#075A8A 100%);
  border-radius:var(--r5);padding:28px 26px 24px;margin:20px 0 14px;
  position:relative;overflow:hidden;
}
.colombo-page-banner::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 80% at 90% 50%,rgba(0,174,239,.16) 0%,transparent 60%);
  pointer-events:none;
}
.colombo-page-banner-inner{
  position:relative;z-index:1;
  display:flex;align-items:flex-end;justify-content:space-between;
  flex-wrap:wrap;gap:16px;
}
.colombo-page-tag{
  font-size:11px;font-weight:600;color:rgba(255,255,255,.6);
  display:block;margin-bottom:8px;letter-spacing:.3px;
}
.colombo-page-title{
  font-size:clamp(20px,4vw,28px);font-weight:800;color:#fff;
  letter-spacing:-.3px;margin-bottom:6px;line-height:1.15;
}
.colombo-page-sub{font-size:13px;color:rgba(255,255,255,.58);line-height:1.5}
.colombo-page-stats{display:flex;gap:20px;flex-shrink:0}
.colombo-stat{text-align:center}
.colombo-stat strong{display:block;font-size:22px;font-weight:800;color:#fff;letter-spacing:-.3px}
.colombo-stat span{font-size:10px;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.4px}
@media(max-width:540px){.colombo-page-stats{display:none}}

/* ── SHOP LISTING — MODE TOGGLE ──────────────────────────────────────── */
.shop-mode-toggle{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.smt{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 18px;border-radius:22px;font-size:13px;font-weight:700;
  color:var(--grey-5);background:var(--grey-1);border:1.5px solid var(--border);
  transition:var(--t);
}
.smt:hover{border-color:var(--brand);color:var(--brand-d);background:var(--brand-pale)}
.smt-on{background:var(--dark);border-color:var(--dark);color:#fff}
.smt-on:hover{background:var(--dark-2);color:#fff;border-color:var(--dark-2)}

/* ── SHOP LISTING — STRUCTURED FILTER CARD ───────────────────────────── */
.shop-filter-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--r4);
  padding:14px 16px;box-shadow:var(--sh-sm);margin-bottom:16px;
}
.shop-filter-row{display:flex;align-items:flex-start;gap:10px}
.shop-filter-label{
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;
  color:var(--grey-4);white-space:nowrap;padding-top:7px;min-width:68px;flex-shrink:0;
}
@media(max-width:479px){.shop-filter-label{display:none}}
.shop-filter-chips{display:flex;flex-wrap:wrap;gap:6px}
.sfc{
  display:inline-flex;align-items:center;gap:4px;
  padding:6px 13px;border-radius:20px;font-size:12px;font-weight:600;
  background:var(--grey-1);border:1.5px solid var(--border);color:var(--grey-5);
  transition:var(--t);white-space:nowrap;
}
.sfc:hover{border-color:var(--brand);color:var(--brand-d);background:var(--brand-pale)}
.sfc-on{background:var(--brand);border-color:var(--brand);color:#fff}
.sfc-on:hover{background:var(--brand-d);color:#fff;border-color:var(--brand-d)}
.shop-filter-divider{border:none;border-top:1px dashed var(--border);margin:10px 0}
.shops-result-count{font-size:13px;color:var(--grey-5);margin-bottom:14px}
.shops-result-count strong{color:var(--dark)}

/* ═══════════════════════════════════════════════════════════
   AD PROMOTIONS — Top Ad, Bump Up, Featured
   ═══════════════════════════════════════════════════════════ */

/* Promotion badges on ad cards */
.ad-badge-feat{
  position:absolute;top:8px;left:8px;
  padding:3px 8px;border-radius:4px;font-size:10px;font-weight:700;
  letter-spacing:.03em;color:#fff;pointer-events:none;
}
.ad-badge-top{background:linear-gradient(135deg,#f59e0b,#d97706)!important;}
.ad-badge-bump{background:linear-gradient(135deg,#8b5cf6,#7c3aed)!important;}

/* Detail page gallery badges */
.ad-badge{
  position:absolute;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:700;
  letter-spacing:.03em;color:#fff;pointer-events:none;
}
.ad-badge-top{background:linear-gradient(135deg,#f59e0b,#d97706);}
.ad-badge-bump{background:linear-gradient(135deg,#8b5cf6,#7c3aed);}
.ad-badge-featured{background:linear-gradient(135deg,#00aeef,#0091c7);}

/* Ad card highlight borders for promoted ads */
.ad-card-top{outline:2px solid #f59e0b;outline-offset:-1px;}
.ad-card-bump{outline:2px solid #8b5cf6;outline-offset:-1px;}

/* Tier divider banners in ads grid */
.promo-tier-banner{
  display:flex;align-items:center;gap:8px;
  padding:7px 14px;border-radius:8px;font-size:12px;font-weight:700;
  letter-spacing:.04em;margin-bottom:4px;
}
.promo-tier-icon{font-size:15px;}
.promo-tier-note{font-size:11px;font-weight:500;margin-left:4px;opacity:.75;}
.promo-tier-top{background:linear-gradient(90deg,#fef3c7,#fde68a);color:#92400e;border:1px solid #fcd34d;}
.promo-tier-bump{background:linear-gradient(90deg,#ede9fe,#ddd6fe);color:#5b21b6;border:1px solid #c4b5fd;}
.promo-tier-regular{background:var(--grey-1);color:var(--grey-5);border:1px solid var(--grey-2);}

/* Active promotion status badges on ad detail page */
.promo-active-badge{
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 10px;border-radius:6px;font-size:12px;font-weight:600;
  margin-bottom:6px;width:100%;box-sizing:border-box;
}
.promo-active-top{background:#fef3c7;color:#92400e;border:1px solid #fcd34d;}
.promo-active-bump{background:#ede9fe;color:#5b21b6;border:1px solid #c4b5fd;}
.promo-active-featured{background:#e0f2fe;color:#0369a1;border:1px solid #7dd3fc;}

/* ── Promotion request form ──────────────────────────────── */
.promo-ad-summary{
  background:var(--grey-1);border-radius:8px;padding:12px 16px;
  margin-bottom:16px;border:1px solid var(--grey-2);
}
.promo-ad-title{font-weight:700;font-size:15px;color:var(--dark);}
.promo-ad-price{font-size:13px;font-weight:700;color:var(--brand-dd);margin-top:2px;}
.promo-ad-city{font-size:12px;color:var(--grey-5);margin-top:2px;}

.promo-feature-cards{display:flex;flex-direction:column;gap:10px;}
.promo-feature-card{
  display:flex;align-items:flex-start;gap:12px;
  padding:14px;border-radius:10px;border:2px solid var(--grey-2);
  cursor:pointer;transition:var(--t);background:#fff;
}
.promo-feature-card:hover{border-color:var(--brand);background:var(--brand-pale);}
.promo-feature-card input[type=checkbox]{
  margin-top:3px;flex-shrink:0;
  width:17px;height:17px;accent-color:var(--brand);cursor:pointer;
}
.promo-feature-card:has(input:checked){
  border-color:var(--brand);background:var(--brand-pale);
}
.promo-feature-card:has(input:disabled){
  opacity:.7;cursor:default;
}
.promo-feature-pending{border-color:#fcd34d;background:#fefce8;}
.promo-feature-body{display:flex;align-items:flex-start;gap:10px;flex:1;}
.promo-feature-icon{
  font-size:22px;width:36px;height:36px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.promo-icon-top{background:#fef3c7;}
.promo-icon-bump{background:#ede9fe;}
.promo-icon-featured{background:#e0f2fe;}
.promo-feature-name{font-weight:700;font-size:14px;color:var(--dark);}
.promo-feature-desc{font-size:12px;color:var(--grey-5);margin-top:3px;line-height:1.5;}
.promo-feature-status{font-size:11px;font-weight:600;margin-top:5px;padding:3px 7px;border-radius:4px;display:inline-block;}
.promo-status-active{background:#d1fae5;color:#065f46;}
.promo-status-pending{background:#fef3c7;color:#92400e;}

/* ── My requests / admin request list ───────────────────── */
.promo-req-type-badge{
  padding:5px 12px;border-radius:6px;font-size:12px;font-weight:700;
  white-space:nowrap;flex-shrink:0;
}
.promo-req-top{background:#fef3c7;color:#92400e;border:1px solid #fcd34d;}
.promo-req-bump{background:#ede9fe;color:#5b21b6;border:1px solid #c4b5fd;}
.promo-req-featured{background:#e0f2fe;color:#0369a1;border:1px solid #7dd3fc;}

/* ── Admin dot indicators ────────────────────────────────── */
.promo-dot{font-size:14px;vertical-align:middle;margin-left:3px;}
.promo-dot-top{color:#f59e0b;}
.promo-dot-bump{color:#8b5cf6;}
.promo-dot-feat{color:var(--brand);}
.promo-dot-off{color:var(--grey-2);}

/* Grey status badge (for "Off" states) */
.status-grey{background:var(--grey-1);color:var(--grey-5);border:1px solid var(--grey-2);}
