/* =====================================================
   SAUDAGRAN — Brand-Matched Premium Theme v5
   Navy #1B4F7A · Teal #155E52 · Light & Colorful
===================================================== */
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,400&display=swap');

/* ── BRAND TOKENS ── */
:root {
  /* Brand primaries from logo */
  --navy:    #1B4F7A;
  --navy-d:  #133a5c;
  --navy-l:  #e8f2fb;
  --teal:    #155E52;
  --teal-d:  #0e4439;
  --teal-l:  #e6f4f1;

  /* Accent palette — warm & colorful */
  --coral:   #f05a28;
  --amber:   #f59e0b;
  --gold:    #eab308;
  --violet:  #7c3aed;
  --pink:    #ec4899;
  --sky:     #0ea5e9;
  --green:   #16a34a;
  --mint:    #10b981;

  /* Semantic */
  --blue:    var(--navy);
  --blue-d:  var(--navy-d);
  --blue-l:  var(--navy-l);
  --indigo:  #4f46e5;

  /* Surfaces — warm white, not cold blue */
  --bg:      #f7f8fa;
  --surface: #ffffff;
  --s2:      #f9fafb;
  --border:  #e5e7eb;
  --text:    #111827;
  --text2:   #1f2937;
  --muted:   #6b7280;
  --muted2:  #9ca3af;

  /* Gradients — brand-matched */
  --gh:  linear-gradient(135deg, #1B4F7A 0%, #1e6b9e 50%, #155E52 100%);
  --gh2: linear-gradient(135deg, #133a5c 0%, #1B4F7A 100%);
  --gw:  linear-gradient(135deg, #f05a28 0%, #ec4899 100%);
  --gc:  linear-gradient(135deg, #0ea5e9 0%, #1B4F7A 100%);
  --gg:  linear-gradient(135deg, #16a34a 0%, #10b981 100%);
  --go:  linear-gradient(135deg, #f59e0b 0%, #f05a28 100%);
  --gp:  linear-gradient(135deg, #7c3aed 0%, #ec4899 100%);
  --gt:  linear-gradient(135deg, #155E52 0%, #10b981 100%);

  --s1:  0 1px 4px rgba(17,24,39,.06);
  --s2s: 0 4px 16px rgba(17,24,39,.08);
  --s3:  0 8px 28px rgba(17,24,39,.11);
  --s4:  0 16px 44px rgba(17,24,39,.14);
  --s5:  0 24px 60px rgba(17,24,39,.18);

  --ease: .22s cubic-bezier(.4,0,.2,1);
  --r1: 8px; --r2: 14px; --r3: 20px; --r4: 28px;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  font-family:'Inter',sans-serif; font-size:15px; line-height:1.65;
  color:var(--text); background:var(--bg); overflow-x:hidden;
}
a { color:inherit; text-decoration:none; }
img { display:block; max-width:100%; }
button,select,input,textarea { font-family:inherit; }

/* Warm subtle background — not cold blue */
body::before {
  content:''; position:fixed; inset:0; pointer-events:none; z-index:-1;
  background:
    radial-gradient(ellipse 800px 600px at 0%   0%,  rgba(27,79,122,.05)  0%, transparent 55%),
    radial-gradient(ellipse 600px 500px at 100% 0%,  rgba(21,94,82,.04)   0%, transparent 55%),
    radial-gradient(ellipse 700px 500px at 80%  100%,rgba(240,90,40,.03)  0%, transparent 55%),
    radial-gradient(ellipse 500px 400px at 0%   90%, rgba(245,158,11,.03) 0%, transparent 55%);
}

.container { width:min(1280px,96vw); margin-inline:auto; }

/* ══════════════════════════════════════
   UTILITY BAR
══════════════════════════════════════ */
.utility-bar {
  background: var(--navy-d);
  font-size: 12.5px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.utility-inner { display:flex; justify-content:space-between; align-items:center; height:36px; }
.left-links,.right-links { display:flex; align-items:center; gap:20px; }
.left-links a,.right-links a { color:rgba(255,255,255,.6); font-weight:500; transition:color var(--ease); }
.left-links a:hover,.right-links a:hover { color:#fff; }
.join-btn {
  background: var(--go) !important; color:#fff !important; font-weight:700 !important;
  padding:4px 14px !important; border-radius:999px !important; font-size:12px !important;
  transition:opacity var(--ease),transform var(--ease) !important;
}
.join-btn:hover { opacity:.88; transform:scale(1.05); }

/* ══════════════════════════════════════
   MAIN HEADER — Clean White
══════════════════════════════════════ */
.main-header {
  background: #fff;
  position: sticky; top:0; z-index:200;
  box-shadow: 0 1px 0 var(--border), 0 2px 12px rgba(17,24,39,.06);
  transition: box-shadow var(--ease);
}
.header-inner { display:flex; align-items:center; gap:20px; padding:12px 0; }
.logo { display:flex; align-items:center; flex-shrink:0; }
.brand-logo { height:48px; max-width:min(260px,46vw); width:auto; object-fit:contain; }

/* Search */
.search-wrap {
  flex:1; display:flex; align-items:stretch;
  border:1.5px solid var(--border); border-radius:var(--r2);
  overflow:hidden; height:46px; background:var(--s2);
  transition:border-color var(--ease),box-shadow var(--ease);
}
.search-wrap:focus-within {
  border-color:var(--navy); box-shadow:0 0 0 3px rgba(27,79,122,.12); background:#fff;
}
.search-wrap select {
  width:115px; border:none; border-right:1.5px solid var(--border);
  background:transparent; padding:0 12px; font-size:13px; font-weight:600;
  color:var(--navy); cursor:pointer; outline:none;
}
.search-wrap input {
  flex:1; border:none; background:transparent; padding:0 16px;
  font-size:14px; color:var(--text); outline:none;
}
.search-wrap input::placeholder { color:var(--muted2); }
.search-wrap button {
  width:100px; border:none; background:var(--gh); color:#fff;
  font-weight:700; font-size:13.5px; cursor:pointer; transition:opacity var(--ease);
}
.search-wrap button:hover { opacity:.88; }

/* ══════════════════════════════════════
   NAVBAR — Beautiful Redesign
══════════════════════════════════════ */
.main-nav {
  background: #fff;
  border-top: 1px solid var(--border);
  border-bottom: 3px solid transparent;
  border-image: var(--gh) 1;
  position: relative;
}
.nav-inner {
  display: flex; align-items: center; gap: 4px;
  padding: 0;
}
.nav-inner a {
  position: relative;
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--muted); padding: 14px 18px;
  font-weight: 600; font-size: 14px;
  border-radius: 0;
  transition: color var(--ease);
  white-space: nowrap;
}
/* animated underline */
.nav-inner a::after {
  content: '';
  position: absolute; bottom: 0; left: 18px; right: 18px;
  height: 3px; border-radius: 3px 3px 0 0;
  background: var(--gh);
  transform: scaleX(0);
  transition: transform var(--ease);
}
.nav-inner a:hover { color: var(--navy); }
.nav-inner a:hover::after { transform: scaleX(1); }
.nav-inner a.active { color: var(--navy); font-weight: 700; }
.nav-inner a.active::after { transform: scaleX(1); }

/* nav icons */
.nav-inner a[href="index.html"]::before        { content: '🏠'; font-size:13px; }
.nav-inner a[href="products.html"]::before     { content: '📦'; font-size:13px; }
.nav-inner a[href="programs.html"]::before     { content: '🌱'; font-size:13px; }
.nav-inner a[href="organization.html"]::before { content: '🤝'; font-size:13px; }
.nav-inner a[href="women-owned.html"]::before  { content: '👩'; font-size:13px; }
.nav-inner a[href="plans.html"]::before        { content: '💳'; font-size:13px; }
.nav-inner a[href="contact.html"]::before      { content: '📬'; font-size: 13px;}
.nav-inner a[href="rfq.html"]::before          { content: '📋'; font-size:13px; }

/* RFQ link — special pill */
.nav-inner a[href="rfq.html"] {
  background: var(--gh);
  color: #fff !important;
  border-radius: var(--r2);
  margin-left: 8px;
  padding: 8px 20px;
}
.nav-inner a[href="rfq.html"]::after { display: none; }
.nav-inner a[href="rfq.html"]:hover { opacity: .88; }
.nav-inner a[href="rfq.html"].active { opacity: 1; box-shadow: 0 4px 14px rgba(27,79,122,.35); }

/* mobile */
.mobile-menu-btn { display:none; }
.mobile-nav { display:none; }


/* ══════════════════════════════════════
   PAGE HERO BANNER (inner pages)
══════════════════════════════════════ */
.page-hero{
  position:relative;overflow:hidden;
  background:var(--gh);
  padding:48px 0 40px;
  margin-bottom:0;
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background:url('https://images.unsplash.com/photo-1486406146926-c627a92ad1ab?auto=format&fit=crop&w=1600&q=60') center/cover;
  opacity:.12;
}
.page-hero-inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.page-hero h1{font-size:32px;font-weight:900;color:#fff;letter-spacing:-.02em;margin-bottom:6px}
.page-hero p{color:rgba(255,255,255,.78);font-size:15px;max-width:520px}
.page-hero-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);
  backdrop-filter:blur(8px);color:#fff;font-size:12px;font-weight:700;
  padding:5px 14px;border-radius:999px;margin-bottom:12px;letter-spacing:.04em;
}

/* ══════════════════════════════════════
   PAGE BODY
══════════════════════════════════════ */
.page-body{padding:24px 0 60px;}

/* ══════════════════════════════════════
   HERO GRID (homepage)
══════════════════════════════════════ */
.hero-grid{display:grid;grid-template-columns:220px 1fr 270px;gap:20px;align-items:start}

/* ── CATEGORY SIDEBAR ── */
.category-sidebar{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r3);padding:20px 16px;box-shadow:var(--s1);
  position:sticky;top:120px;
}
.category-sidebar h3{
  font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;
  color:var(--muted);margin-bottom:12px;padding-bottom:10px;border-bottom:2px solid var(--bg)
}
.category-sidebar a{
  display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:var(--r1);
  color:var(--text2);font-size:10.5px;font-weight:500;
  transition:all var(--ease);border-left:3px solid transparent;
}
.category-sidebar a::before{
  content:'';width:7px;height:7px;border-radius:50%;
  background:var(--gc);flex-shrink:0;transition:transform var(--ease)
}
.category-sidebar a:hover{background:var(--blue-l);color:var(--blue);border-left-color:var(--blue);padding-left:14px}
.category-sidebar a:hover::before{transform:scale(1.5)}

/* ── HERO CENTER ── */
.hero-center{display:grid;gap:16px}

.hero-slide-card{
  background: linear-gradient(135deg, #1B4F7A 0%, #1e6b9e 45%, #155E52 100%);
  border-radius:var(--r4);padding:36px 36px 32px;
  position:relative;overflow:hidden; 
  box-shadow:0 12px 48px rgba(27,79,122,.3);min-height:240px;
}
.hero-slide-card::before{
  content:'';position:absolute;width:420px;height:420px;border-radius:50%;
  background:rgba(255,255,255,.06);right:-120px;top:-120px; 
  animation:hblob 9s ease-in-out infinite;
}

@keyframes hblob{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(18px,-14px) scale(1.06)}
  66%{transform:translate(-12px,18px) scale(.94)}
}

.hero-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);
  backdrop-filter:blur(8px);color:#fff;font-size:12px;font-weight:700;
  padding:6px 14px;border-radius:999px;margin-bottom:16px;letter-spacing:.04em;
  animation:bpulse 3s ease-in-out infinite;
}
@keyframes bpulse{
  0%,100%{box-shadow:0 0 0 0 rgba(255,255,255,.3)}
  50%{box-shadow:0 0 0 7px rgba(255,255,255,0)}
}

h1{font-size:34px;font-weight:900;line-height:1.15;color:#fff;margin-bottom:12px;letter-spacing:-.02em}
.hero-slide-card>p{color:rgba(255,255,255,.82);font-size:15px;max-width:500px}

.hero-actions{display:flex;gap:12px;margin-top:22px;flex-wrap:wrap}
.solid-btn {
  display:inline-flex;align-items:center;gap:6px;padding:13px 26px;
  border-radius:var(--r2);font-size:14px;font-weight:700;background:#fff;color:var(--blue);
  box-shadow:0 4px 16px rgba(0,0,0,.2);transition:transform var(--ease),box-shadow var(--ease);
}
.solid-btn:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(0,0,0,.25)}
.ghost-btn{
  display:inline-flex;align-items:center;gap:6px;padding:13px 26px;
  border-radius:var(--r2);font-size:14px;font-weight:700;
  border:2px solid rgba(255,255,255,.5);color:#fff;
  transition:background var(--ease),border-color var(--ease),transform var(--ease);
}
.ghost-btn:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.9);transform:translateY(-2px)}


.quick-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.quick-tiles article{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);
  padding:18px 16px;text-align:center;box-shadow:var(--s1);
  transition:transform var(--ease),box-shadow var(--ease);position:relative;overflow:hidden;
}
.quick-tiles article::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.quick-tiles article:nth-child(1)::before{background:var(--gc)}
.quick-tiles article:nth-child(2)::before{background:var(--gg)}
.quick-tiles article:nth-child(3)::before{background:var(--gw)}
.quick-tiles article:hover{transform:translateY(-4px);box-shadow:var(--s3)}
.quick-tiles h4{
  font-size:28px;font-weight:900;
  background:var(--gh);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1
}
.quick-tiles p{margin-top:5px;color:var(--muted);font-size:12.5px;font-weight:600}

.hero-right{display:grid;gap:14px}
.promo-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);
  padding:18px;box-shadow:var(--s1);transition:transform var(--ease),box-shadow var(--ease);
  position:relative;overflow:hidden;
}
.promo-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--gc)}
.promo-card.premium::before{background:var(--go)}
.promo-card:hover{transform:translateY(-3px);box-shadow:var(--s3)}
.promo-card h4{font-size:15px;font-weight:800;color:var(--text);margin-bottom:7px}
.promo-card p{color:var(--muted);font-size:13px;line-height:1.6}
.promo-card a {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 12px;
  color: var(--blue); font-weight: 700; font-size: 13px;
  background: var(--blue-l);
  border: 1.5px solid rgba(37,99,235,.2);
  padding: 7px 14px;
  border-radius: 999px;
  transition: background var(--ease), color var(--ease), border-color var(--ease), transform var(--ease);
}
.promo-card a:hover {
  background: var(--blue); color: #fff;
  border-color: var(--blue); transform: translateY(-2px);
}
.promo-card a::after { content: '→'; }
.premium{background:linear-gradient(135deg,#fffbeb,#fef3c7);border-color:#fcd34d}
.premium h4{color:#92400e}
 
/* ══════════════════════════════════════
   MODULE
══════════════════════════════════════ */
.module{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r4);
  padding:28px 30px;margin-top:20px;box-shadow:var(--s1);
  position:relative;overflow:hidden;transition:box-shadow var(--ease);
}
.module:hover{box-shadow:var(--s2s)}
.module::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--navy),var(--teal),var(--coral),var(--amber))}
.module-head{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding-bottom:18px;border-bottom:1px solid var(--border);margin-bottom:6px;
}
.module-head h2{font-size:21px;font-weight:800;color:var(--text);letter-spacing:-.02em}
.module-head a {
  display: inline-flex; align-items: center; gap: 7px;
  color: var(--blue); font-weight: 700; font-size: 13px;
  background: var(--blue-l);
  border: 1.5px solid rgba(37,99,235,.2);
  padding: 8px 16px;
  border-radius: 999px;
  transition: background var(--ease), color var(--ease), border-color var(--ease), transform var(--ease), box-shadow var(--ease);
  white-space: nowrap;
  letter-spacing: .01em;
}
.module-head a:hover {
  background: var(--blue);
  color: #fff;
  border-color: var(--blue);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(37,99,235,.3);
}
.module-head a::after { content: '→'; font-size: 14px; }

/* ══════════════════════════════════════
   PRODUCT CARDS
══════════════════════════════════════ */
.product-row{margin-top:20px;display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.product-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);
  padding:14px;cursor:pointer;
  transition:transform var(--ease),box-shadow var(--ease),border-color var(--ease);
}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--s4);border-color:var(--blue)}
.thumb{height:120px;border-radius:var(--r1);margin-bottom:12px;background-size:cover;background-position:center}
.thumb-1{background:linear-gradient(135deg,#fde68a,#f59e0b,#d97706)}
.thumb-2{background:linear-gradient(135deg,#bfdbfe,#3b82f6,#1d4ed8)}
.thumb-3{background:linear-gradient(135deg,#fecdd3,#f43f5e,#be123c)}
.thumb-4{background:linear-gradient(135deg,#bbf7d0,#22c55e,#15803d)}
.thumb-5{background:linear-gradient(135deg,#e9d5ff,#a855f7,#7e22ce)}
.product-card h4{font-size:14px;font-weight:700;color:var(--text);line-height:1.4}
.product-card p{margin-top:5px;font-size:12.5px;color:var(--muted)}
.product-card span{
  display:inline-block;margin-top:10px;font-size:11px;font-weight:700;
  padding:4px 10px;border-radius:999px;background:var(--blue-l);color:var(--blue);letter-spacing:.02em
}
.visual-banner{margin-top:16px;border-radius:var(--r2);overflow:hidden;box-shadow:var(--s3)}
.visual-banner img{width:100%;height:200px;object-fit:cover;transition:transform .5s ease}
.visual-banner:hover img{transform:scale(1.03)}

/* ══════════════════════════════════════
   FEATURE / OPS GRIDS
══════════════════════════════════════ */
.feature-grid,.ops-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}
.feature-grid article,.ops-grid article{
  background:var(--s2);border:1px solid var(--border);border-radius:var(--r2);
  padding:20px;transition:all var(--ease);position:relative;overflow:hidden;
}
.feature-grid article::before,.ops-grid article::before{
  content:'';position:absolute;top:0;left:0;width:4px;height:100%;
  background:var(--gc);border-radius:0 4px 4px 0;transform:scaleY(0);transition:transform var(--ease)
}
.feature-grid article:hover::before,.ops-grid article:hover::before{transform:scaleY(1)}
.feature-grid article:hover,.ops-grid article:hover{
  background:var(--surface);box-shadow:var(--s3);transform:translateY(-3px);border-color:rgba(37,99,235,.2)
}
.feature-grid article h4,.ops-grid article h4{font-size:15px;font-weight:700;color:var(--text);margin-bottom:8px}
.feature-grid article p,.ops-grid article p{color:var(--muted);font-size:13.5px;line-height:1.65}

/* ══════════════════════════════════════
   RFQ LIST
══════════════════════════════════════ */
.rfq-list{display:grid;gap:12px;margin-top:18px}
.rfq-list article{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--s2);border:1px solid var(--border);border-left:5px solid var(--blue);
  border-radius:var(--r2);padding:16px 20px;transition:all var(--ease);
}
.rfq-list article:nth-child(2){border-left-color:var(--violet)}
.rfq-list article:nth-child(3){border-left-color:var(--green)}
.rfq-list article:hover{background:var(--surface);box-shadow:var(--s3);transform:translateX(4px)}
.rfq-list h4{font-size:15px;font-weight:700;color:var(--text)}
.rfq-list p{margin-top:4px;color:var(--muted);font-size:13px}

/* ══════════════════════════════════════
   PRICING PLANS
══════════════════════════════════════ */
.plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:20px}
.plan-grid article{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r4);
  padding:28px 24px;box-shadow:var(--s1);
  transition:transform var(--ease),box-shadow var(--ease);position:relative;overflow:hidden;
}
.plan-grid article::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:var(--gc)}
.plan-grid article:nth-child(2)::before{background:var(--gh)}
.plan-grid article:nth-child(3)::before{background:var(--gw)}
.plan-grid article:hover{transform:translateY(-6px);box-shadow:var(--s5)}
.plan-grid h4{font-size:20px;font-weight:800;color:var(--text);margin-bottom:4px}
.price{
  font-size:26px;font-weight:900;
  background:var(--gh);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin:10px 0 18px;line-height:1
}
.plan-grid ul{list-style:none}
.plan-grid ul li{
  padding:8px 0;border-bottom:1px solid var(--border);color:var(--text2);font-size:14px;
  display:flex;align-items:center;gap:8px;
}
.plan-grid ul li::before{
  content:'✓';width:20px;height:20px;background:var(--gg);color:#fff;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;flex-shrink:0
}
.highlight{border:2px solid var(--blue);background:linear-gradient(160deg,#eff6ff,#fff);transform:scale(1.03);box-shadow:var(--s4)}
.highlight::after{
  content:'⭐ Most Popular';position:absolute;top:-1px;right:20px;
  background:var(--gh);color:#fff;font-size:11px;font-weight:800;
  padding:5px 14px;border-radius:0 0 var(--r1) var(--r1);letter-spacing:.04em
}

/* ══════════════════════════════════════
   SERVICE / DASHBOARD GRIDS
══════════════════════════════════════ */
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}
.service-grid article{
  background:var(--s2);border:1px solid var(--border);border-radius:var(--r2);
  padding:20px;transition:all var(--ease);
}
.service-grid article:hover{background:var(--surface);box-shadow:var(--s3);transform:translateY(-3px)}
.service-grid h4{font-size:15px;font-weight:700;color:var(--text);margin-bottom:6px}
.service-grid p{color:var(--muted);font-size:13.5px}

.dashboard-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:18px}
.dashboard-grid article{
  background:linear-gradient(135deg,var(--blue-l),#fff);border:1px solid #c7d9f8;
  border-radius:var(--r2);padding:22px 18px;text-align:center;
  transition:transform var(--ease),box-shadow var(--ease);
}
.dashboard-grid article:hover{transform:translateY(-4px);box-shadow:var(--s3)}
.dashboard-grid h4{font-size:16px;font-weight:800;color:var(--blue-d);margin-bottom:5px}
.dashboard-grid p{color:var(--muted);font-size:13px}

/* ══════════════════════════════════════
   PAGE SHOWCASE (inner pages)
══════════════════════════════════════ */
.page-showcase{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r4);padding:16px;box-shadow:var(--s3);overflow:hidden;
}
.page-showcase>img{width:100%;height:240px;object-fit:cover;border-radius:var(--r3);margin-bottom:14px}
.showcase-cards{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.showcase-cards article{
  border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;
  background:var(--s2);transition:transform var(--ease),box-shadow var(--ease);
}
.showcase-cards article:hover{transform:translateY(-4px);box-shadow:var(--s3)}
.showcase-cards .card-media{width:100%;height:90px;object-fit:cover}
.showcase-cards h4{font-size:13px;font-weight:700;text-align:center;padding:8px 6px}

/* ══════════════════════════════════════
   FILTER BAR + FORMS
══════════════════════════════════════ */
.filter-bar{display:grid;grid-template-columns:1fr 200px;gap:12px;margin-top:18px}
.filter-bar input,.filter-bar select,
.rfq-form input,.rfq-form textarea,.rfq-form button{
  width:100%;border:1.5px solid var(--border);border-radius:var(--r2);
  padding:12px 16px;font:inherit;font-size:14px;color:var(--text);
  background:var(--surface);transition:border-color var(--ease),box-shadow var(--ease);
}
.filter-bar input:focus,.filter-bar select:focus,
.rfq-form input:focus,.rfq-form textarea:focus{
  outline:none;border-color:var(--blue);box-shadow:0 0 0 4px rgba(37,99,235,.12)
}

/* ══════════════════════════════════════
   LIST / COMMUNITY CARDS
══════════════════════════════════════ */
.list-grid{margin-top:18px;display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.list-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);
  padding:14px;box-shadow:var(--s1);cursor:pointer;
  transition:transform var(--ease),box-shadow var(--ease),border-color var(--ease);
}
.list-card:hover{transform:translateY(-6px);box-shadow:var(--s4);border-color:var(--blue)}
.card-media{width:100%;height:140px;object-fit:cover;border-radius:var(--r1);margin-bottom:10px}
.list-card h4{font-size:14.5px;font-weight:700}
.list-card p{margin-top:6px;font-size:13px;color:var(--muted)}
.status-chip{margin-top:10px;display:inline-block;border-radius:999px;font-size:11.5px;padding:4px 10px;font-weight:700}
.chip-green{background:#dcfce7;color:#15803d}
.chip-blue{background:var(--blue-l);color:var(--blue-d)}
.chip-gray{background:#f1f5f9;color:#475569}

.community-grid{margin-top:18px;display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.community-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);
  padding:18px;box-shadow:var(--s1);transition:transform var(--ease),box-shadow var(--ease);
}
.community-card:hover{transform:translateY(-4px);box-shadow:var(--s4)}
.community-card h3{font-size:16px;font-weight:700}
.community-card p{margin-top:6px;color:var(--muted);font-size:13px}

.mini-rfq-grid{margin-top:18px;display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.mini-rfq{
  background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--blue);
  border-radius:var(--r2);padding:14px;box-shadow:var(--s1);
}
.mini-rfq h4{font-size:14px;font-weight:700}
.mini-rfq p{margin-top:6px;color:var(--muted);font-size:13px}

.inline-link {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 12px;
  color: var(--blue); font-weight: 700; font-size: 13px;
  background: var(--blue-l);
  border: 1.5px solid rgba(37,99,235,.2);
  padding: 7px 14px;
  border-radius: 999px;
  transition: background var(--ease), color var(--ease), border-color var(--ease), transform var(--ease), box-shadow var(--ease);
}
.inline-link:hover {
  background: var(--blue);
  color: #fff;
  border-color: var(--blue);
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(37,99,235,.28);
}
.inline-link::after { content: '→'; }

/* ══════════════════════════════════════
   RFQ FORM
══════════════════════════════════════ */
.rfq-form{margin-top:18px;display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.rfq-form textarea{min-height:100px;grid-column:span 2;resize:vertical}
.rfq-form button{
  background:var(--gh);color:#fff;font-weight:700;border:none;
  cursor:pointer;transition:opacity var(--ease),transform var(--ease)
}
.rfq-form button:hover{opacity:.88;transform:translateY(-2px)}
.rfq-layout{margin-top:18px;display:grid;grid-template-columns:1.2fr .8fr;gap:16px}
.rfq-side-cards{display:grid;gap:12px}
.rfq-side-cards article{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);padding:14px;box-shadow:var(--s1)
}
.rfq-side-cards .card-media{height:110px;border-radius:var(--r1);margin-bottom:10px}
.rfq-side-cards h4{font-size:14.5px;font-weight:700;margin-top:4px}
.rfq-side-cards p{margin-top:6px;color:var(--muted);font-size:13px}

/* ══════════════════════════════════════
   TABLE
══════════════════════════════════════ */
.table-wrap{margin-top:18px;overflow-x:auto}
table{width:100%;border-collapse:collapse;background:var(--surface);border-radius:var(--r2);overflow:hidden;box-shadow:var(--s1)}
th,td{border:1px solid var(--border);padding:12px 14px;font-size:13.5px;text-align:left}
th{background:var(--blue-l);color:var(--blue-d);font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.05em}
tr:hover td{background:#f8faff}

/* ══════════════════════════════════════
   DETAIL PAGES
══════════════════════════════════════ */
#productDetailView{margin-top:18px}
.detail-hero,.supplier-hero{display:grid;grid-template-columns:.9fr 1.1fr;gap:18px;margin-bottom:18px}
.detail-main-image{width:100%;height:320px;object-fit:cover;border-radius:var(--r3);border:1px solid var(--border);box-shadow:var(--s4)}
.detail-copy{background:var(--surface);border:1px solid var(--border);border-radius:var(--r3);padding:22px}
.detail-copy h1{font-size:28px;margin-bottom:10px}
.detail-line{margin:8px 0;color:var(--muted);font-size:14px}
.detail-actions{margin-top:16px;display:flex;gap:10px;flex-wrap:wrap}
.detail-gallery{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:14px}
.detail-gallery img{width:100%;height:110px;object-fit:cover;border-radius:var(--r1);border:1px solid var(--border);transition:transform var(--ease)}
.detail-gallery img:hover{transform:scale(1.05)}
.detail-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.detail-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);padding:14px}
.detail-card h4{font-size:14px;font-weight:700}
.detail-card p{margin-top:6px;font-size:12.5px;color:var(--muted)}
.detail-provider{margin-top:14px}
.detail-provider-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);padding:16px}
.detail-provider-card h3{font-size:16px;font-weight:700}
.detail-provider-card p{margin-top:6px;color:var(--muted);font-size:13px}

/* ══════════════════════════════════════
   FOOTER — Premium Design
══════════════════════════════════════ */
.site-footer{
  background:#080f1e;
  position:relative;overflow:hidden;
  margin-top:40px;
}
.site-footer::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 600px 400px at 10% 50%,rgba(37,99,235,.12) 0%,transparent 60%),
    radial-gradient(ellipse 500px 350px at 90% 20%,rgba(124,58,237,.10) 0%,transparent 60%);
}

/* top gradient line */
.footer-top-bar{
  height:4px;
  background:linear-gradient(90deg,#1B4F7A,#155E52,#f05a28,#f59e0b,#10b981,#0ea5e9);
  background-size:200% 100%;
  animation:footerBar 4s linear infinite;
}
@keyframes footerBar{
  0%{background-position:0% 0%}
  100%{background-position:200% 0%}
}

.footer-main{
  position:relative;z-index:1;
  padding:56px 0 40px;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr 1fr;
  gap:40px;
}

/* brand column */
.footer-brand { display: flex; flex-direction: column; }
.footer-logo{
  height:44px;max-width:200px;width:auto;object-fit:contain;
  filter:brightness(0) invert(1);opacity:.9;margin-bottom:16px;
}
.footer-tagline{
  color:#94a3b8;font-size:14px;line-height:1.7;max-width:260px;margin-bottom:20px;
}
.footer-socials{display:flex;gap:10px}
.footer-social-btn{
  width:38px;height:38px;border-radius:var(--r1);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:16px;font-weight:700;color:#fff;
  transition:transform var(--ease),opacity var(--ease);
  text-decoration:none;
}
.footer-social-btn:hover{transform:translateY(-3px);opacity:.85}
.fsb-li{background:linear-gradient(135deg,#0077b5,#00a0dc)}
.fsb-tw{background:linear-gradient(135deg,#1da1f2,#0d8ecf)}
.fsb-ig{background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888)}
.fsb-wa{background:linear-gradient(135deg,#25d366,#128c7e)}

/* nav columns */
.footer-col h5{
  font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;
  color:#e2e8f0;margin-bottom:18px;
  display:flex;align-items:center;gap:8px;
}
.footer-col h5::before{
  content:'';width:20px;height:2px;border-radius:2px;
  background:var(--gc);flex-shrink:0;
}
.footer-col a{
  display:flex;align-items:center;gap:6px;
  color:#94a3b8;font-size:13.5px;margin:10px 0;
  transition:color var(--ease),gap var(--ease);
}
.footer-col a::before{content:'›';color:#60a5fa;font-weight:700;font-size:15px;line-height:1}
.footer-col a:hover{color:#fff;gap:10px}

/* newsletter strip */
.footer-newsletter{
  position:relative;z-index:1;
  padding:28px 0;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.footer-newsletter-inner{
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
}
.footer-newsletter-text h4{font-size:18px;font-weight:800;color:#fff;margin-bottom:4px}
.footer-newsletter-text p{color:#64748b;font-size:13.5px}
.footer-newsletter-form{display:flex;gap:0;border-radius:var(--r2);overflow:hidden;box-shadow:var(--s3);flex-shrink:0}
.footer-newsletter-form input{
  width:280px;border:none;background:rgba(255,255,255,.07);
  color:#fff;padding:13px 18px;font:inherit;font-size:14px;outline:none;
  border:1px solid rgba(255,255,255,.1);border-right:none;border-radius:var(--r2) 0 0 var(--r2);
}
.footer-newsletter-form input::placeholder{color:#475569}
.footer-newsletter-form button{
  border:none;background:var(--gh);color:#fff;font-weight:700;font-size:14px;
  padding:13px 24px;cursor:pointer;white-space:nowrap;
  border-radius:0 var(--r2) var(--r2) 0;transition:opacity var(--ease);
}
.footer-newsletter-form button:hover{opacity:.88}

/* bottom bar */
.footer-bottom{
  position:relative;z-index:1;
  padding:20px 0;
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
}
.footer-bottom p{color:#94a3b8;font-size:13px}
.footer-bottom-links{display:flex;gap:20px}
.footer-bottom-links a{color:#94a3b8;font-size:13px;transition:color var(--ease)}
.footer-bottom-links a:hover{color:#fff}
.footer-bottom-links a:hover{color:#94a3b8}

/* trust badges */
.footer-badges{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.footer-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r1);padding:6px 12px;color:#64748b;font-size:12px;font-weight:600;
}
.footer-badge span{font-size:14px}

/* ══════════════════════════════════════
   REVEAL ANIMATIONS
══════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* stagger children */
.reveal-stagger>*{
  opacity:0;transform:translateY(20px);
  transition:opacity .5s ease,transform .5s ease;
}
.reveal-stagger.visible>*:nth-child(1){opacity:1;transform:none;transition-delay:.05s}
.reveal-stagger.visible>*:nth-child(2){opacity:1;transform:none;transition-delay:.12s}
.reveal-stagger.visible>*:nth-child(3){opacity:1;transform:none;transition-delay:.19s}
.reveal-stagger.visible>*:nth-child(4){opacity:1;transform:none;transition-delay:.26s}
.reveal-stagger.visible>*:nth-child(5){opacity:1;transform:none;transition-delay:.33s}
.reveal-stagger.visible>*:nth-child(6){opacity:1;transform:none;transition-delay:.40s}

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media(max-width:1100px){
  .hero-grid{grid-template-columns:1fr}
  .category-sidebar{display:grid;grid-template-columns:repeat(2,1fr);gap:4px 14px;position:static}
  .product-row{grid-template-columns:repeat(4,1fr)}
  .feature-grid,.ops-grid{grid-template-columns:repeat(2,1fr)}
  .list-grid,.detail-gallery,.detail-grid{grid-template-columns:repeat(4,1fr)}
  .showcase-cards{grid-template-columns:repeat(4,1fr)}
  .community-grid{grid-template-columns:repeat(3,1fr)}
  .dashboard-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr 1fr}
}
@media(max-width:850px){
  .search-wrap{display:none}
  .mobile-menu-btn{
    display:inline-flex;align-items:center;gap:6px;
    border:1.5px solid var(--border);background:var(--surface);
    border-radius:var(--r1);padding:9px 16px;font-weight:600;font-size:14px;cursor:pointer;
    color: var(--navy);
  }
  .mobile-nav{
    display:none;flex-direction:column;gap:4px;
    padding:8px 0 14px; background:#fff;
    border-top:1px solid var(--border);
  }
  .mobile-nav a{
    display:flex; align-items:center; gap:8px;
    background:var(--s2);border:1px solid var(--border);
    border-radius:var(--r1);padding:11px 16px;font-weight:600;font-size:14px;
    color:var(--text2);
    transition:background var(--ease),color var(--ease);
  }
  .mobile-nav a:hover,
  .mobile-nav a.active { background:var(--navy-l); color:var(--navy); border-color:rgba(27,79,122,.2); }
  .left-links,.right-links,.main-nav{display:none}
  .product-row,.plan-grid,.feature-grid,.ops-grid,
  .mini-rfq-grid,.list-grid,.community-grid,
  .detail-gallery,.detail-grid,.service-grid,
  .footer-grid,.dashboard-grid,.showcase-cards{grid-template-columns:1fr}
  .filter-bar,.rfq-form{grid-template-columns:1fr}
  .rfq-layout,.detail-hero,.supplier-hero{grid-template-columns:1fr}
  .rfq-form textarea{grid-column:span 1}
  .quick-tiles{grid-template-columns:repeat(3,1fr)}
  .highlight{transform:none}
  .footer-newsletter-inner{flex-direction:column;align-items:flex-start}
  .footer-newsletter-form{width:100%}
  .footer-newsletter-form input{width:100%;flex:1}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:10px}
}

/* ══════════════════════════════════════
   RFQ PAGE — Complete Redesign
══════════════════════════════════════ */

/* ── RFQ HERO ── */
.rfq-hero {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, #1B4F7A 0%, #1e6b9e 45%, #155E52 100%);
  margin-bottom: 0;
}
.rfq-hero-bg {
  position: absolute; inset: 0;
  background:
    url('https://images.unsplash.com/photo-1486406146926-c627a92ad1ab?auto=format&fit=crop&w=1600&q=40') center/cover;
  opacity: .08;
}
.rfq-hero-bg::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(27,79,122,.65) 0%, rgba(21,94,82,.45) 100%);
}
.rfq-hero-inner {
  position: relative; z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
  padding: 60px 0 56px;
}
.rfq-hero-badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.25);
  backdrop-filter: blur(8px);
  color: #fff; font-size: 12px; font-weight: 700;
  padding: 6px 16px; border-radius: 999px;
  margin-bottom: 18px; letter-spacing: .05em;
  animation: bpulse 3s ease-in-out infinite;
}
.rfq-hero-title {
  font-size: 42px; font-weight: 900; color: #fff;
  line-height: 1.1; letter-spacing: -.03em;
  margin-bottom: 16px;
}
.rfq-hero-sub {
  color: rgba(255,255,255,.78); font-size: 16px;
  line-height: 1.7; max-width: 460px; margin-bottom: 32px;
}
.rfq-hero-stats {
  display: flex; gap: 32px;
}
.rfq-stat {
  display: flex; flex-direction: column; gap: 2px;
}
.rfq-stat-num {
  font-size: 26px; font-weight: 900; color: #fff; line-height: 1;
}
.rfq-stat-label {
  font-size: 12px; color: rgba(255,255,255,.6); font-weight: 600;
}
.rfq-hero-img-wrap {
  position: relative;
}
.rfq-hero-img {
  width: 100%; height: 340px; object-fit: cover;
  border-radius: var(--r3);
  border: 3px solid rgba(255,255,255,.2);
  box-shadow: 0 24px 64px rgba(0,0,0,.35);
}
.rfq-hero-float {
  position: absolute;
  background: #fff;
  border-radius: var(--r2);
  padding: 10px 16px;
  font-size: 13px; font-weight: 700; color: var(--text);
  box-shadow: var(--s4);
  white-space: nowrap;
}
.rfq-float-1 {
  top: 24px; left: -20px;
  animation: floatCard 4s ease-in-out infinite;
}
.rfq-float-2 {
  bottom: 32px; right: -16px;
  animation: floatCard 4s ease-in-out infinite .8s;
}
@keyframes floatCard {
  0%,100% { transform: translateY(0); }
  50%      { transform: translateY(-8px); }
}

/* ── HOW IT WORKS STEPS ── */
.rfq-steps {
  display: flex;
  align-items: center;
  gap: 0;
  margin-top: 24px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r3);
  padding: 28px 24px;
  box-shadow: var(--s2s);
  overflow: hidden;
  position: relative;
}
.rfq-steps::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 4px;
  background: var(--gh);
}
.rfq-step {
  flex: 1;
  display: flex; flex-direction: column; align-items: center;
  text-align: center; gap: 10px;
  padding: 0 12px;
  transition: transform var(--ease);
}
.rfq-step:hover { transform: translateY(-4px); }
.rfq-step-icon {
  width: 40px; height: 40px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 16px; font-weight: 900;
  box-shadow: var(--s3);
  flex-shrink: 0;
}
.rfq-step-img {
  width: 100%; height: 100px; object-fit: cover;
  border-radius: var(--r2);
  box-shadow: var(--s2s);
  transition: transform var(--ease), box-shadow var(--ease);
}
.rfq-step:hover .rfq-step-img {
  transform: scale(1.04);
  box-shadow: var(--s3);
}
.rfq-step h4 { font-size: 14px; font-weight: 800; color: var(--text); }
.rfq-step p  { font-size: 12.5px; color: var(--muted); line-height: 1.5; }
.rfq-step-arrow {
  font-size: 22px; color: var(--muted2); flex-shrink: 0;
  padding: 0 4px; margin-top: -20px;
}

/* ── FORM LAYOUT ── */
.rfq-layout-new {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 24px;
  margin-top: 20px;
}

/* ── FORM WRAP ── */
.rfq-form-wrap {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r3);
  overflow: hidden;
  box-shadow: var(--s2s);
}
.rfq-form-header {
  position: relative; height: 160px; overflow: hidden;
}
.rfq-form-banner {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .5s ease;
}
.rfq-form-wrap:hover .rfq-form-banner { transform: scale(1.04); }
.rfq-form-header-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(30,58,138,.75), rgba(124,58,237,.6));
  display: flex; flex-direction: column;
  justify-content: flex-end; padding: 20px 24px;
}
.rfq-form-header-overlay span {
  font-size: 12px; font-weight: 700; color: rgba(255,255,255,.7);
  letter-spacing: .06em; text-transform: uppercase; margin-bottom: 4px;
}
.rfq-form-header-overlay h3 {
  font-size: 22px; font-weight: 900; color: #fff; letter-spacing: -.02em;
}

/* ── FORM FIELDS ── */
.rfq-form-new {
  padding: 28px 28px 24px;
  display: flex; flex-direction: column; gap: 18px;
}
.rfq-field-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
}
.rfq-field {
  display: flex; flex-direction: column; gap: 6px;
}
.rfq-field-full { grid-column: span 2; }
.rfq-field label {
  font-size: 13px; font-weight: 700; color: var(--text2);
  letter-spacing: .01em;
}
.req { color: var(--rose); }
.rfq-field input,
.rfq-field textarea,
.rfq-field select {
  width: 100%;
  border: 1.5px solid var(--border);
  border-radius: var(--r2);
  padding: 13px 16px;
  font: inherit; font-size: 14px;
  color: var(--text);
  background: var(--s2);
  transition: border-color var(--ease), box-shadow var(--ease), background var(--ease);
  outline: none;
}
.rfq-field input:focus,
.rfq-field textarea:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 4px rgba(37,99,235,.12);
  background: var(--surface);
}
.rfq-field input::placeholder,
.rfq-field textarea::placeholder { color: var(--muted2); }
.rfq-field textarea { resize: vertical; min-height: 110px; }

.rfq-submit-btn {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  width: 100%; padding: 16px 24px;
  background: var(--gh);
  color: #fff; font: inherit; font-size: 16px; font-weight: 800;
  border: none; border-radius: var(--r2); cursor: pointer;
  box-shadow: 0 8px 24px rgba(37,99,235,.35);
  transition: transform var(--ease), box-shadow var(--ease), background var(--ease);
  letter-spacing: .01em;
}
.rfq-submit-btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 36px rgba(37,99,235,.45);
}
.rfq-btn-icon { font-size: 18px; }
.rfq-form-note {
  text-align: center; font-size: 12.5px; color: var(--muted);
  margin-top: -6px;
}

/* ── SIDEBAR ── */
.rfq-sidebar {
  display: flex; flex-direction: column; gap: 14px;
}
.rfq-sidebar-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r2);
  overflow: hidden;
  box-shadow: var(--s1);
  transition: transform var(--ease), box-shadow var(--ease);
}
.rfq-sidebar-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--s3);
}
.rfq-sidebar-feature {
  border-color: rgba(37,99,235,.25);
  background: linear-gradient(160deg, #eff6ff, #fff);
}
.rfq-sidebar-img {
  width: 100%; height: 110px; object-fit: cover;
  display: block;
  transition: transform .4s ease;
}
.rfq-sidebar-card:hover .rfq-sidebar-img { transform: scale(1.05); }
.rfq-sidebar-body {
  padding: 14px 16px;
}
.rfq-sidebar-icon {
  font-size: 22px; margin-bottom: 6px;
}
.rfq-sidebar-body h4 {
  font-size: 14.5px; font-weight: 800; color: var(--text); margin-bottom: 5px;
}
.rfq-sidebar-body p {
  font-size: 13px; color: var(--muted); line-height: 1.6;
}
.rfq-trust-box {
  background: var(--s2);
  border: 1px solid var(--border);
  border-radius: var(--r2);
  padding: 16px;
  display: flex; flex-direction: column; gap: 10px;
}
.rfq-trust-item {
  display: flex; align-items: center; gap: 10px;
  font-size: 13.5px; font-weight: 600; color: var(--text2);
}
.rfq-trust-item span { font-size: 16px; }

/* ── RESPONSIVE ── */
@media (max-width: 1000px) {
  .rfq-hero-inner { grid-template-columns: 1fr; }
  .rfq-hero-img-wrap { display: none; }
  .rfq-layout-new { grid-template-columns: 1fr; }
  .rfq-steps { flex-wrap: wrap; }
  .rfq-step-arrow { display: none; }
  .rfq-step { flex: 0 0 calc(50% - 12px); }
}
@media (max-width: 600px) {
  .rfq-field-row { grid-template-columns: 1fr; }
  .rfq-hero-title { font-size: 30px; }
  .rfq-hero-stats { gap: 20px; }
  .rfq-step { flex: 0 0 100%; }
}

/* ══════════════════════════════════════
   Organization PAGE
══════════════════════════════════════ */

/* ── HERO ── */
.comm-hero {
  position: relative; overflow: hidden;
  background: linear-gradient(135deg, #155E52 0%, #1a7a6a 40%, #1B4F7A 100%);
}
.comm-hero-bg {
  position: absolute; inset: 0;
  background: url('https://images.unsplash.com/photo-1511632765486-a01980e01a18?auto=format&fit=crop&w=1600&q=40') center/cover;
  opacity: .1;
}
.comm-hero-bg::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(21,94,82,.72) 0%, rgba(27,79,122,.5) 100%);
}
.comm-hero-inner {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 48px; align-items: center;
  padding: 60px 0 56px;
}
.comm-hero-badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.25);
  backdrop-filter: blur(8px); color: #fff;
  font-size: 12px; font-weight: 700; padding: 6px 16px;
  border-radius: 999px; margin-bottom: 18px; letter-spacing: .05em;
  animation: bpulse 3s ease-in-out infinite;
}
.comm-hero-title {
  font-size: 42px; font-weight: 900; color: #fff;
  line-height: 1.1; letter-spacing: -.03em; margin-bottom: 16px;
}
.comm-hero-sub {
  color: rgba(255,255,255,.78); font-size: 15px;
  line-height: 1.7; max-width: 460px; margin-bottom: 28px;
}
.comm-hero-stats {
  display: flex; gap: 32px; margin-bottom: 28px;
}
.comm-stat { display: flex; flex-direction: column; gap: 2px; }
.comm-stat-num { font-size: 26px; font-weight: 900; color: #fff; line-height: 1; }
.comm-stat-label { font-size: 12px; color: rgba(255,255,255,.6); font-weight: 600; }
.comm-hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }

/* hero mosaic */
.comm-hero-mosaic {
  position: relative; display: grid;
  grid-template-columns: 1fr 1fr; grid-template-rows: 200px 160px;
  gap: 10px;
}
.comm-mosaic-main {
  grid-column: 1; grid-row: 1 / 3;
  width: 100%; height: 100%; object-fit: cover;
  border-radius: var(--r3); border: 3px solid rgba(255,255,255,.2);
  box-shadow: var(--s4);
}
.comm-mosaic-a, .comm-mosaic-b {
  width: 100%; height: 100%; object-fit: cover;
  border-radius: var(--r2); border: 3px solid rgba(255,255,255,.2);
  box-shadow: var(--s3);
}
.comm-hero-float {
  position: absolute; background: #fff; border-radius: var(--r2);
  padding: 10px 16px; font-size: 13px; font-weight: 700; color: var(--text);
  box-shadow: var(--s4); white-space: nowrap; z-index: 2;
}
.comm-float-1 { top: 16px; left: -16px; animation: floatCard 4s ease-in-out infinite; }
.comm-float-2 { bottom: 24px; right: -12px; animation: floatCard 4s ease-in-out infinite .9s; }

/* ── FOCUS STRIP ── */
.comm-focus-strip {
  display: grid; grid-template-columns: repeat(5, 1fr);
  gap: 12px; margin-top: 20px;
}
.comm-focus-item {
  position: relative; border-radius: var(--r2); overflow: hidden;
  height: 110px; cursor: pointer;
  box-shadow: var(--s2s);
  transition: transform var(--ease), box-shadow var(--ease);
}
.comm-focus-item:hover { transform: translateY(-5px); box-shadow: var(--s4); }
.comm-focus-item img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .4s ease;
}
.comm-focus-item:hover img { transform: scale(1.08); }
.comm-focus-item span {
  position: absolute; inset: 0;
  display: flex; align-items: flex-end; justify-content: center;
  padding-bottom: 12px;
  background: linear-gradient(to top, rgba(0,0,0,.65) 0%, transparent 60%);
  color: #fff; font-size: 13px; font-weight: 800; letter-spacing: .02em;
}

/* ── ORG GRID ── */
.comm-org-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 20px; margin-top: 20px;
}
.comm-org-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r3); overflow: hidden;
  box-shadow: var(--s1);
  transition: transform var(--ease), box-shadow var(--ease), border-color var(--ease);
}
.comm-org-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--s4);
  border-color: rgba(16,185,129,.3);
}
.comm-org-img-wrap {
  position: relative; height: 180px; overflow: hidden;
}
.comm-org-img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .45s ease;
}
.comm-org-card:hover .comm-org-img { transform: scale(1.06); }
.comm-org-badge-icon {
  position: absolute; top: 14px; right: 14px;
  width: 42px; height: 42px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; box-shadow: var(--s3);
  border: 2px solid rgba(255,255,255,.4);
}
.comm-org-body { padding: 18px 20px 20px; }
.comm-org-meta {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 8px; flex-wrap: wrap;
}
.comm-org-city {
  font-size: 12px; font-weight: 600; color: var(--muted);
}
.comm-org-focus {
  font-size: 11.5px; font-weight: 700; color: var(--green);
  background: #d1fae5; padding: 3px 10px; border-radius: 999px;
}
.comm-org-name {
  font-size: 18px; font-weight: 800; color: var(--text);
  margin-bottom: 12px; line-height: 1.3;
}
.comm-org-stats {
  display: flex; gap: 20px; margin-bottom: 14px;
  padding: 12px 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
}
.comm-org-stat {
  display: flex; flex-direction: column; gap: 2px;
}
.comm-org-stat strong {
  font-size: 20px; font-weight: 900; color: var(--text);
}
.comm-org-stat span {
  font-size: 11.5px; color: var(--muted); font-weight: 600;
}
.comm-org-tags {
  display: flex; flex-wrap: wrap; gap: 6px; margin: 12px 0;
}
.comm-org-tag {
  font-size: 11.5px; font-weight: 600; color: var(--text2);
  background: var(--s2); border: 1px solid var(--border);
  padding: 4px 10px; border-radius: 999px;
  transition: background var(--ease), color var(--ease);
}
.comm-org-card:hover .comm-org-tag {
  background: var(--blue-l); color: var(--blue); border-color: rgba(37,99,235,.2);
}

/* ── IMPACT BANNER ── */
.comm-impact {
  margin-top: 20px; border-radius: var(--r4);
  overflow: hidden; position: relative;
  min-height: 320px;
  display: flex; align-items: center;
}
.comm-impact-bg {
  position: absolute; inset: 0;
}
.comm-impact-bg img {
  width: 100%; height: 100%; object-fit: cover;
}
.comm-impact-bg::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(6,78,59,.88) 0%, rgba(4,120,87,.75) 100%);
}
.comm-impact-content {
  position: relative; z-index: 1;
  padding: 48px 48px;
  max-width: 700px;
}
.comm-impact-content h2 {
  font-size: 32px; font-weight: 900; color: #fff;
  letter-spacing: -.02em; margin-bottom: 12px;
}
.comm-impact-content > p {
  color: rgba(255,255,255,.78); font-size: 15px;
  line-height: 1.7; margin-bottom: 28px;
}
.comm-impact-stats {
  display: flex; gap: 32px; margin-bottom: 32px; flex-wrap: wrap;
}
.comm-impact-stat span {
  display: block; font-size: 28px; font-weight: 900; color: #fff; line-height: 1;
}
.comm-impact-stat p {
  font-size: 12.5px; color: rgba(255,255,255,.65); font-weight: 600; margin-top: 4px;
}

/* ── SERVICES PREVIEW ── */
.comm-services-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 16px; margin-top: 20px;
}
.comm-svc-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r2); overflow: hidden;
  box-shadow: var(--s1);
  transition: transform var(--ease), box-shadow var(--ease);
}
.comm-svc-card:hover { transform: translateY(-5px); box-shadow: var(--s4); }
.comm-svc-card > img {
  width: 100%; height: 140px; object-fit: cover;
  transition: transform .4s ease;
}
.comm-svc-card:hover > img { transform: scale(1.05); }
.comm-svc-body { padding: 14px 16px 16px; }
.comm-svc-badge {
  display: inline-block; font-size: 11px; font-weight: 800;
  padding: 3px 10px; border-radius: 999px; margin-bottom: 8px;
  letter-spacing: .04em; text-transform: uppercase;
}
.comm-svc-badge.open     { background: #d1fae5; color: #065f46; }
.comm-svc-badge.upcoming { background: #dbeafe; color: #1e40af; }
.comm-svc-badge.closed   { background: #f1f5f9; color: #475569; }
.comm-svc-body h4 { font-size: 15px; font-weight: 800; color: var(--text); margin-bottom: 5px; }
.comm-svc-body p  { font-size: 12.5px; color: var(--muted); line-height: 1.5; }

/* ── JOIN CTA ── */
.comm-cta {
  margin-top: 20px;
  background: var(--gh);
  border-radius: var(--r4);
  overflow: hidden; position: relative;
  box-shadow: 0 12px 48px rgba(37,99,235,.3);
}
.comm-cta::before {
  content: ''; position: absolute; inset: 0;
  background: url('https://images.unsplash.com/photo-1577896851231-70ef18881754?auto=format&fit=crop&w=1400&q=40') center/cover;
  opacity: .07;
}
.comm-cta-inner {
  position: relative; z-index: 1;
  display: flex; align-items: center; justify-content: space-between;
  gap: 32px; padding: 44px 48px; flex-wrap: wrap;
}
.comm-cta-text h2 {
  font-size: 26px; font-weight: 900; color: #fff;
  letter-spacing: -.02em; margin-bottom: 8px;
}
.comm-cta-text p {
  color: rgba(255,255,255,.75); font-size: 14.5px;
  line-height: 1.65; max-width: 500px;
}
.comm-cta-actions { display: flex; gap: 12px; flex-shrink: 0; flex-wrap: wrap; }

/* ── RESPONSIVE ── */
@media (max-width: 1100px) {
  .comm-org-grid { grid-template-columns: repeat(2, 1fr); }
  .comm-services-grid { grid-template-columns: repeat(2, 1fr); }
  .comm-focus-strip { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 850px) {
  .comm-hero-inner { grid-template-columns: 1fr; }
  .comm-hero-mosaic { display: none; }
  .comm-hero-title { font-size: 30px; }
  .comm-hero-stats { gap: 20px; }
  .comm-org-grid { grid-template-columns: 1fr; }
  .comm-services-grid { grid-template-columns: 1fr; }
  .comm-focus-strip { grid-template-columns: repeat(2, 1fr); }
  .comm-impact-content { padding: 32px 24px; }
  .comm-impact-stats { gap: 20px; }
  .comm-cta-inner { flex-direction: column; align-items: flex-start; padding: 32px 24px; }
}

/* ══════════════════════════════════════
   SERVICES PAGE
══════════════════════════════════════ */

/* ── HERO ── */
.svc-hero {
  position: relative; overflow: hidden;
  background: linear-gradient(135deg, #1B4F7A 0%, #1e6b9e 45%, #155E52 100%);
}
.svc-hero-bg {
  position: absolute; inset: 0;
  background: url('https://images.unsplash.com/photo-1469571486292-b53601020e2f?auto=format&fit=crop&w=1600&q=40') center/cover;
  opacity: .08;
}
.svc-hero-bg::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(27,79,122,.72) 0%, rgba(21,94,82,.5) 100%);
}
.svc-hero-inner {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 48px; align-items: center;
  padding: 60px 0 56px;
}
.svc-hero-badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.25);
  backdrop-filter: blur(8px); color: #fff;
  font-size: 12px; font-weight: 700; padding: 6px 16px;
  border-radius: 999px; margin-bottom: 18px; letter-spacing: .05em;
  animation: bpulse 3s ease-in-out infinite;
}
.svc-hero-title {
  font-size: 42px; font-weight: 900; color: #fff;
  line-height: 1.1; letter-spacing: -.03em; margin-bottom: 16px;
}
.svc-hero-sub {
  color: rgba(255,255,255,.78); font-size: 15px;
  line-height: 1.7; max-width: 460px; margin-bottom: 28px;
}
.svc-hero-stats { display: flex; gap: 32px; margin-bottom: 28px; }
.svc-stat { display: flex; flex-direction: column; gap: 2px; }
.svc-stat-num  { font-size: 26px; font-weight: 900; color: #fff; line-height: 1; }
.svc-stat-label{ font-size: 12px; color: rgba(255,255,255,.6); font-weight: 600; }
.svc-hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }

/* hero image mosaic */
.svc-hero-cards {
  position: relative;
  display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 180px 150px;
  gap: 10px;
}
.svc-hero-card {
  position: relative; border-radius: var(--r2); overflow: hidden;
  box-shadow: var(--s4); border: 3px solid rgba(255,255,255,.15);
}
.svc-hc-1 { grid-column: 1; grid-row: 1 / 3; }
.svc-hero-card img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .4s ease;
}
.svc-hero-card:hover img { transform: scale(1.06); }
.svc-hero-card span {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(to top, rgba(0,0,0,.7), transparent);
  color: #fff; font-size: 13px; font-weight: 800;
  padding: 10px 12px;
}
.svc-hero-float {
  position: absolute; background: #fff; border-radius: var(--r2);
  padding: 10px 16px; font-size: 13px; font-weight: 700; color: var(--text);
  box-shadow: var(--s4); white-space: nowrap; z-index: 2;
}
.svc-float-1 { top: 12px; left: -18px; animation: floatCard 4s ease-in-out infinite; }
.svc-float-2 { bottom: 20px; right: -14px; animation: floatCard 4s ease-in-out infinite 1s; }

/* ── FILTER SECTION ── */
.svc-filter-section {
  margin-top: 20px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r3); padding: 20px 24px;
  box-shadow: var(--s1);
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; flex-wrap: wrap;
}
.svc-filter-tabs {
  display: flex; gap: 8px; flex-wrap: wrap;
}
.svc-tab {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 9px 18px; border-radius: 999px;
  border: 1.5px solid var(--border);
  background: var(--s2); color: var(--muted);
  font: inherit; font-size: 13.5px; font-weight: 600;
  cursor: pointer;
  transition: all var(--ease);
}
.svc-tab:hover { border-color: var(--navy); color: var(--navy); background: var(--navy-l); }
.svc-tab.active {
  background: var(--gh); color: #fff;
  border-color: transparent;
  box-shadow: 0 4px 14px rgba(27,79,122,.3);
}
.svc-tab-icon { font-size: 15px; }
.svc-search-wrap {
  flex-shrink: 0;
}
.svc-search-wrap input {
  border: 1.5px solid var(--border); border-radius: var(--r2);
  padding: 10px 16px; font: inherit; font-size: 14px;
  color: var(--text); background: var(--s2); outline: none;
  width: 260px;
  transition: border-color var(--ease), box-shadow var(--ease);
}
.svc-search-wrap input:focus {
  border-color: var(--navy);
  box-shadow: 0 0 0 3px rgba(27,79,122,.12);
  background: var(--surface);
}
.svc-search-wrap input::placeholder { color: var(--muted2); }

/* ── SERVICES GRID ── */
.svc-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 20px; margin-top: 20px;
}
.svc-empty {
  grid-column: 1 / -1; text-align: center;
  padding: 48px; color: var(--muted); font-size: 15px;
}

/* ── SERVICE CARD ── */
.svc-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r3); overflow: hidden;
  box-shadow: var(--s1);
  transition: transform var(--ease), box-shadow var(--ease), border-color var(--ease);
  display: flex; flex-direction: column;
}
.svc-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--s4);
  border-color: rgba(79,70,229,.25);
}
.svc-card-img-wrap {
  position: relative; height: 190px; overflow: hidden; flex-shrink: 0;
}
.svc-card-img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .45s ease;
}
.svc-card:hover .svc-card-img { transform: scale(1.06); }
.svc-card-type-badge {
  position: absolute; top: 12px; left: 12px;
  color: #fff; font-size: 11.5px; font-weight: 800;
  padding: 5px 12px; border-radius: 999px;
  letter-spacing: .04em; backdrop-filter: blur(4px);
  box-shadow: 0 2px 8px rgba(0,0,0,.2);
}
.svc-card-status {
  position: absolute; top: 12px; right: 12px;
  font-size: 11px; font-weight: 800; padding: 4px 10px;
  border-radius: 999px; letter-spacing: .04em; text-transform: uppercase;
}
.svc-chip-open     { background: #d1fae5; color: #065f46; }
.svc-chip-upcoming { background: #dbeafe; color: #1e40af; }
.svc-chip-closed   { background: #f1f5f9; color: #64748b; }

.svc-card-body {
  padding: 18px 20px 20px;
  display: flex; flex-direction: column; flex: 1;
}
.svc-card-title {
  font-size: 17px; font-weight: 800; color: var(--text);
  line-height: 1.3; margin-bottom: 8px;
}
.svc-card-org {
  display: flex; align-items: center; gap: 7px;
  font-size: 13px; font-weight: 600; color: var(--muted);
  margin-bottom: 12px;
}
.svc-card-org-dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
}
.svc-card-meta-row {
  display: flex; gap: 16px; flex-wrap: wrap;
  font-size: 12.5px; color: var(--muted); font-weight: 500;
  margin-bottom: 6px;
}
.svc-card-btn {
  display: inline-flex; align-items: center; justify-content: center;
  margin-top: auto; padding-top: 14px;
  width: 100%; padding: 12px 20px;
  background: var(--gh); color: #fff;
  font: inherit; font-size: 14px; font-weight: 700;
  border: none; border-radius: var(--r2); cursor: pointer;
  text-align: center;
  box-shadow: 0 4px 14px rgba(79,70,229,.3);
  transition: opacity var(--ease), transform var(--ease);
  margin-top: 16px;
}
.svc-card-btn:hover { opacity: .88; transform: translateY(-2px); }
.svc-card-btn-disabled {
  background: var(--s2); color: var(--muted2);
  box-shadow: none; cursor: not-allowed;
}
.svc-card-btn-disabled:hover { opacity: 1; transform: none; }

/* ── HOW TO APPLY ── */
.svc-how {
  margin-top: 20px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r4); padding: 36px 32px;
  box-shadow: var(--s1); position: relative; overflow: hidden;
}
.svc-how::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0;
  height: 4px; background: var(--gh);
}
.svc-how-header {
  text-align: center; margin-bottom: 32px;
}
.svc-how-header h2 {
  font-size: 26px; font-weight: 900; color: var(--text);
  letter-spacing: -.02em; margin-bottom: 6px;
}
.svc-how-header p { color: var(--muted); font-size: 15px; }
.svc-how-steps {
  display: flex; align-items: center; gap: 0;
}
.svc-how-step {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; text-align: center; gap: 10px;
  padding: 0 12px;
  transition: transform var(--ease);
}
.svc-how-step:hover { transform: translateY(-4px); }
.svc-how-num {
  width: 40px; height: 40px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 16px; font-weight: 900;
  box-shadow: var(--s3); flex-shrink: 0;
}
.svc-how-img {
  width: 100%; height: 100px; object-fit: cover;
  border-radius: var(--r2); box-shadow: var(--s2s);
  transition: transform var(--ease), box-shadow var(--ease);
}
.svc-how-step:hover .svc-how-img { transform: scale(1.04); box-shadow: var(--s3); }
.svc-how-step h4 { font-size: 14.5px; font-weight: 800; color: var(--text); }
.svc-how-step p  { font-size: 12.5px; color: var(--muted); line-height: 1.55; }
.svc-how-arrow   { font-size: 22px; color: var(--muted2); flex-shrink: 0; margin-top: -20px; }

/* ── PARTNER CTA ── */
.svc-cta {
  margin-top: 20px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r4); overflow: hidden;
  box-shadow: var(--s2s);
}
.svc-cta-inner {
  display: grid; grid-template-columns: 1fr 1.2fr;
}
.svc-cta-img-col img {
  width: 100%; height: 100%; object-fit: cover;
  min-height: 360px;
  transition: transform .5s ease;
}
.svc-cta:hover .svc-cta-img-col img { transform: scale(1.03); }
.svc-cta-img-col { overflow: hidden; }
.svc-cta-text-col {
  padding: 44px 40px;
  background: linear-gradient(160deg, #f0f7f5, #fff);
}
.svc-cta-badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--teal-l); color: var(--teal);
  font-size: 12px; font-weight: 700; padding: 5px 14px;
  border-radius: 999px; margin-bottom: 16px; letter-spacing: .04em;
}
.svc-cta-text-col h2 {
  font-size: 26px; font-weight: 900; color: var(--text);
  letter-spacing: -.02em; margin-bottom: 12px; line-height: 1.25;
}
.svc-cta-text-col > p {
  color: var(--muted); font-size: 14.5px; line-height: 1.7; margin-bottom: 24px;
}
.svc-cta-features {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 28px;
}
.svc-cta-feat {
  display: flex; align-items: center; gap: 8px;
  font-size: 13.5px; font-weight: 600; color: var(--text2);
}
.svc-cta-feat span { font-size: 18px; }
.svc-cta-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.ghost-btn-dark {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 13px 26px; border-radius: var(--r2);
  font-size: 14px; font-weight: 700;
  border: 2px solid var(--border); color: var(--text2);
  transition: border-color var(--ease), background var(--ease), transform var(--ease);
}
.ghost-btn-dark:hover {
  border-color: var(--indigo); color: var(--indigo);
  background: #eef2ff; transform: translateY(-2px);
}

/* ── RESPONSIVE ── */
@media (max-width: 1100px) {
  .svc-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 850px) {
  .svc-hero-inner { grid-template-columns: 1fr; }
  .svc-hero-cards { display: none; }
  .svc-hero-title { font-size: 30px; }
  .svc-hero-stats { gap: 20px; }
  .svc-filter-section { flex-direction: column; align-items: flex-start; }
  .svc-search-wrap input { width: 100%; }
  .svc-grid { grid-template-columns: 1fr; }
  .svc-how-steps { flex-wrap: wrap; }
  .svc-how-arrow { display: none; }
  .svc-how-step { flex: 0 0 calc(50% - 12px); }
  .svc-cta-inner { grid-template-columns: 1fr; }
  .svc-cta-img-col img { min-height: 220px; }
  .svc-cta-text-col { padding: 28px 24px; }
  .svc-cta-features { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════
   COMMUNITY PROFILE PAGE
══════════════════════════════════════ */
.cp-hero { position:relative; overflow:hidden; }
.cp-hero-bg { position:absolute; inset:0; opacity:.9; }
.cp-hero-inner {
  position:relative; z-index:1;
  display:grid; grid-template-columns:320px 1fr;
  gap:40px; align-items:center; padding:48px 0 44px;
}
.cp-hero-img {
  width:100%; height:280px; object-fit:cover;
  border-radius:var(--r3); border:4px solid rgba(255,255,255,.25);
  box-shadow:var(--s5);
}
.cp-hero-badge {
  display:inline-flex; align-items:center; gap:6px;
  background:rgba(255,255,255,.18); border:1px solid rgba(255,255,255,.3);
  color:#fff; font-size:12px; font-weight:700;
  padding:5px 14px; border-radius:999px; margin-bottom:14px; letter-spacing:.04em;
}
.cp-hero-name { font-size:36px; font-weight:900; color:#fff; letter-spacing:-.02em; margin-bottom:12px; }
.cp-hero-meta { display:flex; gap:20px; flex-wrap:wrap; margin-bottom:14px; }
.cp-hero-meta span { color:rgba(255,255,255,.8); font-size:14px; font-weight:600; }
.cp-hero-tags { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:20px; }
.cp-hero-tags .comm-org-tag { background:rgba(255,255,255,.15); color:#fff; border-color:rgba(255,255,255,.2); }

.cp-stats-strip {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:14px; margin-top:20px;
}
.cp-stat-box {
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--r2); padding:20px 18px; text-align:center;
  box-shadow:var(--s1); transition:transform var(--ease),box-shadow var(--ease);
}
.cp-stat-box:hover { transform:translateY(-3px); box-shadow:var(--s3); }
.cp-stat-num { display:block; font-size:26px; font-weight:900; color:var(--navy); line-height:1; }
.cp-stat-label { display:block; font-size:12.5px; color:var(--muted); font-weight:600; margin-top:5px; }

.cp-about { display:grid; grid-template-columns:280px 1fr; gap:24px; margin-top:18px; align-items:start; }
.cp-about-img { width:100%; height:200px; object-fit:cover; border-radius:var(--r2); box-shadow:var(--s2s); }
.cp-about-text p { color:var(--text2); font-size:14.5px; line-height:1.75; }
.cp-about-tags { display:flex; flex-wrap:wrap; gap:8px; }

.cp-services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:18px; }
.cp-svc-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--r2); overflow:hidden; box-shadow:var(--s1);
  transition:transform var(--ease),box-shadow var(--ease);
}
.cp-svc-card:hover { transform:translateY(-5px); box-shadow:var(--s4); }
.cp-svc-img { width:100%; height:150px; object-fit:cover; transition:transform .4s ease; }
.cp-svc-card:hover .cp-svc-img { transform:scale(1.05); }
.cp-svc-body { padding:16px 18px 18px; }
.cp-svc-body h4 { font-size:16px; font-weight:800; color:var(--text); margin-bottom:6px; }
.cp-no-services {
  grid-column:1/-1; text-align:center; padding:48px;
  color:var(--muted); font-size:15px;
}

.cp-cta {
  margin-top:20px; background:var(--gh);
  border-radius:var(--r4); overflow:hidden;
  box-shadow:0 12px 40px rgba(27,79,122,.25);
}
.cp-cta-inner {
  display:flex; align-items:center; justify-content:space-between;
  gap:24px; padding:36px 40px; flex-wrap:wrap;
}
.cp-cta-inner h2 { font-size:24px; font-weight:900; color:#fff; margin-bottom:6px; }
.cp-cta-inner p { color:rgba(255,255,255,.75); font-size:14px; }
.cp-cta-btns { display:flex; gap:12px; flex-shrink:0; }

@media(max-width:900px){
  .cp-hero-inner { grid-template-columns:1fr; }
  .cp-hero-img { height:200px; }
  .cp-stats-strip { grid-template-columns:repeat(2,1fr); }
  .cp-about { grid-template-columns:1fr; }
  .cp-services-grid { grid-template-columns:1fr; }
  .cp-cta-inner { flex-direction:column; align-items:flex-start; padding:28px 24px; }
}

/* ══════════════════════════════════════
   AUTH PAGES (Login + Register)
══════════════════════════════════════ */
body.auth-page { background:#f7f8fa; }
body.auth-page::before { display:none; }

.auth-split {
  display:grid; grid-template-columns:1fr 1fr;
  min-height:100vh;
}

/* LEFT PANEL */
.auth-left {
  background:var(--gh);
  position:relative; overflow:hidden;
  display:flex; align-items:stretch;
}
.auth-left-bg {
  position:absolute; inset:0;
  background:url('https://images.unsplash.com/photo-1486406146926-c627a92ad1ab?auto=format&fit=crop&w=900&q=40') center/cover;
  opacity:.07;
}
.auth-left-content {
  position:relative; z-index:1;
  padding:40px 44px;
  display:flex; flex-direction:column; gap:0;
  width:100%;
}
.auth-logo img { height:44px; object-fit:contain; filter:brightness(0) invert(1); opacity:.9; margin-bottom:32px; }
.auth-left-content h2 {
  font-size:30px; font-weight:900; color:#fff;
  line-height:1.2; letter-spacing:-.02em; margin-bottom:14px;
}
.auth-left-content > p { color:rgba(255,255,255,.75); font-size:14.5px; line-height:1.7; margin-bottom:28px; }
.auth-left-stats { display:flex; gap:28px; margin-bottom:28px; }
.auth-left-stats div { display:flex; flex-direction:column; gap:2px; }
.auth-left-stats strong { font-size:22px; font-weight:900; color:#fff; }
.auth-left-stats span { font-size:12px; color:rgba(255,255,255,.6); font-weight:600; }
.auth-left-perks { display:flex; flex-direction:column; gap:10px; margin-bottom:28px; }
.auth-perk {
  display:flex; align-items:center; gap:8px;
  color:rgba(255,255,255,.85); font-size:14px; font-weight:500;
}
.auth-left-img {
  width:100%; height:180px; object-fit:cover;
  border-radius:var(--r2); border:2px solid rgba(255,255,255,.15);
  box-shadow:var(--s4); margin-top:auto;
}
.auth-plan-preview { display:flex; flex-direction:column; gap:8px; margin-bottom:20px; }
.auth-plan {
  display:flex; justify-content:space-between; align-items:center;
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.15);
  border-radius:var(--r1); padding:10px 14px;
  color:#fff; font-size:13.5px;
}
.auth-plan strong { font-weight:700; }
.auth-plan span { color:rgba(255,255,255,.7); font-size:13px; }
.auth-plan-hot { background:rgba(255,255,255,.2); border-color:rgba(255,255,255,.35); }

/* RIGHT PANEL */
.auth-right {
  display:flex; align-items:center; justify-content:center;
  padding:40px 32px; overflow-y:auto;
  background:#fff;
}
.auth-form-wrap { width:100%; max-width:460px; }
.auth-form-header { margin-bottom:24px; }
.auth-step-badge {
  display:inline-flex; align-items:center; gap:6px;
  background:var(--navy-l); color:var(--navy);
  font-size:12px; font-weight:700; padding:5px 12px;
  border-radius:999px; margin-bottom:12px; letter-spacing:.04em;
}
.auth-form-header h1 { font-size:26px; font-weight:900; color:var(--text); margin-bottom:5px; letter-spacing:-.02em; }
.auth-form-header p { color:var(--muted); font-size:14.5px; }

/* Role tabs */
.auth-role-tabs { display:flex; gap:8px; margin-bottom:24px; }
.auth-role-tab {
  flex:1; padding:10px 8px; border-radius:var(--r1);
  border:1.5px solid var(--border); background:var(--s2);
  font:inherit; font-size:13px; font-weight:600; color:var(--muted);
  cursor:pointer; transition:all var(--ease);
}
.auth-role-tab:hover { border-color:var(--navy); color:var(--navy); background:var(--navy-l); }
.auth-role-tab.active { background:var(--gh); color:#fff; border-color:transparent; box-shadow:0 4px 14px rgba(27,79,122,.3); }

/* Form fields */
.auth-form { display:flex; flex-direction:column; gap:16px; }
.auth-field-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.auth-field { display:flex; flex-direction:column; gap:6px; }
.auth-field label { font-size:13px; font-weight:700; color:var(--text2); }
.auth-field input,
.auth-field select,
.auth-field textarea {
  width:100%; border:1.5px solid var(--border); border-radius:var(--r2);
  padding:12px 14px; font:inherit; font-size:14px; color:var(--text);
  background:var(--s2); outline:none;
  transition:border-color var(--ease),box-shadow var(--ease),background var(--ease);
}
.auth-field input:focus,
.auth-field select:focus {
  border-color:var(--navy); box-shadow:0 0 0 3px rgba(27,79,122,.12); background:#fff;
}
.auth-input-wrap { position:relative; }
.auth-input-wrap input { padding-right:44px; }
.auth-eye {
  position:absolute; right:12px; top:50%; transform:translateY(-50%);
  background:none; border:none; cursor:pointer; font-size:16px; padding:4px;
}
.auth-phone-wrap { display:flex; border:1.5px solid var(--border); border-radius:var(--r2); overflow:hidden; background:var(--s2); transition:border-color var(--ease),box-shadow var(--ease); }
.auth-phone-wrap:focus-within { border-color:var(--navy); box-shadow:0 0 0 3px rgba(27,79,122,.12); background:#fff; }
.auth-phone-code { padding:0 14px; background:var(--navy-l); color:var(--navy); font-size:13.5px; font-weight:700; display:flex; align-items:center; white-space:nowrap; border-right:1.5px solid var(--border); }
.auth-phone-wrap input { border:none; background:transparent; flex:1; padding:12px 14px; font:inherit; font-size:14px; outline:none; }
.auth-row { display:flex; align-items:center; justify-content:space-between; }
.auth-check { display:flex; align-items:center; gap:8px; font-size:13.5px; color:var(--text2); cursor:pointer; }
.auth-check input { width:16px; height:16px; accent-color:var(--navy); }
.auth-forgot { font-size:13.5px; color:var(--navy); font-weight:600; }
.auth-forgot:hover { text-decoration:underline; }
.req { color:#ef4444; }

/* Submit button */
.auth-submit-btn {
  width:100%; padding:14px 24px;
  background:var(--gh); color:#fff;
  font:inherit; font-size:15px; font-weight:800;
  border:none; border-radius:var(--r2); cursor:pointer;
  box-shadow:0 6px 20px rgba(27,79,122,.3);
  transition:opacity var(--ease),transform var(--ease);
  letter-spacing:.01em;
}
.auth-submit-btn:hover { opacity:.88; transform:translateY(-2px); }

/* Divider */
.auth-divider { display:flex; align-items:center; gap:12px; margin:16px 0; }
.auth-divider::before,.auth-divider::after { content:''; flex:1; height:1px; background:var(--border); }
.auth-divider span { font-size:13px; color:var(--muted); white-space:nowrap; }

/* Social */
.auth-social-row { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:16px; }
.auth-social-btn {
  padding:11px; border:1.5px solid var(--border); border-radius:var(--r2);
  background:var(--s2); font:inherit; font-size:13.5px; font-weight:600;
  color:var(--text2); cursor:pointer; transition:all var(--ease);
}
.auth-social-btn:hover { border-color:var(--navy); background:var(--navy-l); color:var(--navy); }

/* OTP */
.auth-otp-row { display:flex; gap:10px; justify-content:center; }
.auth-otp-box {
  width:52px; height:60px; text-align:center;
  font-size:24px; font-weight:800; color:var(--navy);
  border:2px solid var(--border); border-radius:var(--r2);
  background:var(--s2); outline:none;
  transition:border-color var(--ease),box-shadow var(--ease);
}
.auth-otp-box:focus { border-color:var(--navy); box-shadow:0 0 0 3px rgba(27,79,122,.12); background:#fff; }
.auth-otp-hint { text-align:center; font-size:13.5px; color:var(--muted); margin-top:12px; }
.auth-resend { background:none; border:none; color:var(--navy); font:inherit; font-size:13.5px; font-weight:700; cursor:pointer; }
.auth-resend:disabled { color:var(--muted2); cursor:default; }

/* Plan select */
.auth-plan-select { display:flex; flex-direction:column; gap:8px; }
.auth-plan-opt {
  display:flex; align-items:center; gap:10px;
  border:1.5px solid var(--border); border-radius:var(--r2);
  padding:12px 14px; cursor:pointer;
  transition:border-color var(--ease),background var(--ease);
}
.auth-plan-opt:hover { border-color:var(--navy); background:var(--navy-l); }
.auth-plan-opt input { accent-color:var(--navy); }
.auth-plan-opt-hot { border-color:var(--amber); background:#fffbeb; }
.auth-plan-opt-hot:hover { border-color:var(--coral); }

/* Checkbox grid */
.auth-checkbox-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; }

/* Bottom links */
.auth-switch { text-align:center; font-size:13.5px; color:var(--muted); margin-top:16px; }
.auth-switch a { color:var(--navy); font-weight:700; }
.auth-switch a:hover { text-decoration:underline; }
.auth-reg-links { text-align:center; font-size:13px; color:var(--muted2); margin-top:8px; }
.auth-reg-links a { color:var(--navy); font-weight:600; }
.auth-form-note { text-align:center; font-size:12.5px; color:var(--muted); margin-top:-8px; }

@media(max-width:900px){
  .auth-split { grid-template-columns:1fr; }
  .auth-left { display:none; }
  .auth-right { padding:32px 20px; }
  .auth-field-row { grid-template-columns:1fr; }
  .auth-checkbox-grid { grid-template-columns:1fr; }
}

/* ══════════════════════════════════════
   COMMUNITY PROFILE — CONTACT FORM
══════════════════════════════════════ */
.cp-contact-layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 28px;
  margin-top: 20px;
  align-items: start;
}
.cp-contact-info {
  display: flex; flex-direction: column; gap: 16px;
  background: var(--s2); border: 1px solid var(--border);
  border-radius: var(--r2); padding: 20px;
}
.cp-contact-item {
  display: flex; align-items: flex-start; gap: 12px;
}
.cp-contact-icon {
  font-size: 20px; flex-shrink: 0; margin-top: 2px;
}
.cp-contact-item strong {
  display: block; font-size: 13px; font-weight: 700; color: var(--text); margin-bottom: 2px;
}
.cp-contact-item p {
  font-size: 13px; color: var(--muted); line-height: 1.5;
}
.cp-contact-form {
  display: flex; flex-direction: column; gap: 16px;
}
.cp-form-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
}
.cp-contact-form .auth-field input,
.cp-contact-form .auth-field select,
.cp-contact-form .auth-field textarea {
  width: 100%; border: 1.5px solid var(--border); border-radius: var(--r2);
  padding: 12px 14px; font: inherit; font-size: 14px; color: var(--text);
  background: var(--s2); outline: none;
  transition: border-color var(--ease), box-shadow var(--ease), background var(--ease);
}
.cp-contact-form .auth-field input:focus,
.cp-contact-form .auth-field select:focus,
.cp-contact-form .auth-field textarea:focus {
  border-color: var(--navy); box-shadow: 0 0 0 3px rgba(27,79,122,.12); background: #fff;
}
.cp-contact-form .auth-field textarea { resize: vertical; min-height: 110px; }
.cp-contact-btn {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  width: 100%; padding: 14px 24px;
  background: var(--gh); color: #fff;
  font: inherit; font-size: 15px; font-weight: 800;
  border: none; border-radius: var(--r2); cursor: pointer;
  box-shadow: 0 6px 20px rgba(27,79,122,.28);
  transition: opacity var(--ease), transform var(--ease), background var(--ease);
}
.cp-contact-btn:hover { opacity: .88; transform: translateY(-2px); }

@media(max-width:800px){
  .cp-contact-layout { grid-template-columns: 1fr; }
  .cp-form-row { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════
   CHATBOT
══════════════════════════════════════ */
.sg-bot {
  position: fixed;
  bottom: 28px; right: 28px;
  z-index: 9999;
  font-family: 'Inter', sans-serif;
}

/* Toggle button */
.sg-bot-toggle {
  width: 58px; height: 58px; border-radius: 50%;
  background: var(--gh);
  border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 24px;
  box-shadow: 0 8px 28px rgba(27,79,122,.45);
  transition: transform var(--ease), box-shadow var(--ease);
  position: relative;
}
.sg-bot-toggle:hover {
  transform: scale(1.1);
  box-shadow: 0 12px 36px rgba(27,79,122,.55);
}
.sg-bot-badge {
  position: absolute; top: -4px; right: -4px;
  width: 20px; height: 20px; border-radius: 50%;
  background: #ef4444; color: #fff;
  font-size: 11px; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  border: 2px solid #fff;
  animation: badgePop .3s ease;
}
@keyframes badgePop { from { transform: scale(0); } to { transform: scale(1); } }

/* Chat window */
.sg-bot-window {
  position: absolute;
  bottom: 70px; right: 0;
  width: 360px;
  background: #fff;
  border-radius: var(--r3);
  box-shadow: 0 20px 60px rgba(17,24,39,.2);
  border: 1px solid var(--border);
  display: flex; flex-direction: column;
  overflow: hidden;
  opacity: 0; transform: translateY(16px) scale(.96);
  pointer-events: none;
  transition: opacity .25s ease, transform .25s ease;
}
.sg-bot-window.open {
  opacity: 1; transform: translateY(0) scale(1);
  pointer-events: all;
}

/* Header */
.sg-bot-header {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px;
  background: var(--gh);
  color: #fff;
}
.sg-bot-avatar {
  width: 38px; height: 38px; border-radius: 50%;
  background: rgba(255,255,255,.2);
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; flex-shrink: 0;
}
.sg-bot-name { font-size: 14px; font-weight: 800; }
.sg-bot-status { font-size: 11.5px; color: rgba(255,255,255,.75); margin-top: 1px; }
.sg-bot-close {
  margin-left: auto; background: rgba(255,255,255,.15);
  border: none; color: #fff; width: 28px; height: 28px;
  border-radius: 50%; cursor: pointer; font-size: 13px;
  display: flex; align-items: center; justify-content: center;
  transition: background var(--ease);
}
.sg-bot-close:hover { background: rgba(255,255,255,.3); }

/* Messages */
.sg-bot-messages {
  flex: 1; overflow-y: auto; padding: 16px;
  display: flex; flex-direction: column; gap: 12px;
  max-height: 340px;
  background: #f9fafb;
}
.sg-bot-messages::-webkit-scrollbar { width: 4px; }
.sg-bot-messages::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }

.sg-bot-msg { display: flex; }
.sg-bot-msg.bot { justify-content: flex-start; }
.sg-bot-msg.user { justify-content: flex-end; }

.sg-bot-bubble {
  max-width: 88%;
  padding: 11px 14px;
  border-radius: 16px;
  font-size: 13.5px; line-height: 1.6;
}
.sg-bot-msg.bot .sg-bot-bubble {
  background: #fff;
  border: 1px solid var(--border);
  border-bottom-left-radius: 4px;
  color: var(--text);
  box-shadow: var(--s1);
}
.sg-bot-msg.user .sg-bot-bubble {
  background: var(--gh);
  color: #fff;
  border-bottom-right-radius: 4px;
}

/* Quick chips */
.sg-bot-chips {
  display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px;
}
.sg-chip {
  padding: 5px 12px; border-radius: 999px;
  border: 1.5px solid rgba(27,79,122,.2);
  background: var(--navy-l); color: var(--navy);
  font: inherit; font-size: 12px; font-weight: 700;
  cursor: pointer;
  transition: background var(--ease), color var(--ease), border-color var(--ease);
}
.sg-chip:hover {
  background: var(--navy); color: #fff; border-color: var(--navy);
}

/* Links inside bot */
.sg-link {
  color: var(--navy); font-weight: 700; text-decoration: underline;
}
.sg-bot-msg.user .sg-link { color: #bfdbfe; }

/* Input row */
.sg-bot-input-row {
  display: flex; gap: 0;
  border-top: 1px solid var(--border);
  background: #fff;
}
.sg-bot-input-row input {
  flex: 1; border: none; padding: 13px 16px;
  font: inherit; font-size: 14px; color: var(--text);
  outline: none; background: transparent;
}
.sg-bot-input-row input::placeholder { color: var(--muted2); }
.sg-bot-input-row button {
  width: 48px; border: none;
  background: var(--gh); color: #fff;
  font-size: 16px; cursor: pointer;
  transition: opacity var(--ease);
}
.sg-bot-input-row button:hover { opacity: .85; }

@media(max-width:480px){
  .sg-bot { bottom: 16px; right: 16px; }
  .sg-bot-window { width: calc(100vw - 32px); right: 0; }
}

/* ══════════════════════════════════════
   PRODUCT DETAIL PAGE
══════════════════════════════════════ */
.pd-hero {
  display: grid;
  grid-template-columns: 420px 1fr;
  gap: 28px;
  align-items: start;
  margin-top: 4px;
}

.pd-hero-img-col { position: relative; }
.pd-main-img {
  width: 100%; height: 360px; object-fit: cover;
  border-radius: var(--r3);
  border: 1px solid var(--border);
  box-shadow: var(--s3);
}

/* breadcrumb */
.pd-breadcrumb {
  font-size: 13px; color: var(--muted); margin-bottom: 10px;
}
.pd-breadcrumb a { color: var(--navy); font-weight: 600; }
.pd-breadcrumb a:hover { text-decoration: underline; }

.pd-title {
  font-size: 26px; font-weight: 900; color: var(--text);
  letter-spacing: -.02em; line-height: 1.2; margin-bottom: 14px;
  /* override the global h1 white color */
  color: var(--text) !important;
}

/* badges */
.pd-badges-row { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 20px; }
.pd-badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 12px; font-weight: 700; padding: 4px 12px;
  border-radius: 999px; letter-spacing: .02em;
}
.pd-badge-green  { background: #dcfce7; color: #15803d; }
.pd-badge-gray   { background: #f1f5f9; color: #64748b; }
.pd-badge-blue   { background: #dbeafe; color: #1e40af; }
.pd-badge-navy   { background: var(--navy-l); color: var(--navy); }

.pd-price-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 14px 0;
  flex-wrap: wrap;
}
.pd-price-label {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--muted);
}
.pd-price-locked {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: linear-gradient(135deg, #f1f5f9, #e2e8f0);
  border: 1.5px dashed #94a3b8;
  color: #1B4F7A;
  font-size: 14px;
  font-weight: 700;
  padding: 8px 18px;
  border-radius: 10px;
  text-decoration: none;
  transition: all .2s;
  cursor: pointer;
}
.pd-price-locked:hover {
  background: linear-gradient(135deg, #1B4F7A, #155E52);
  color: #fff;
  border-color: transparent;
}

.pd-price-value {
  font-size: 20px;
  font-weight: 800;
  color: var(--navy);
  background: linear-gradient(135deg, #1B4F7A, #155E52);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* specs table */
.pd-specs {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 0;
  border: 1px solid var(--border); border-radius: var(--r2);
  overflow: hidden; margin-bottom: 22px;
}
.pd-spec {
  display: flex; flex-direction: column; gap: 3px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
  background: var(--s2);
  transition: background var(--ease);
}
.pd-spec:hover { background: var(--navy-l); }
.pd-spec:nth-last-child(-n+2) { border-bottom: none; }
.pd-spec-label {
  font-size: 11px; font-weight: 700; color: var(--muted);
  text-transform: uppercase; letter-spacing: .06em;
}
.pd-spec-val {
  font-size: 14px; font-weight: 600; color: var(--text);
}
.pd-stars { color: var(--amber); letter-spacing: 1px; }

/* action buttons */
.pd-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.pd-btn-primary {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 13px 24px; border-radius: var(--r2);
  background: var(--gh); color: #fff;
  font: inherit; font-size: 14px; font-weight: 700;
  border: none; cursor: pointer;
  box-shadow: 0 6px 20px rgba(27,79,122,.3);
  transition: opacity var(--ease), transform var(--ease);
  text-decoration: none;
}
.pd-btn-primary:hover { opacity: .88; transform: translateY(-2px); }

.pd-btn-secondary {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 13px 20px; border-radius: var(--r2);
  background: var(--navy-l); color: var(--navy);
  font: inherit; font-size: 14px; font-weight: 700;
  border: 1.5px solid rgba(27,79,122,.2);
  cursor: pointer;
  transition: background var(--ease), border-color var(--ease), transform var(--ease);
  text-decoration: none;
}
.pd-btn-secondary:hover { background: var(--navy); color: #fff; border-color: var(--navy); transform: translateY(-2px); }

.pd-btn-ghost {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 13px 18px; border-radius: var(--r2);
  background: transparent; color: var(--muted);
  font: inherit; font-size: 14px; font-weight: 600;
  border: 1.5px solid var(--border);
  cursor: pointer;
  transition: border-color var(--ease), color var(--ease);
  text-decoration: none;
}
.pd-btn-ghost:hover { border-color: var(--navy); color: var(--navy); }

/* supplier card */
.pd-supplier-card {
  display: flex; align-items: center; gap: 18px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r2); padding: 18px 20px;
  margin-top: 20px; box-shadow: var(--s1);
  transition: box-shadow var(--ease);
}
.pd-supplier-card:hover { box-shadow: var(--s3); }
.pd-supplier-img {
  width: 72px; height: 72px; object-fit: cover;
  border-radius: var(--r1); border: 1px solid var(--border);
  flex-shrink: 0;
}
.pd-supplier-info { flex: 1; }
.pd-supplier-name { font-size: 16px; font-weight: 800; color: var(--text); margin-bottom: 5px; }
.pd-supplier-meta {
  display: flex; gap: 16px; flex-wrap: wrap;
  font-size: 13px; color: var(--muted); font-weight: 500; margin-bottom: 5px;
}
.pd-supplier-certs {
  font-size: 12.5px; color: var(--navy); font-weight: 600;
  background: var(--navy-l); display: inline-block;
  padding: 3px 10px; border-radius: 999px;
}

@media(max-width:900px){
  .pd-hero { grid-template-columns: 1fr; }
  .pd-main-img { height: 260px; }
  .pd-specs { grid-template-columns: 1fr; }
  .pd-spec:nth-last-child(-n+2) { border-bottom: 1px solid var(--border); }
  .pd-spec:last-child { border-bottom: none; }
  .pd-supplier-card { flex-direction: column; align-items: flex-start; }
}

/* ══════════════════════════════════════
   SERVICE PROVIDER PAGE
══════════════════════════════════════ */
.sp-hero {
  position: relative; overflow: hidden;
  background: linear-gradient(135deg, #1B4F7A 0%, #1e6b9e 50%, #155E52 100%);
}
.sp-hero-bg {
  position: absolute; inset: 0;
  background: url('https://images.unsplash.com/photo-1486406146926-c627a92ad1ab?auto=format&fit=crop&w=1600&q=40') center/cover;
  opacity: .07;
}
.sp-hero-inner {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: 340px 1fr;
  gap: 40px; align-items: center; padding: 52px 0 48px;
}
.sp-hero-img {
  width: 100%; height: 280px; object-fit: cover;
  border-radius: var(--r3); border: 3px solid rgba(255,255,255,.2);
  box-shadow: var(--s5);
}
.sp-breadcrumb { font-size: 13px; color: rgba(255,255,255,.6); margin-bottom: 10px; }
.sp-breadcrumb a { color: rgba(255,255,255,.8); font-weight: 600; }
.sp-verified-badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.25);
  color: #fff; font-size: 12px; }

/* ══════════════════════════════════════
   SERVIC PROVIDER PAGE
══════════════════════════════════════ */
.sp-hero { position:relative; overflow:hidden; }
.sp-hero-bg { position:absolute; inset:0; opacity:.9; }
.sp-hero-inner {
  position:relative; z-index:1;
  display:grid; grid-template-columns:300px 1fr;
  gap:40px; align-items:center; padding:48px 0 44px;
}
.sp-hero-img {
  width:100%; height:260px; object-fit:cover;
  border-radius:var(--r3); border:4px solid rgba(255,255,255,.2);
  box-shadow:var(--s5);
}
.sp-hero-badge {
  display:inline-flex; align-items:center; gap:6px;
  background:rgba(255,255,255,.18); border:1px solid rgba(255,255,255,.3);
  color:#fff; font-size:12px; font-weight:700;
  padding:5px 14px; border-radius:999px; margin-bottom:14px; letter-spacing:.04em;
}
.sp-hero-name { font-size:34px; font-weight:900; color:#fff; letter-spacing:-.02em; margin-bottom:12px; }
.sp-hero-meta { display:flex; gap:20px; flex-wrap:wrap; margin-bottom:12px; }
.sp-hero-meta span { color:rgba(255,255,255,.8); font-size:14px; font-weight:600; }
.sp-hero-rating { display:flex; align-items:center; gap:8px; margin-bottom:12px; }
.sp-stars { color:#fbbf24; font-size:18px; letter-spacing:2px; }
.sp-rating-num { color:#fff; font-size:16px; font-weight:800; }
.sp-response { color:rgba(255,255,255,.65); font-size:13px; }
.sp-certs {
  display:inline-block; background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.25); color:#fff;
  font-size:12.5px; font-weight:600; padding:5px 14px;
  border-radius:999px; margin-bottom:20px;
}
.sp-hero-actions { display:flex; gap:12px; flex-wrap:wrap; }

.sp-stats {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:14px; margin-top:20px;
}
.sp-stat {
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--r2); padding:20px 18px; text-align:center;
  box-shadow:var(--s1); transition:transform var(--ease),box-shadow var(--ease);
}
.sp-stat:hover { transform:translateY(-3px); box-shadow:var(--s3); }
.sp-stat span { display:block; font-size:26px; font-weight:900; color:var(--navy); line-height:1; }
.sp-stat p { font-size:12.5px; color:var(--muted); font-weight:600; margin-top:5px; }

.sp-products-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:16px; margin-top:18px;
}
.sp-prod-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--r2); overflow:hidden; text-decoration:none;
  box-shadow:var(--s1); transition:transform var(--ease),box-shadow var(--ease),border-color var(--ease);
  display:flex; flex-direction:column;
}
.sp-prod-card:hover { transform:translateY(-5px); box-shadow:var(--s4); border-color:var(--navy); }
.sp-prod-card > img { width:100%; height:150px; object-fit:cover; transition:transform .4s ease; }
.sp-prod-card:hover > img { transform:scale(1.05); }
.sp-prod-body { padding:14px 16px; flex:1; display:flex; flex-direction:column; gap:5px; }
.sp-prod-cat { font-size:11px; font-weight:700; color:var(--navy); background:var(--navy-l); padding:3px 9px; border-radius:999px; display:inline-block; }
.sp-prod-body h4 { font-size:14px; font-weight:700; color:var(--text); line-height:1.35; }
.sp-prod-body p { font-size:12.5px; color:var(--muted); }
.sp-prod-badge { font-size:11px; font-weight:700; padding:3px 9px; border-radius:999px; display:inline-block; margin-top:4px; }
.sp-badge-green { background:#dcfce7; color:#15803d; }
.sp-badge-gray  { background:#f1f5f9; color:#64748b; }

@media(max-width:900px){
  .sp-hero-inner { grid-template-columns:1fr; }
  .sp-hero-img { height:200px; }
  .sp-stats { grid-template-columns:repeat(2,1fr); }
  .sp-products-grid { grid-template-columns:repeat(2,1fr); }
}

/* ══════════════════════════════════════
   PRODUCTS PAGE
══════════════════════════════════════ */
.prod-hero {
  position:relative; overflow:hidden;
  background:linear-gradient(135deg,#1B4F7A 0%,#1e6b9e 50%,#155E52 100%);
}
.prod-hero-bg {
  position:absolute; inset:0;
  background:url('https://images.unsplash.com/photo-1486406146926-c627a92ad1ab?auto=format&fit=crop&w=1600&q=40') center/cover;
  opacity:.07;
}
.prod-hero-inner {
  position:relative; z-index:1;
  display:grid; grid-template-columns:1fr 1fr;
  gap:48px; align-items:center; padding:56px 0 52px;
}
.prod-hero-badge {
  display:inline-flex; align-items:center; gap:6px;
  background:rgba(255,255,255,.15); border:1px solid rgba(255,255,255,.25);
  color:#fff; font-size:12px; font-weight:700;
  padding:6px 16px; border-radius:999px; margin-bottom:18px; letter-spacing:.05em;
  animation:bpulse 3s ease-in-out infinite;
}
.prod-hero-title { font-size:40px; font-weight:900; color:#fff; line-height:1.1; letter-spacing:-.03em; margin-bottom:16px; }
.prod-hero-sub { color:rgba(255,255,255,.78); font-size:15px; line-height:1.7; max-width:460px; margin-bottom:28px; }
.prod-hero-stats { display:flex; gap:32px; }
.prod-stat { display:flex; flex-direction:column; gap:2px; }
.prod-stat span { font-size:24px; font-weight:900; color:#fff; line-height:1; }
.prod-stat p { font-size:12px; color:rgba(255,255,255,.6); font-weight:600; }
.prod-hero-imgs {
  position:relative; display:grid;
  grid-template-columns:1fr 1fr; grid-template-rows:200px 160px; gap:10px;
}
.prod-hero-img-main { grid-column:1; grid-row:1/3; width:100%; height:100%; object-fit:cover; border-radius:var(--r3); border:3px solid rgba(255,255,255,.2); box-shadow:var(--s4); }
.prod-hero-img-a,.prod-hero-img-b { width:100%; height:100%; object-fit:cover; border-radius:var(--r2); border:3px solid rgba(255,255,255,.2); box-shadow:var(--s3); }

.prod-filter-section {
  margin-top:20px; background:var(--surface); border:1px solid var(--border);
  border-radius:var(--r3); padding:18px 22px; box-shadow:var(--s1);
  display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap;
}
.prod-cat-tabs { display:flex; gap:8px; flex-wrap:wrap; }
.prod-cat-tab {
  display:inline-flex; align-items:center; gap:5px;
  padding:8px 16px; border-radius:999px;
  border:1.5px solid var(--border); background:var(--s2);
  color:var(--muted); font:inherit; font-size:13px; font-weight:600;
  cursor:pointer; transition:all var(--ease);
}
.prod-cat-tab:hover { border-color:var(--navy); color:var(--navy); background:var(--navy-l); }
.prod-cat-tab.active { background:var(--gh); color:#fff; border-color:transparent; box-shadow:0 4px 14px rgba(27,79,122,.3); }
.prod-search-row input {
  border:1.5px solid var(--border); border-radius:var(--r2);
  padding:10px 16px; font:inherit; font-size:14px;
  color:var(--text); background:var(--s2); outline:none; width:260px;
  transition:border-color var(--ease),box-shadow var(--ease);
}
.prod-search-row input:focus { border-color:var(--navy); box-shadow:0 0 0 3px rgba(27,79,122,.12); background:#fff; }
.prod-search-row input::placeholder { color:var(--muted2); }

.prod-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:18px; margin-top:20px;
}
.prod-empty { grid-column:1/-1; text-align:center; padding:48px; color:var(--muted); font-size:15px; }

.prod-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--r2); overflow:hidden; box-shadow:var(--s1);
  transition:transform var(--ease),box-shadow var(--ease),border-color var(--ease);
  display:flex; flex-direction:column;
}
.prod-card:hover { transform:translateY(-6px); box-shadow:var(--s4); border-color:var(--navy); }
.prod-card-img-wrap {
  position:relative; height:180px; overflow:hidden; display:block; text-decoration:none;
}
.prod-card-img { width:100%; height:100%; object-fit:cover; transition:transform .45s ease; }
.prod-card:hover .prod-card-img { transform:scale(1.06); }
.prod-card-cat {
  position:absolute; top:10px; left:10px;
  background:rgba(27,79,122,.85); color:#fff;
  font-size:11px; font-weight:700; padding:4px 10px;
  border-radius:999px; backdrop-filter:blur(4px);
}
.prod-card-status {
  position:absolute; top:10px; right:10px;
  font-size:11px; font-weight:700; padding:4px 10px; border-radius:999px;
}
.prod-chip-green { background:#dcfce7; color:#15803d; }
.prod-chip-gray  { background:rgba(255,255,255,.9); color:#64748b; }

.prod-card-body { padding:14px 16px 16px; flex:1; display:flex; flex-direction:column; }
.prod-card-name { font-size:15px; font-weight:800; color:var(--text); line-height:1.3; margin-bottom:6px; }
.prod-card-name a { color:inherit; }
.prod-card-name a:hover { color:var(--navy); }
.prod-card-supplier { font-size:13px; color:var(--muted); margin-bottom:8px; display:flex; align-items:center; gap:5px; }
.prod-card-supplier a { color:var(--navy); font-weight:600; }
.prod-card-supplier a:hover { text-decoration:underline; }
.prod-card-meta { display:flex; gap:14px; font-size:12.5px; color:var(--muted); margin-bottom:12px; flex-wrap:wrap; }
.prod-card-actions { display:flex; gap:8px; margin-top:auto; }
.prod-btn-view {
  flex:1; text-align:center; padding:9px 12px;
  background:var(--navy-l); color:var(--navy);
  border:1.5px solid rgba(27,79,122,.2); border-radius:var(--r1);
  font-size:13px; font-weight:700;
  transition:background var(--ease),color var(--ease); text-decoration:none;
}
.prod-btn-view:hover { background:var(--navy); color:#fff; }
.prod-btn-rfq {
  padding:9px 14px; background:var(--gh); color:#fff;
  border:none; border-radius:var(--r1); font-size:13px; font-weight:700;
  cursor:pointer; transition:opacity var(--ease); text-decoration:none;
  display:inline-flex; align-items:center;
}
.prod-btn-rfq:hover { opacity:.88; }

@media(max-width:1100px){ .prod-grid { grid-template-columns:repeat(3,1fr); } }
@media(max-width:850px){
  .prod-hero-inner { grid-template-columns:1fr; }
  .prod-hero-imgs { display:none; }
  .prod-hero-title { font-size:28px; }
  .prod-filter-section { flex-direction:column; align-items:flex-start; }
  .prod-search-row input { width:100%; }
  .prod-grid { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:500px){ .prod-grid { grid-template-columns:1fr; } }

/* ══════════════════════════════════════
   HOME EXPLORE GRID
══════════════════════════════════════ */
.home-explore-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:16px; margin-top:18px;
}
.home-explore-card {
  position:relative; border-radius:var(--r2); overflow:hidden;
  height:200px; display:block; text-decoration:none;
  box-shadow:var(--s2s);
  transition:transform var(--ease),box-shadow var(--ease);
}
.home-explore-card:hover { transform:translateY(-5px); box-shadow:var(--s4); }
.home-explore-card img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .45s ease;
}
.home-explore-card:hover img { transform:scale(1.07); }
.home-explore-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(27,79,122,.88) 0%, rgba(27,79,122,.3) 60%, transparent 100%);
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:16px;
  transition:background var(--ease);
}
.home-explore-card:hover .home-explore-overlay {
  background:linear-gradient(to top, rgba(21,94,82,.9) 0%, rgba(21,94,82,.4) 60%, transparent 100%);
}
.home-explore-icon { font-size:22px; margin-bottom:6px; }
.home-explore-overlay h4 { font-size:16px; font-weight:800; color:#fff; margin-bottom:4px; }
.home-explore-overlay p { font-size:12.5px; color:rgba(255,255,255,.8); line-height:1.4; }

@media(max-width:850px){ .home-explore-grid { grid-template-columns:repeat(2,1fr); } }

/* ══════════════════════════════════════
   REGISTER SERVICE PROVIDER — PLAN SELECT FIX
══════════════════════════════════════ */
.auth-plan-opt {
  display:flex; align-items:flex-start; gap:12px;
  border:1.5px solid var(--border); border-radius:var(--r2);
  padding:14px 16px; cursor:pointer;
  transition:border-color var(--ease),background var(--ease),box-shadow var(--ease);
}
.auth-plan-opt:hover { border-color:var(--navy); background:var(--navy-l); }
.auth-plan-opt input[type="radio"] { margin-top:3px; accent-color:var(--navy); flex-shrink:0; width:16px; height:16px; }
.auth-plan-opt-content { flex:1; }
.auth-plan-opt-name { font-size:15px; font-weight:800; color:var(--text); display:flex; align-items:center; gap:8px; margin-bottom:3px; }
.auth-plan-opt-price { font-size:18px; font-weight:900; color:var(--navy); margin-bottom:4px; }
.auth-plan-opt-desc { font-size:12.5px; color:var(--muted); }
.auth-plan-popular {
  font-size:10px; font-weight:700; background:var(--go); color:#fff;
  padding:2px 8px; border-radius:999px; letter-spacing:.04em;
}
.auth-plan-opt-hot {
  border-color:var(--amber); background:linear-gradient(135deg,#fffbeb,#fff);
  box-shadow:0 4px 14px rgba(245,158,11,.15);
}
.auth-plan-opt-hot:hover { border-color:var(--coral); box-shadow:0 6px 20px rgba(245,158,11,.25); }
.auth-plan-opt-hot .auth-plan-opt-price { color:var(--coral); }

/* ══════════════════════════════════════
   HOME PAGE — TRENDING PRODUCTS GRID
══════════════════════════════════════ */
.home-prod-grid {
  grid-template-columns: repeat(4, 1fr) !important;
}
@media(max-width:1100px){ .home-prod-grid { grid-template-columns: repeat(2,1fr) !important; } }
@media(max-width:600px)  { .home-prod-grid { grid-template-columns: 1fr !important; } }

/* ══════════════════════════════════════
   HOME PAGE — BUY LEADS (RFQ)
══════════════════════════════════════ */
.home-rfq-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-top: 18px;
}
.home-rfq-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 4px solid var(--navy);
  border-radius: var(--r2);
  padding: 18px 18px 16px;
  box-shadow: var(--s1);
  display: flex; flex-direction: column; gap: 10px;
  transition: transform var(--ease), box-shadow var(--ease), border-left-color var(--ease);
}
.home-rfq-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--s3);
  border-left-color: var(--teal);
}
.home-rfq-top {
  display: flex; align-items: center; justify-content: space-between;
}
.home-rfq-badge {
  font-size: 11.5px; font-weight: 700; padding: 3px 10px;
  border-radius: 999px; background: #dcfce7; color: #15803d;
}
.home-rfq-badge-urgent { background: #fee2e2; color: #dc2626; }
.home-rfq-deadline {
  font-size: 11.5px; color: var(--muted); font-weight: 600;
}
.home-rfq-card h4 {
  font-size: 14.5px; font-weight: 800; color: var(--text); line-height: 1.35;
}
.home-rfq-meta {
  display: flex; flex-direction: column; gap: 4px;
}
.home-rfq-meta span {
  font-size: 12.5px; color: var(--muted); font-weight: 500;
}
.home-rfq-btn {
  display: inline-flex; align-items: center; justify-content: center;
  margin-top: auto;
  padding: 9px 16px; border-radius: var(--r1);
  background: var(--navy-l); color: var(--navy);
  font-size: 13px; font-weight: 700;
  border: 1.5px solid rgba(27,79,122,.2);
  transition: background var(--ease), color var(--ease), border-color var(--ease);
  text-decoration: none;
}
.home-rfq-btn:hover { background: var(--navy); color: #fff; border-color: var(--navy); }

@media(max-width:1100px){ .home-rfq-grid { grid-template-columns: repeat(2,1fr); } }
@media(max-width:600px)  { .home-rfq-grid { grid-template-columns: 1fr; } }

/* ══════════════════════════════════════
   HOME PAGE — COMMUNITY SERVICES
══════════════════════════════════════ */
.home-svc-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 18px;
}
.home-svc-card {
  position: relative; border-radius: var(--r2);
  overflow: hidden; height: 200px; display: block;
  text-decoration: none; box-shadow: var(--s2s);
  transition: transform var(--ease), box-shadow var(--ease);
}
.home-svc-card:hover { transform: translateY(-5px); box-shadow: var(--s4); }
.home-svc-card img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .45s ease;
}
.home-svc-card:hover img { transform: scale(1.07); }
.home-svc-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(21,94,82,.88) 0%, rgba(21,94,82,.3) 55%, transparent 100%);
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 16px;
  transition: background var(--ease);
}
.home-svc-card:hover .home-svc-overlay {
  background: linear-gradient(to top, rgba(27,79,122,.9) 0%, rgba(27,79,122,.4) 55%, transparent 100%);
}
.home-svc-status {
  display: inline-block; font-size: 10.5px; font-weight: 800;
  padding: 3px 9px; border-radius: 999px; margin-bottom: 7px;
  letter-spacing: .05em; text-transform: uppercase; width: fit-content;
}
.home-svc-status.open     { background: rgba(220,252,231,.9); color: #15803d; }
.home-svc-status.upcoming { background: rgba(219,234,254,.9); color: #1e40af; }
.home-svc-overlay h4 { font-size: 15px; font-weight: 800; color: #fff; margin-bottom: 4px; }
.home-svc-overlay p  { font-size: 12.5px; color: rgba(255,255,255,.8); line-height: 1.4; }

@media(max-width:900px) { .home-svc-grid { grid-template-columns: repeat(2,1fr); } }
@media(max-width:500px) { .home-svc-grid { grid-template-columns: 1fr; } }

/* ══════════════════════════════════════
   HOME — CATEGORY PRODUCT SLIDERS
══════════════════════════════════════ */
.hcs-row {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 0;
  margin-top: 16px;
  border-radius: var(--r2);
  overflow: hidden;
  box-shadow: var(--s2s);
  min-height: 200px;
}

/* left label */
.hcs-label {
  display: flex; flex-direction: column;
  align-items: flex-start; justify-content: flex-end;
  padding: 20px 18px;
  gap: 8px;
  position: relative;
  background-size: cover;
  background-position: center;
  overflow: hidden;
}
.hcs-label-overlay {
  position: absolute; inset: 0;
  background: rgba(15,23,42,.55);
  z-index: 0;
}
.hcs-label-icon,
.hcs-label h4,
.hcs-label-link {
  position: relative; z-index: 1;
}
.hcs-label-icon { font-size: 30px; line-height: 1; }
.hcs-label h4 {
  font-size: 15px; font-weight: 900; color: #fff;
  line-height: 1.2; letter-spacing: -.01em;
}
.hcs-label-link {
  display: inline-flex; align-items: center;
  font-size: 12px; font-weight: 700; color: rgba(255,255,255,.85);
  background: rgba(255,255,255,.18); border: 1px solid rgba(255,255,255,.25);
  padding: 5px 12px; border-radius: 999px; margin-top: 4px;
  transition: background var(--ease), color var(--ease);
  text-decoration: none;
}
.hcs-label-link:hover { background: rgba(255,255,255,.3); color: #fff; }

/* right track */
.hcs-track-wrap {
  position: relative;
  background: var(--s2);
  border-left: 1px solid var(--border);
  overflow: hidden;
}
.hcs-track {
  display: flex;
  gap: 14px;
  padding: 16px 52px 16px 16px;
  overflow-x: auto;
  scroll-behavior: smooth;
  scrollbar-width: none;
}
.hcs-track::-webkit-scrollbar { display: none; }

/* arrow buttons */
.hcs-arrow {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--surface); border: 1.5px solid var(--border);
  box-shadow: var(--s2s); cursor: pointer;
  font-size: 20px; font-weight: 700; color: var(--navy);
  display: flex; align-items: center; justify-content: center;
  transition: background var(--ease), color var(--ease), box-shadow var(--ease);
  z-index: 2;
}
.hcs-arrow:hover { background: var(--navy); color: #fff; box-shadow: var(--s3); }
.hcs-prev { left: 8px; }
.hcs-next { right: 8px; }

/* product card inside slider */
.hcs-card {
  flex-shrink: 0;
  width: 190px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r2);
  overflow: hidden;
  text-decoration: none;
  box-shadow: var(--s1);
  transition: transform var(--ease), box-shadow var(--ease), border-color var(--ease);
  display: flex; flex-direction: column;
}
.hcs-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--s3);
  border-color: var(--navy);
}
.hcs-card img {
  width: 100%; height: 120px; object-fit: cover;
  transition: transform .4s ease;
}
.hcs-card:hover img { transform: scale(1.05); }
.hcs-card-body {
  padding: 10px 12px 12px;
  display: flex; flex-direction: column; gap: 4px; flex: 1;
}
.hcs-card-body h5 {
  font-size: 13px; font-weight: 700; color: var(--text);
  line-height: 1.35;
  display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.hcs-card-body p { font-size: 11.5px; color: var(--muted); }
.hcs-chip-green, .hcs-chip-gray {
  display: inline-block; font-size: 10.5px; font-weight: 700;
  padding: 3px 8px; border-radius: 999px; margin-top: 4px; width: fit-content;
}
.hcs-chip-green { background: #dcfce7; color: #15803d; }
.hcs-chip-gray  { background: #f1f5f9; color: #64748b; }

@media(max-width:850px){
  .hcs-row { grid-template-columns: 1fr; }
  .hcs-label { flex-direction: row; align-items: center; padding: 14px 16px; gap: 12px; }
  .hcs-label h4 { font-size: 14px; }
  .hcs-track { padding: 12px 48px 12px 12px; }
}

/* ══════════════════════════════════════
   APPLY NOW MODAL
══════════════════════════════════════ */
.apm-backdrop {
  position: fixed; inset: 0; z-index: 9000;
  background: rgba(15,23,42,.55);
  backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
  opacity: 0; transition: opacity .25s ease;
}
.apm-backdrop.apm-open { opacity: 1; }
.apm-backdrop.apm-open .apm-box {
  transform: translateY(0) scale(1);
}

.apm-box {
  background: var(--surface);
  border-radius: var(--r3);
  width: 100%; max-width: 580px;
  max-height: 90vh; overflow-y: auto;
  box-shadow: var(--s5);
  position: relative;
  transform: translateY(24px) scale(.97);
  transition: transform .25s ease;
}
.apm-box::-webkit-scrollbar { width: 4px; }
.apm-box::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }

/* close */
.apm-close {
  position: absolute; top: 12px; right: 12px; z-index: 2;
  width: 32px; height: 32px; border-radius: 50%;
  background: rgba(255,255,255,.2); border: none;
  color: #fff; font-size: 14px; font-weight: 700;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: background var(--ease);
}
.apm-close:hover { background: rgba(255,255,255,.35); }

/* header with image */
.apm-header {
  position: relative; height: 140px; overflow: hidden; border-radius: var(--r3) var(--r3) 0 0;
}
.apm-header-img { width: 100%; height: 100%; object-fit: cover; }
.apm-header-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(27,79,122,.8) 0%, rgba(21,94,82,.6) 100%);
}
.apm-header-text {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 16px 20px;
}
.apm-badge {
  display: inline-block; font-size: 11px; font-weight: 800;
  padding: 3px 10px; border-radius: 999px; margin-bottom: 6px;
  letter-spacing: .04em;
}
.apm-header-text h2 {
  font-size: 20px; font-weight: 900; color: #fff;
  letter-spacing: -.02em; margin-bottom: 6px;
}
.apm-meta {
  display: flex; gap: 14px; flex-wrap: wrap;
  font-size: 12.5px; color: rgba(255,255,255,.8); font-weight: 500;
}

/* form */
.apm-form {
  padding: 24px 24px 20px;
  display: flex; flex-direction: column; gap: 14px;
}
.apm-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.apm-field { display: flex; flex-direction: column; gap: 5px; }
.apm-field label { font-size: 13px; font-weight: 700; color: var(--text2); }
.apm-field input,
.apm-field textarea,
.apm-field select {
  width: 100%; border: 1.5px solid var(--border); border-radius: var(--r2);
  padding: 11px 14px; font: inherit; font-size: 14px;
  color: var(--text); background: var(--s2); outline: none;
  transition: border-color var(--ease), box-shadow var(--ease), background var(--ease);
}
.apm-field input:focus,
.apm-field textarea:focus {
  border-color: var(--navy); box-shadow: 0 0 0 3px rgba(27,79,122,.12); background: #fff;
}
.apm-field textarea { resize: vertical; min-height: 90px; }
.apm-field input::placeholder,
.apm-field textarea::placeholder { color: var(--muted2); }

.apm-upload {
  border: 1.5px dashed var(--border); border-radius: var(--r2);
  padding: 14px 16px; background: var(--s2);
  font-size: 13.5px; color: var(--muted); font-weight: 500;
  display: flex; align-items: center; gap: 8px;
  cursor: pointer; transition: border-color var(--ease), background var(--ease);
}
.apm-upload:hover { border-color: var(--navy); background: var(--navy-l); color: var(--navy); }

.apm-check-row { margin-top: -4px; }

.apm-submit {
  width: 100%; padding: 14px 24px;
  background: var(--gh); color: #fff;
  font: inherit; font-size: 15px; font-weight: 800;
  border: none; border-radius: var(--r2); cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  box-shadow: 0 6px 20px rgba(27,79,122,.28);
  transition: opacity var(--ease), transform var(--ease);
}
.apm-submit:hover { opacity: .88; transform: translateY(-2px); }

.apm-note {
  text-align: center; font-size: 12.5px; color: var(--muted); margin-top: -6px;
}

/* success state */
.apm-success {
  padding: 40px 24px;
  flex-direction: column; align-items: center; text-align: center; gap: 12px;
}
.apm-success-icon { font-size: 52px; line-height: 1; }
.apm-success h3 { font-size: 22px; font-weight: 900; color: var(--text); }
.apm-success p  { font-size: 14.5px; color: var(--muted); line-height: 1.7; max-width: 400px; }

@media(max-width:560px){
  .apm-field-row { grid-template-columns: 1fr; }
  .apm-form { padding: 18px 16px; }
}

/* hcs-card background image */
.hcs-card-img {
  width: 100%; height: 130px;
  background-size: cover; background-position: center;
  position: relative; overflow: hidden;
  transition: transform .4s ease;
}
.hcs-card:hover .hcs-card-img { transform: scale(1.05); }
.hcs-card-img-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(15,23,42,.45) 0%, transparent 60%);
}
.hcs-chip-abs {
  position: absolute; top: 8px; right: 8px;
  margin-top: 0 !important;
}

/* search-wrap without select — remove left border */
.search-wrap input:first-child {
  border-left: none;
}

 /* ── HELP CENTER STYLES ── */
    .hc-hero {
      position: relative; overflow: hidden;
      background: linear-gradient(135deg, #1B4F7A 0%, #1e6b9e 45%, #155E52 100%);
    }
    .hc-hero-bg {
      position: absolute; inset: 0;
      background: url('https://images.unsplash.com/photo-1486406146926-c627a92ad1ab?auto=format&fit=crop&w=1600&q=40') center/cover;
      opacity: .07;
    }
    .hc-hero-inner {
      position: relative; z-index: 1;
      text-align: center;
      padding: 72px 0 60px;
    }
    .hc-hero-badge {
      display: inline-flex; align-items: center; gap: 6px;
      background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.25);
      backdrop-filter: blur(8px); color: #fff;
      font-size: 12px; font-weight: 700; padding: 6px 16px;
      border-radius: 999px; margin-bottom: 20px; letter-spacing: .05em;
    }
    .hc-hero-title {
      font-size: 42px; font-weight: 900; color: #fff;
      line-height: 1.1; letter-spacing: -.03em; margin-bottom: 14px;
    }
    .hc-hero-sub {
      color: rgba(255,255,255,.78); font-size: 16px;
      line-height: 1.7; margin-bottom: 32px;
    }
    .hc-search-wrap {
      display: flex; align-items: stretch;
      max-width: 560px; margin: 0 auto;
      border-radius: var(--r2); overflow: hidden;
      box-shadow: 0 8px 28px rgba(0,0,0,.2);
      height: 52px;
    }
    .hc-search-wrap input {
      flex: 1; border: none; background: #fff;
      padding: 0 20px; font: inherit; font-size: 15px;
      color: var(--text); outline: none;
    }
    .hc-search-wrap input::placeholder { color: var(--muted2); }
    .hc-search-wrap button {
      width: 120px; border: none; background: var(--go);
      color: #fff; font-weight: 700; font-size: 14px;
      cursor: pointer; transition: opacity var(--ease);
    }
    .hc-search-wrap button:hover { opacity: .88; }
    .hc-popular-tags {
      display: flex; align-items: center; gap: 8px;
      justify-content: center; flex-wrap: wrap;
      margin-top: 20px;
    }
    .hc-popular-tags span { font-size: 13px; color: rgba(255,255,255,.6); font-weight: 600; }
    .hc-tag-btn {
      background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.25);
      color: rgba(255,255,255,.85); font-size: 12.5px; font-weight: 600;
      padding: 5px 14px; border-radius: 999px; cursor: pointer; transition: background var(--ease);
      font-family: inherit;
    }
    .hc-tag-btn:hover { background: rgba(255,255,255,.28); }

    /* ── CATEGORY CARDS ── */
    .hc-cats {
      display: grid; grid-template-columns: repeat(4, 1fr);
      gap: 16px; margin-top: 20px;
    }
    .hc-cat {
      background: var(--surface); border: 1px solid var(--border);
      border-radius: var(--r2); padding: 24px 20px;
      text-align: center; cursor: pointer;
      box-shadow: var(--s1);
      transition: transform var(--ease), box-shadow var(--ease), border-color var(--ease);
      text-decoration: none; display: flex; flex-direction: column; align-items: center; gap: 10px;
      position: relative; overflow: hidden;
    }
    .hc-cat::before {
      content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
      background: var(--gh); transform: scaleX(0); transition: transform var(--ease);
    }
    .hc-cat:hover { transform: translateY(-5px); box-shadow: var(--s4); border-color: rgba(27,79,122,.25); }
    .hc-cat:hover::before { transform: scaleX(1); }
    .hc-cat-icon {
      width: 52px; height: 52px; border-radius: 50%;
      display: flex; align-items: center; justify-content: center;
      font-size: 22px; flex-shrink: 0;
    }
    .hc-cat h4 { font-size: 15px; font-weight: 800; color: var(--text); }
    .hc-cat p  { font-size: 13px; color: var(--muted); line-height: 1.5; }
    .hc-cat-count {
      font-size: 11.5px; font-weight: 700; padding: 3px 10px;
      border-radius: 999px; background: var(--navy-l); color: var(--navy);
    }

    /* ── FAQ SECTION ── */
    .hc-faq-grid {
      display: grid; grid-template-columns: 1fr 1fr;
      gap: 20px; margin-top: 20px;
    }
    .hc-faq-group h3 {
      font-size: 15px; font-weight: 800; color: var(--navy);
      display: flex; align-items: center; gap: 8px;
      margin-bottom: 14px; padding-bottom: 10px;
      border-bottom: 2px solid var(--navy-l);
    }
    .hc-faq-item {
      border: 1px solid var(--border); border-radius: var(--r2);
      margin-bottom: 8px; overflow: hidden;
      transition: border-color var(--ease), box-shadow var(--ease);
    }
    .hc-faq-item:hover { border-color: rgba(27,79,122,.3); box-shadow: var(--s1); }
    .hc-faq-q {
      width: 100%; background: none; border: none; text-align: left;
      padding: 14px 16px; font: inherit; font-size: 14px; font-weight: 700;
      color: var(--text); cursor: pointer; display: flex; align-items: center;
      justify-content: space-between; gap: 12px; transition: background var(--ease);
    }
    .hc-faq-q:hover { background: var(--s2); }
    .hc-faq-q.open { color: var(--navy); background: var(--navy-l); }
    .hc-faq-chevron {
      font-size: 14px; color: var(--muted); transition: transform .3s ease; flex-shrink: 0;
    }
    .hc-faq-q.open .hc-faq-chevron { transform: rotate(180deg); }
    .hc-faq-a {
      display: none; padding: 0 16px 14px;
      font-size: 13.5px; color: var(--muted); line-height: 1.7;
    }
    .hc-faq-a.open { display: block; }
    .hc-faq-a a { color: var(--navy); font-weight: 600; }

    /* ── GUIDES ── */
    .hc-guides-grid {
      display: grid; grid-template-columns: repeat(3, 1fr);
      gap: 16px; margin-top: 20px;
    }
    .hc-guide {
      background: var(--surface); border: 1px solid var(--border);
      border-radius: var(--r2); overflow: hidden; box-shadow: var(--s1);
      transition: transform var(--ease), box-shadow var(--ease);
      text-decoration: none; display: flex; flex-direction: column;
    }
    .hc-guide:hover { transform: translateY(-4px); box-shadow: var(--s3); }
    .hc-guide-img { width: 100%; height: 140px; object-fit: cover; transition: transform .4s ease; }
    .hc-guide:hover .hc-guide-img { transform: scale(1.05); }
    .hc-guide-body { padding: 16px 18px 18px; flex: 1; display: flex; flex-direction: column; gap: 6px; }
    .hc-guide-tag {
      font-size: 11px; font-weight: 700; padding: 3px 10px;
      border-radius: 999px; display: inline-block; width: fit-content; letter-spacing: .04em;
    }
    .hc-guide-tag.buyer   { background: var(--navy-l); color: var(--navy); }
    .hc-guide-tag.supplier{ background: #d1fae5; color: #065f46; }
    .hc-guide-tag.org     { background: #ede9fe; color: #5b21b6; }
    .hc-guide-body h4 { font-size: 14.5px; font-weight: 800; color: var(--text); line-height: 1.35; }
    .hc-guide-body p  { font-size: 13px; color: var(--muted); line-height: 1.55; flex: 1; }
    .hc-guide-link {
      font-size: 13px; font-weight: 700; color: var(--navy);
      display: flex; align-items: center; gap: 4px; margin-top: 8px;
    }

    /* ── CONTACT STRIP ── */
    .hc-contact-strip {
      display: grid; grid-template-columns: repeat(3, 1fr);
      gap: 16px; margin-top: 20px;
    }
    .hc-contact-card {
      background: var(--surface); border: 1px solid var(--border);
      border-radius: var(--r2); padding: 24px 20px; text-align: center;
      box-shadow: var(--s1); transition: transform var(--ease), box-shadow var(--ease);
      position: relative; overflow: hidden;
    }
    .hc-contact-card::before {
      content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
    }
    .hc-contact-card:nth-child(1)::before { background: var(--gc); }
    .hc-contact-card:nth-child(2)::before { background: var(--gg); }
    .hc-contact-card:nth-child(3)::before { background: var(--go); }
    .hc-contact-card:hover { transform: translateY(-4px); box-shadow: var(--s3); }
    .hc-contact-icon { font-size: 32px; margin-bottom: 12px; display: block; }
    .hc-contact-card h4 { font-size: 16px; font-weight: 800; color: var(--text); margin-bottom: 6px; }
    .hc-contact-card p  { font-size: 13.5px; color: var(--muted); line-height: 1.6; margin-bottom: 16px; }
    .hc-contact-btn {
      display: inline-flex; align-items: center; gap: 6px;
      padding: 10px 22px; border-radius: var(--r2);
      background: var(--gh); color: #fff;
      font: inherit; font-size: 13.5px; font-weight: 700;
      border: none; cursor: pointer;
      transition: opacity var(--ease), transform var(--ease); text-decoration: none;
    }
    .hc-contact-btn:hover { opacity: .88; transform: translateY(-2px); }
    .hc-contact-btn.ghost {
      background: transparent; color: var(--navy);
      border: 1.5px solid rgba(27,79,122,.25);
    }
    .hc-contact-btn.ghost:hover { background: var(--navy-l); }

    /* ── STATUS BANNER ── */
    .hc-status-bar {
      display: flex; align-items: center; gap: 12px;
      background: #d1fae5; border: 1px solid #a7f3d0;
      border-radius: var(--r2); padding: 14px 20px;
      margin-top: 20px; font-size: 14px; color: #065f46; font-weight: 600;
    }
    .hc-status-dot {
      width: 10px; height: 10px; border-radius: 50%;
      background: #16a34a; flex-shrink: 0;
      animation: pulse-green 2s infinite;
    }
    @keyframes pulse-green {
      0%,100%{box-shadow:0 0 0 0 rgba(22,163,74,.4)}
      50%{box-shadow:0 0 0 6px rgba(22,163,74,0)}
    }

    /* ── SEARCH RESULTS ── */
    #hcResults {
      background: var(--surface); border: 1px solid var(--border);
      border-radius: var(--r2); margin-top: 12px; display: none;
      box-shadow: var(--s3);
    }
    .hc-result-item {
      padding: 12px 18px; border-bottom: 1px solid var(--border);
      cursor: pointer; transition: background var(--ease);
      display: flex; align-items: center; gap: 12px;
    }
    .hc-result-item:last-child { border-bottom: none; }
    .hc-result-item:hover { background: var(--navy-l); }
    .hc-result-icon { font-size: 18px; flex-shrink: 0; }
    .hc-result-item h5 { font-size: 14px; font-weight: 700; color: var(--text); margin-bottom: 2px; }
    .hc-result-item p  { font-size: 12.5px; color: var(--muted); }
    .hc-no-result { padding: 20px 18px; text-align: center; color: var(--muted); font-size: 14px; }

    /* ── RESPONSIVE ── */
    @media(max-width:1100px){
      .hc-cats { grid-template-columns: repeat(2,1fr); }
      .hc-guides-grid { grid-template-columns: repeat(2,1fr); }
    }
    @media(max-width:850px){
      .hc-hero-title { font-size: 28px; }
      .hc-faq-grid { grid-template-columns: 1fr; }
      .hc-contact-strip { grid-template-columns: 1fr; }
      .hc-cats { grid-template-columns: repeat(2,1fr); }
      .hc-guides-grid { grid-template-columns: 1fr; }
    }
    @media(max-width:500px){
      .hc-cats { grid-template-columns: 1fr; }
    }

        /* ──  SPONSORS SLIDER  ── */
    
  .sponsors-wrap {
        background: var(--surface);
        border: 1px solid var(--border);
        border-radius: var(--r2);
        padding: 14px 16px 12px;
        box-shadow: var(--s1);
      }
      .sponsors-head {
        display: flex;
        align-items: center;
        justify-content: space-between;
        margin-bottom: 12px;
      }
      .sponsors-title {
        font-size: 11px;
        font-weight: 800;
        text-transform: uppercase;
        letter-spacing: .12em;
        color: var(--muted);
        display: flex;
        align-items: center;
        gap: 8px;
      }
      .sponsors-title::before,
      .sponsors-title::after {
        content: '';
        width: 20px;
        height: 2px;
        border-radius: 2px;
        background: linear-gradient(135deg, #1B4F7A 0%, #155E52 100%);
        flex-shrink: 0;
      }
      .sponsors-controls {
        display: flex;
        align-items: center;
        gap: 8px;
      }
      .spn-btn {
        width: 28px;
        height: 28px;
        border-radius: 50%;
        background: #f9fafb;
        border: 1.5px solid #e5e7eb;
        color: #1B4F7A;
        font-size: 14px;
        font-weight: 700;
        display: flex;
        align-items: center;
        justify-content: center;
        cursor: pointer;
        transition: background .2s, color .2s, transform .15s;
        line-height: 1;
        user-select: none;
        flex-shrink: 0;
      }
      .spn-btn:hover {
        background: #1B4F7A;
        color: #fff;
        border-color: #1B4F7A;
        transform: scale(1.1);
      }
      .sponsors-viewport {
        overflow: hidden;
        border-radius: 8px;
        width: 100%;
      }
      .sponsors-track {
        display: flex;
        gap: 12px;
        transition: transform .45s cubic-bezier(.4,0,.2,1);
        will-change: transform;
      }
      .spn-slide {
        flex-shrink: 0;
        border-radius: 8px;
        overflow: hidden;
        border: 1.5px solid #e5e7eb;
        position: relative;
        cursor: pointer;
        transition: transform .22s, box-shadow .22s, border-color .22s;
        /* width set by JS */
      }
      .spn-slide:hover {
        transform: translateY(-3px) scale(1.01);
        box-shadow: 0 8px 24px rgba(27,79,122,.15);
        border-color: rgba(27,79,122,.35);
      }
      .spn-slide img {
        width: 100%;
        height: 110px;
        object-fit: cover;
        display: block;
        transition: transform .5s ease;
      }
      .spn-slide:hover img {
        transform: scale(1.06);
      }
      .spn-overlay {
        position: absolute;
        inset: 0;
        background: linear-gradient(to top, rgba(27,79,122,.78) 0%, transparent 55%);
        display: flex;
        align-items: flex-end;
        padding: 8px 10px;
        opacity: 0;
        transition: opacity .22s;
      }
      .spn-slide:hover .spn-overlay {
        opacity: 1;
      }
      .spn-overlay span {
        font-size: 12px;
        font-weight: 700;
        color: #fff;
        letter-spacing: .02em;
      }
      .sponsors-dots {
        display: flex;
        justify-content: center;
        gap: 5px;
        margin-top: 10px;
      }
      .spn-dot {
        height: 5px;
        border-radius: 3px;
        background: #e5e7eb;
        border: none;
        cursor: pointer;
        padding: 0;
        transition: background .2s, width .3s;
        width: 6px;
      }
      .spn-dot.active {
        background: #1B4F7A;
        width: 16px;
      }
     

      /* ── REVIEWS ── */
.rv-section { margin: 40px 0; }
.rv-header { display: flex; align-items: center; gap: 14px; margin-bottom: 24px; }
.rv-header h2 { font-size: 22px; font-weight: 800; color: var(--dark); }
.rv-count { background: var(--navy); color: #fff; font-size: 12px; font-weight: 700; padding: 3px 10px; border-radius: 20px; }

.rv-summary { display: flex; gap: 40px; align-items: center; background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 16px; padding: 28px 32px; margin-bottom: 32px; flex-wrap: wrap; }
.rv-summary-left { text-align: center; min-width: 100px; }
.rv-big-score { font-size: 56px; font-weight: 900; color: var(--navy); line-height: 1; }
.rv-big-label { font-size: 12px; color: var(--muted); margin-top: 4px; }
.rv-summary-bars { flex: 1; min-width: 200px; display: flex; flex-direction: column; gap: 8px; }
.rv-bar-row { display: flex; align-items: center; gap: 10px; }
.rv-bar-label { font-size: 12px; font-weight: 700; color: var(--muted); width: 30px; flex-shrink: 0; }
.rv-bar-track { flex: 1; height: 8px; background: #e2e8f0; border-radius: 99px; overflow: hidden; }
.rv-bar-fill { height: 100%; border-radius: 99px; transition: width .6s ease; }
.rv-bar-num { font-size: 12px; color: var(--muted); width: 20px; text-align: right; }

.rv-write-box { background: linear-gradient(135deg,#f0f9ff,#f0fdf4); border: 1px solid #bae6fd; border-radius: 16px; padding: 28px; margin-bottom: 32px; }
.rv-write-box h3 { font-size: 17px; font-weight: 800; color: var(--navy); margin-bottom: 20px; }
.rv-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.rv-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.rv-field label { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .4px; color: var(--muted); }
.rv-field input, .rv-field textarea { border: 1.5px solid #e2e8f0; border-radius: 10px; padding: 10px 14px; font-size: 14px; font-family: inherit; outline: none; transition: border-color .2s; background: #fff; }
.rv-field input:focus, .rv-field textarea:focus { border-color: var(--navy); }
.rv-star-picker { display: flex; align-items: center; gap: 4px; margin-top: 4px; }
.rv-submit-btn { background: linear-gradient(135deg,#1B4F7A,#155E52); color: #fff; border: none; border-radius: 12px; padding: 13px 32px; font-size: 15px; font-weight: 700; cursor: pointer; transition: opacity .2s; width: 100%; margin-top: 4px; }
.rv-submit-btn:hover { opacity: .9; }

.rv-list { display: flex; flex-direction: column; gap: 16px; }
.rv-card { background: #fff; border: 1px solid #e2e8f0; border-radius: 14px; padding: 20px 24px; transition: box-shadow .2s; }
.rv-card:hover { box-shadow: 0 4px 20px rgba(15,23,42,.08); }
.rv-card-top { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 10px; }
.rv-avatar { width: 40px; height: 40px; border-radius: 50%; background: linear-gradient(135deg,#1B4F7A,#155E52); color: #fff; font-size: 17px; font-weight: 800; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.rv-card-meta { flex: 1; }
.rv-card-name { font-size: 14px; font-weight: 700; color: var(--dark); display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.rv-card-city { font-size: 12px; font-weight: 400; color: var(--muted); }
.rv-card-date { font-size: 12px; color: var(--muted); flex-shrink: 0; }
.rv-card-title { font-size: 15px; font-weight: 700; color: var(--dark); margin-bottom: 6px; }
.rv-card-body { font-size: 14px; color: var(--muted); line-height: 1.6; }
.rv-helpful { font-size: 12px; color: var(--muted); margin-top: 10px; }
.rv-empty { text-align: center; padding: 40px; color: var(--muted); font-size: 15px; background: #f8fafc; border-radius: 12px; border: 1px dashed #e2e8f0; }

@media (max-width: 600px) {
  .rv-form-row { grid-template-columns: 1fr; }
  .rv-summary { gap: 20px; padding: 20px; }
  .rv-big-score { font-size: 40px; }
}

.rv-section { overflow: hidden; }
.rv-bar-track { max-width: 100%; overflow: hidden; }
.rv-summary { overflow: hidden; max-width: 100%; box-sizing: border-box; }
.rv-bar-fill { max-width: 100%; }

#productReviews {
  max-width: 100%;
  overflow-x: hidden;
  box-sizing: border-box;
  padding: 0 20px;
}

.rv-summary-bars {
  flex: 1;
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
}

.rv-bar-row {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  box-sizing: border-box;
}

.rv-bar-track {
  flex: 1;
  min-width: 0;
  height: 8px;
  background: #e2e8f0;
  border-radius: 99px;
  overflow: hidden;
  max-width: 100%;
}

/* ── GUEST MODAL ── */
.gm-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.75);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  opacity: 0;
  transition: opacity 0.35s ease;
}
.gm-backdrop.gm-open {
  opacity: 1;
}
.gm-backdrop.gm-closing {
  opacity: 0;
}
.gm-box {
  background: #fff;
  border-radius: 20px;
  width: 100%;
  max-width: 440px;
  padding: 40px 36px 32px;
  box-shadow: 0 24px 80px rgba(15, 23, 42, 0.25);
  transform: translateY(30px) scale(0.97);
  transition: transform 0.35s cubic-bezier(.34,1.56,.64,1);
}
.gm-open .gm-box {
  transform: translateY(0) scale(1);
}
.gm-header {
  text-align: center;
  margin-bottom: 28px;
}
.gm-logo-wrap {
  margin-bottom: 16px;
}
.gm-logo {
  height: 44px;
  object-fit: contain;
}
.gm-title {
  font-size: 22px;
  font-weight: 800;
  color: var(--dark);
  margin-bottom: 8px;
}
.gm-sub {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.5;
}
.gm-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.gm-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.gm-field label {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: var(--muted);
}
.gm-field input {
  border: 1.5px solid #e2e8f0;
  border-radius: 10px;
  padding: 12px 14px;
  font-size: 15px;
  font-family: inherit;
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
  background: #f8fafc;
}
.gm-field input:focus {
  border-color: var(--navy);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(27, 79, 122, 0.1);
}
.gm-err {
  font-size: 12px;
  color: #f43f5e;
  font-weight: 600;
  min-height: 16px;
}
.gm-submit {
  background: linear-gradient(135deg, #1B4F7A, #155E52);
  color: #fff;
  border: none;
  border-radius: 12px;
  padding: 14px;
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
  transition: opacity 0.2s, transform 0.15s;
  margin-top: 4px;
}
.gm-submit:hover {
  opacity: 0.92;
  transform: translateY(-1px);
}
.gm-submit:active {
  transform: translateY(0);
}
.gm-note {
  text-align: center;
  font-size: 12px;
  color: var(--muted);
  margin-top: -4px;
}
.gm-login-row {
  text-align: center;
  font-size: 13px;
  color: var(--muted);
  padding-top: 8px;
  border-top: 1px solid #f1f5f9;
}
.gm-login-row a {
  color: var(--navy);
  font-weight: 700;
  text-decoration: none;
}
.gm-login-row a:hover {
  text-decoration: underline;
}

@media (max-width: 480px) {
  .gm-box {
    padding: 28px 20px 24px;
  }
  .gm-title {
    font-size: 19px;
  }
}

/* 

/* ══════════════════════════════════════
   PRODUCT DETAIL — DESCRIPTION & FEATURES
   Paste these rules at the very bottom of styles.css
══════════════════════════════════════ */

/* ── SHARED SECTION WRAPPER ── */
.pd-info-section {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r3);
  padding: 28px 30px;
  margin-top: 20px;
  box-shadow: var(--s1);
  position: relative;
  overflow: hidden;
  transition: box-shadow var(--ease);
}
.pd-info-section:hover {
  box-shadow: var(--s2s);
}
.pd-info-section::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--navy), var(--teal), var(--coral), var(--amber));
}

/* ── SECTION HEADER ── */
.pd-info-section-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 22px;
}
.pd-info-section-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--r1);
  background: var(--navy-l);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
}
.pd-info-section-title {
  font-size: 19px !important;
  font-weight: 800 !important;
  color: var(--text) !important;
  letter-spacing: -.02em;
  line-height: 1.2 !important;
  /* Explicitly override any inherited white color from hero h1 global rule */
  -webkit-text-fill-color: var(--text) !important;
  background: none !important;
  background-clip: unset !important;
  -webkit-background-clip: unset !important;
}

/* ── DESCRIPTION TEXT ── */
.pd-description-text {
  font-size: 15px;
  color: var(--text2);
  line-height: 1.85;
  max-width: 860px;
}

/* ── FEATURES GRID ── */
.pd-features-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}

/* ── SINGLE FEATURE ITEM ── */
.pd-feature-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  background: var(--s2);
  border: 1px solid var(--border);
  border-radius: var(--r2);
  padding: 14px 16px;
  transition: background var(--ease), border-color var(--ease),
              transform var(--ease), box-shadow var(--ease);
  position: relative;
  overflow: hidden;
}
.pd-feature-item::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 3px;
  height: 100%;
  background: var(--gc);
  border-radius: 0 3px 3px 0;
  transform: scaleY(0);
  transition: transform var(--ease);
}
.pd-feature-item:hover {
  background: var(--surface);
  border-color: rgba(27,79,122,.2);
  transform: translateY(-3px);
  box-shadow: var(--s3);
}
.pd-feature-item:hover::before {
  transform: scaleY(1);
}

/* ── FEATURE ICON ── */
.pd-feature-icon {
  font-size: 22px;
  line-height: 1;
  flex-shrink: 0;
  margin-top: 2px;
}

/* ── FEATURE TEXT ── */
.pd-feature-text {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.pd-feature-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pd-feature-value {
  font-size: 14px;
  font-weight: 800;
  color: var(--navy);
  line-height: 1.3;
}

/* ── RESPONSIVE ── */
@media (max-width: 1100px) {
  .pd-features-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 850px) {
  .pd-features-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .pd-info-section {
    padding: 20px 18px;
  }
}
@media (max-width: 500px) {
  .pd-features-grid {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
  .pd-feature-item {
    padding: 12px;
    gap: 9px;
  }
  .pd-feature-icon {
    font-size: 18px;
  }
  .pd-feature-value {
    font-size: 13px;
  }
}

 .pgd-stat-num {
    background: var(--gh);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    font-size: 20px;
    font-weight: 900;
    line-height: 1.2;
  }
  /* When stat-num contains short/plain text like "All genders", keep consistent */
  .pgd-stats-strip .pgd-stat-box:last-child .pgd-stat-num {
    font-size: 16px;
  }

  /* Fix 2: Apply button — remove the "..." ellipsis prefix, fix padding */
  .pgd-apply-btn {
    padding: 14px 16px;
    font-size: 14px;
    gap: 6px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  /* Fix 3: Hero breadcrumb — make it more readable */
  .pgd-breadcrumb {
    font-size: 13px;
    color: rgba(255,255,255,.85);
    font-weight: 600;
    text-shadow: 0 1px 4px rgba(0,0,0,.4);
  }
  .pgd-breadcrumb a {
    color: #fff;
    text-shadow: 0 1px 4px rgba(0,0,0,.4);
  }
  .pgd-breadcrumb span {
    color: rgba(255,255,255,.6);
  }

  /* Fix 4: Body grid — better proportions, prevent sidebar from being too narrow */
  .pgd-body {
    grid-template-columns: 1fr 360px;
    gap: 28px;
    align-items: start;
  }

  /* Fix 5: Apply card header — remove the "..." from button text via CSS */
  .pgd-apply-card-header p {
    font-size: 12px;
    color: rgba(255,255,255,.8);
    margin-top: 4px;
    line-height: 1.4;
  }

  /* Fix 6: Quick facts slot label alignment */
  .pgd-qf-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
    font-size: 13px;
  }
  .pgd-qf-value {
    text-align: right;
    font-size: 13px;
    font-weight: 700;
    color: var(--text);
    flex-shrink: 0;
    max-width: 55%;
    word-break: break-word;
  }

  /* Fix 7: Slots progress bar — make it visible */
  .pgd-slots-bar {
    background: var(--border);
    border-radius: 999px;
    height: 8px;
    overflow: hidden;
    margin-top: 6px;
  }
  .pgd-slots-fill {
    height: 100%;
    border-radius: 999px;
    min-width: 4px;
    transition: width .6s ease;
  }
  /* Fix 8: Slots text row — cleaner layout */
  .pgd-slots-info {
    display: flex;
    justify-content: space-between;
    font-size: 12px;
    color: var(--muted);
    margin-bottom: 4px;
  }

  /* Fix 9: Send Message button — ensure it uses gradient */
  #pgdContactForm button[type="submit"].pgd-apply-btn {
    background: var(--gh);
    color: #fff;
    border: none;
    max-width: 220px;
    font-size: 14px;
  }

  /* Fix 10: Org card avatar fallback */
  .pgd-org-card-avatar {
    width: 52px;
    height: 52px;
    border-radius: var(--r1);
    object-fit: cover;
    flex-shrink: 0;
    border: 1px solid var(--border);
    background: var(--navy-l);
  }

  /* Fix 11: Card section headers — icon bg more consistent */
  .pgd-card-icon {
    width: 40px;
    height: 40px;
    border-radius: var(--r1);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    flex-shrink: 0;
    box-shadow: var(--s1);
  }

  /* Fix 12: Timeline dot alignment */
  .pgd-timeline-dot {
    position: absolute;
    left: -28px;
    top: 4px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    flex-shrink: 0;
  }

  /* Fix 13: Related programs grid spacing */
  .pgd-related-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
    margin-top: 20px;
  }

  /* Fix 14: Stats strip responsive — prevent overflow */
  .pgd-stats-strip {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .pgd-stat-box {
    min-width: 120px;
  }

  /* Fix 15: Hero title white color override */
  .pgd-hero-title {
    color: #fff !important;
    -webkit-text-fill-color: #fff !important;
    background: none !important;
  }

  @media (max-width: 1100px) {
    .pgd-body { grid-template-columns: 1fr; }
    .pgd-apply-card { position: static; }
    .pgd-related-grid { grid-template-columns: repeat(2, 1fr); }
  }
  @media (max-width: 600px) {
    .pgd-related-grid { grid-template-columns: 1fr; }
    .pgd-stats-strip { grid-template-columns: repeat(2, 1fr); }
  }

  /* ══════════════════════════════════════
   PRODUCT DETAIL — MORE FROM SELLER
   Append this block to the bottom of styles.css
══════════════════════════════════════ */

/* View-all link sits on the right of the section header */
.pds-more-seller .pd-info-section-header {
  justify-content: flex-start;
}
.pds-view-all-btn {
  margin-left: auto;
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--navy); font-size: 13px; font-weight: 700;
  background: var(--navy-l);
  border: 1.5px solid rgba(27,79,122,.2);
  padding: 7px 16px; border-radius: 999px;
  text-decoration: none;
  transition: background var(--ease), color var(--ease), border-color var(--ease), transform var(--ease);
  white-space: nowrap;
}
.pds-view-all-btn:hover {
  background: var(--navy); color: #fff;
  border-color: var(--navy); transform: translateY(-2px);
}

/* 5-column grid */
.pds-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 14px;
}

/* Card shell */
.pds-card {
  display: flex; flex-direction: column;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r2);
  overflow: hidden;
  text-decoration: none;
  box-shadow: var(--s1);
  transition: transform var(--ease), box-shadow var(--ease), border-color var(--ease);
}
.pds-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--s3);
  border-color: var(--navy);
}

/* Image area */
.pds-card-img-wrap {
  position: relative; height: 130px; overflow: hidden; flex-shrink: 0;
}
.pds-card-img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .4s ease;
}
.pds-card:hover .pds-card-img { transform: scale(1.07); }

/* Category pill — bottom-left over image */
.pds-card-cat {
  position: absolute; bottom: 8px; left: 8px;
  background: rgba(27,79,122,.85); color: #fff;
  font-size: 10px; font-weight: 700;
  padding: 3px 8px; border-radius: 999px;
  backdrop-filter: blur(4px);
  letter-spacing: .02em;
}

/* Verified badge — top-right icon bubble */
.pds-card-status {
  position: absolute; top: 8px; right: 8px;
  font-size: 13px; line-height: 1;
  width: 26px; height: 26px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  box-shadow: 0 1px 4px rgba(0,0,0,.15);
}
.pds-chip-green { background: rgba(220,252,231,.95); }
.pds-chip-gray  { background: rgba(241,245,249,.95); }

/* Card body */
.pds-card-body {
  padding: 12px 13px 14px;
  display: flex; flex-direction: column; gap: 6px; flex: 1;
}
.pds-card-name {
  font-size: 13px; font-weight: 700; color: var(--text);
  line-height: 1.35;
  display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden;
}
.pds-card-meta {
  display: flex; flex-direction: column; gap: 2px;
  font-size: 11.5px; color: var(--muted); font-weight: 500;
}

/* CTA pill at bottom of card */
.pds-rfq-btn {
  display: inline-flex; align-items: center; justify-content: center;
  margin-top: auto;
  font-size: 12px; font-weight: 700;
  color: var(--navy);
  background: var(--navy-l);
  border: 1.5px solid rgba(27,79,122,.15);
  padding: 6px 10px; border-radius: var(--r1);
  transition: background var(--ease), color var(--ease);
}
.pds-card:hover .pds-rfq-btn {
  background: var(--navy); color: #fff;
}

/* Responsive breakpoints */
@media (max-width: 1100px) {
  .pds-grid { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
}
@media (max-width: 850px) {
  .pds-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .pds-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
}