/* ===================================================================
   TechNova — assets/css/frontend.css
   Public frontend site styles
   =================================================================== */

/* ── TOPBAR ──────────────────────────────────────────────────── */
#topbar { background:var(--primary-dark); color:rgba(255,255,255,.72); font-size:12.5px; padding:7px 0; }
.topbar-inner { max-width:1280px; margin:0 auto; padding:0 28px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px; }
.tb-left,.tb-right { display:flex; align-items:center; gap:18px; }
.tb-right a { color:rgba(255,255,255,.7); text-decoration:none; display:flex; align-items:center; gap:5px; transition:color .2s; }
.tb-right a:hover { color:var(--accent); }
.tb-login-chip { background:var(--accent); color:var(--primary-dark); padding:3px 10px; border-radius:20px; font-weight:700; font-size:11.5px; }

/* ── NAVBAR ──────────────────────────────────────────────────── */
#navbar { position:sticky; top:0; z-index:1000; background:#fff; box-shadow:0 2px 16px rgba(27,107,47,.08); transition:all .3s; }
.nav-inner { max-width:1280px; margin:0 auto; padding:0 28px; height:var(--nav-h); display:flex; align-items:center; gap:24px; }
.nav-brand { display:flex; align-items:center; gap:12px; text-decoration:none; flex-shrink:0; }
.brand-icon { width:44px; height:44px; background:linear-gradient(135deg,var(--accent),var(--primary-light)); border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:18px; color:#fff; box-shadow:0 4px 16px rgba(82,201,110,.4); }
.brand-text { font-family:var(--font-display); font-size:22px; font-weight:800; color:var(--primary-dark); }
.brand-text span { color:var(--accent); }
.brand-sub { font-size:10px; color:var(--text-muted); display:block; margin-top:1px; letter-spacing:.3px; }
.nav-links { display:flex; list-style:none; gap:2px; flex:1; }
.nav-links > li > a { display:flex; align-items:center; gap:5px; padding:8px 13px; border-radius:10px; text-decoration:none; font-size:13.5px; font-weight:500; color:var(--text-dark); transition:all .2s; }
.nav-links > li > a:hover, .nav-links > li > a.active { background:var(--accent-muted); color:var(--primary); }

/* Dropdown */
.has-dd { position:relative; }
.dropdown { position:absolute; top:calc(100% + 8px); left:0; background:#fff; border:1px solid var(--border); border-radius:16px; box-shadow:var(--shadow-lg); padding:8px; min-width:220px; display:none; z-index:100; animation:fadeInDn .2s ease; }
.has-dd:hover .dropdown { display:block; }
@keyframes fadeInDn { from{opacity:0;transform:translateY(-6px)} to{opacity:1;transform:translateY(0)} }
.dropdown a { display:flex; align-items:center; gap:10px; padding:10px 14px; border-radius:10px; font-size:13.5px; color:var(--text-dark)!important; background:none!important; }
.dropdown a:hover { background:var(--body-bg)!important; color:var(--primary)!important; }
.dd-icon { width:32px; height:32px; background:var(--accent-muted); border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:13px; color:var(--primary); flex-shrink:0; }

.nav-actions { display:flex; align-items:center; gap:10px; flex-shrink:0; }
.btn-ghost { padding:8px 18px; border:1.5px solid var(--primary); border-radius:10px; color:var(--primary); font-size:13.5px; font-weight:600; text-decoration:none; transition:all .2s; }
.btn-ghost:hover { background:var(--primary); color:#fff; }
.btn-nav { padding:9px 20px; background:linear-gradient(135deg,var(--primary-light),var(--accent)); border:none; border-radius:10px; color:#fff; font-size:13.5px; font-weight:600; text-decoration:none; cursor:pointer; transition:all .2s; box-shadow:0 4px 14px rgba(40,167,69,.3); }
.btn-nav:hover { transform:translateY(-1px); box-shadow:0 6px 18px rgba(40,167,69,.4); color:#fff; }

.hamburger { display:none; width:38px; height:38px; background:var(--accent-muted); border:none; border-radius:10px; cursor:pointer; font-size:18px; color:var(--primary); align-items:center; justify-content:center; flex-shrink:0; }
.mobile-menu { display:none; position:fixed; top:var(--nav-h); left:0; right:0; background:#fff; border-bottom:2px solid var(--border); padding:16px 20px; z-index:999; flex-direction:column; gap:4px; box-shadow:0 8px 24px rgba(27,107,47,.1); }
.mobile-menu.open { display:flex; animation:slideDown .25s ease; }
@keyframes slideDown { from{opacity:0;transform:translateY(-10px)} to{opacity:1;transform:translateY(0)} }
.mobile-menu a { padding:11px 16px; border-radius:10px; color:var(--text-dark); text-decoration:none; font-size:14px; font-weight:500; transition:background .2s; }
.mobile-menu a:hover { background:var(--accent-muted); color:var(--primary); }

/* ── FRONTEND FOOTER ─────────────────────────────────────────── */
#site-footer { background:var(--primary-dark); color:rgba(255,255,255,.65); padding:60px 0 0; }
.foot-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px; margin-bottom:48px; max-width:1280px; margin-left:auto; margin-right:auto; padding:0 28px; }
.fb .fn { font-family:var(--font-display); font-size:22px; font-weight:800; color:#fff; margin-bottom:10px; }
.fb .fn span { color:var(--accent); }
.fb p { font-size:13.5px; line-height:1.75; margin-bottom:18px; }
.socials { display:flex; gap:9px; margin-bottom:20px; }
.soc-btn { width:38px; height:38px; background:rgba(255,255,255,.07); border-radius:10px; display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.55); text-decoration:none; font-size:15px; transition:all .2s; }
.soc-btn:hover { background:var(--primary-light); color:#fff; }
.foot-cert { display:flex; gap:8px; flex-wrap:wrap; }
.cert-badge { padding:5px 11px; background:rgba(82,201,110,.1); border:1px solid rgba(82,201,110,.2); border-radius:20px; font-size:11px; color:var(--accent); font-weight:600; }
.fc { }
.fc h4 { font-family:var(--font-display); font-size:14.5px; font-weight:700; color:#fff; margin-bottom:14px; }
.fc ul { list-style:none; display:flex; flex-direction:column; gap:8px; }
.fc ul a { color:rgba(255,255,255,.5); text-decoration:none; font-size:13px; transition:color .2s; }
.fc ul a:hover { color:var(--accent); }
.foot-bottom { border-top:1px solid rgba(255,255,255,.07); padding:18px 28px; display:flex; justify-content:space-between; align-items:center; font-size:13px; flex-wrap:wrap; gap:10px; max-width:1280px; margin:0 auto; }
.foot-links a { color:var(--accent); text-decoration:none; margin-left:14px; }
.foot-links a:hover { text-decoration:underline; }

/* WhatsApp + Chat FAB */
.wa-fab { position:fixed; bottom:90px; right:24px; width:52px; height:52px; background:#25D366; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:24px; color:#fff; text-decoration:none; box-shadow:0 6px 20px rgba(37,211,102,.5); z-index:999; animation:floatBtn 3s ease-in-out infinite alternate; }
.wa-fab:hover { transform:scale(1.12); }
.chat-fab { position:fixed; bottom:24px; right:24px; width:52px; height:52px; background:linear-gradient(135deg,var(--primary-light),var(--accent)); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:22px; color:#fff; cursor:pointer; box-shadow:0 6px 20px rgba(40,167,69,.4); z-index:999; border:none; transition:all .3s; }
.chat-fab:hover { transform:scale(1.1); }
@keyframes floatBtn { from{transform:translateY(0)} to{transform:translateY(-7px)} }

/* Chat window */
.chat-win { position:fixed; bottom:88px; right:24px; width:325px; background:#fff; border:1px solid var(--border); border-radius:20px; box-shadow:0 20px 60px rgba(0,0,0,.12); z-index:1000; display:none; flex-direction:column; overflow:hidden; }
.chat-win.open { display:flex; animation:cSlideUp .3s ease; }
@keyframes cSlideUp { from{opacity:0;transform:translateY(18px)} to{opacity:1;transform:translateY(0)} }
.chat-hdr { background:linear-gradient(135deg,var(--primary),var(--primary-light)); padding:14px 16px; display:flex; align-items:center; gap:10px; color:#fff; }
.chat-av { width:36px; height:36px; background:rgba(255,255,255,.2); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:16px; }
.chat-hdr h4 { font-size:14px; font-weight:700; }
.chat-hdr p  { font-size:11px; opacity:.75; }
.chat-cls { margin-left:auto; background:none; border:none; color:#fff; cursor:pointer; font-size:16px; }
.chat-msgs { padding:14px; height:220px; overflow-y:auto; display:flex; flex-direction:column; gap:10px; }
.cmsg { max-width:82%; }
.cmsg.bot  { align-self:flex-start; }
.cmsg.user { align-self:flex-end; }
.cbubble { padding:10px 14px; border-radius:14px; font-size:13px; line-height:1.5; }
.bot .cbubble  { background:var(--body-bg); color:var(--text-dark); border-radius:4px 14px 14px 14px; }
.user .cbubble { background:var(--primary-light); color:#fff; border-radius:14px 4px 14px 14px; }
.chat-qr { padding:0 14px 10px; display:flex; flex-wrap:wrap; gap:6px; }
.qr { padding:5px 10px; background:var(--accent-muted); border:none; border-radius:20px; font-size:11px; font-weight:600; color:var(--primary); cursor:pointer; transition:all .2s; }
.qr:hover { background:var(--primary); color:#fff; }
.chat-inp-row { padding:10px 12px; border-top:1px solid var(--border); display:flex; gap:8px; }
.chat-inp { flex:1; padding:9px 13px; border:1.5px solid var(--border); border-radius:10px; font-size:13px; outline:none; }
.chat-inp:focus { border-color:var(--accent); }
.chat-snd { padding:9px 13px; background:var(--primary-light); border:none; border-radius:10px; color:#fff; cursor:pointer; font-size:14px; }

/* Toast */
.toast { position:fixed; top:90px; right:24px; background:var(--primary); color:#fff; padding:13px 20px; border-radius:12px; font-size:13.5px; font-weight:600; box-shadow:0 8px 24px rgba(27,107,47,.3); z-index:9999; display:none; align-items:center; gap:10px; }
.toast.show { display:flex; animation:toastIn .3s ease; }
@keyframes toastIn { from{opacity:0;transform:translateX(20px)} to{opacity:1;transform:translateX(0)} }

/* ── HERO ────────────────────────────────────────────────────── */
/* .hero { min-height:100vh; background:linear-gradient(160deg,#020d04 0%,#0D3B1E 40%,#1B6B2F 70%,#0F4A20 100%); display:flex; align-items:center; position:relative; overflow:hidden; padding-top:var(--nav-h); }
.hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 70% 30%,rgba(82,201,110,.12) 0%,transparent 50%),radial-gradient(ellipse at 20% 80%,rgba(32,201,151,.08) 0%,transparent 40%); }
.hero-dots { position:absolute; inset:0; background-image:radial-gradient(rgba(82,201,110,.08) 1px,transparent 1px); background-size:10px 10px; }
.hero-inner { max-width:1280px; margin:0 auto; padding:80px 28px; display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; position:relative; z-index:1; width:100%; }
.hero-badge { display:inline-flex; align-items:center; gap:8px; background:rgba(82,201,110,.15); border:1px solid rgba(82,201,110,.3); color:var(--accent); padding:6px 14px; border-radius:20px; font-size:12.5px; font-weight:600; margin-bottom:24px; }
.hero-badge .dot { width:6px; height:6px; background:var(--accent); border-radius:50%; animation:pulse 2s infinite; }
@keyframes pulse { 0%,100%{transform:scale(1);opacity:1} 50%{transform:scale(1.5);opacity:.5} }
.hero h1 { font-family:var(--font-display); font-size:clamp(36px,5vw,60px); font-weight:800; color:#fff; line-height:1.1; letter-spacing:-2px; margin-bottom:22px; }
.hero h1 .g { background:linear-gradient(135deg,var(--accent),var(--success)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.hero p { font-size:17px; color:rgba(255,255,255,.6); line-height:1.75; margin-bottom:36px; max-width:500px; }
.hero-ctas { display:flex; gap:14px; flex-wrap:wrap; }
.btn-hp { display:inline-flex; align-items:center; gap:9px; padding:14px 28px; background:linear-gradient(135deg,var(--primary-light),var(--accent)); border:none; border-radius:12px; color:#fff; font-family:var(--font-display); font-size:15px; font-weight:700; cursor:pointer; text-decoration:none; box-shadow:0 8px 28px rgba(40,167,69,.4); transition:all .3s; }
.btn-hp:hover { transform:translateY(-3px); box-shadow:0 12px 36px rgba(40,167,69,.5); color:#fff; }
.btn-ho { display:inline-flex; align-items:center; gap:9px; padding:14px 28px; background:rgba(255,255,255,.08); border:1.5px solid rgba(255,255,255,.25); border-radius:12px; color:#fff; font-size:15px; font-weight:600; cursor:pointer; text-decoration:none; transition:all .3s; backdrop-filter:blur(8px); }
.btn-ho:hover { background:rgba(255,255,255,.15); border-color:rgba(255,255,255,.4); color:#fff; }
.hero-stats { display:flex; gap:32px; margin-top:46px; padding-top:26px; border-top:1px solid rgba(255,255,255,.1); flex-wrap:wrap; }
.hs .val { font-family:var(--font-display); font-size:28px; font-weight:800; color:var(--accent); display:block; line-height:1; }
.hs .lbl { font-size:12px; color:rgba(255,255,255,.45); margin-top:3px; } */



.hero { 
  min-height:100vh; 
  /* IT Theme: Deep Slate to Tech Blue gradient */
  background:linear-gradient(160deg, #020617 0%, #0F172A 40%, #1E293B 70%, #0F172A 100%); 
  display:flex; 
  align-items:center; 
  position:relative; 
  overflow:hidden; 
  padding-top:var(--nav-h); 
}

.hero::before { 
  content:''; 
  position:absolute; 
  inset:0; 
  /* Accents: Electric Blue and Indigo glows */
  background:radial-gradient(ellipse at 70% 30%, rgba(0, 212, 255, 0.12) 0%, transparent 50%),
             radial-gradient(ellipse at 20% 80%, rgba(99, 102, 241, 0.08) 0%, transparent 40%); 
}

.hero-dots { 
  position:absolute; 
  inset:0; 
  /* Dot grid feel (common in dev tools) */
  background-image:radial-gradient(rgba(0, 212, 255, 0.08) 1px, transparent 1px); 
  background-size:10px 10px; 
}

.hero-inner { 
  max-width:90%; 
  margin:0 auto; 
  padding:5px 28px; 
  display:grid; 
  grid-template-columns:1fr 1fr; 
  gap:60px; 
  align-items:center; 
  position:relative; 
  z-index:1; 
  width:100%; 
}

.hero-badge { 
  display:inline-flex; 
  align-items:center; 
  gap:8px; 
  background:rgba(0, 212, 255, 0.1); 
  border:1px solid rgba(0, 212, 255, 0.25); 
  color:var(--accent); 
  padding:6px 14px; 
  border-radius:20px; 
  font-size:12.5px; 
  font-weight:600; 
  margin-bottom:24px; 
}

.hero-badge .dot { 
  width:6px; 
  height:6px; 
  background:var(--accent); 
  border-radius:50%; 
  animation:pulse 2s infinite; 
}

@keyframes pulse { 
  0%,100%{transform:scale(1); opacity:1} 
  50%{transform:scale(1.5); opacity:.5} 
}

.hero h1 { 
  font-family:var(--font-display); 
  font-size:clamp(36px, 5vw, 60px); 
  font-weight:800; 
  color:#fff; 
  line-height:1.1; 
  letter-spacing:-2px; 
  margin-bottom:22px; 
}

.hero h1 .g { 
  /* IT Theme: Cyan to Purple gradient for "tech" look */
  background:linear-gradient(135deg, var(--accent), var(--purple)); 
  -webkit-background-clip:text; 
  -webkit-text-fill-color:transparent; 
  background-clip:text; 
}

.hero p { 
  font-size:17px; 
  color:rgba(255, 255, 255, 0.7); 
  line-height:1.75; 
  margin-bottom:36px; 
  max-width:500px; 
}

.hero-ctas { 
  display:flex; 
  gap:14px; 
  flex-wrap:wrap; 
}

.btn-hp { 
  display:inline-flex; 
  align-items:center; 
  gap:9px; 
  padding:14px 28px; 
  /* Primary IT Gradient: Bright Tech Blue */
  background:linear-gradient(135deg, var(--primary), var(--primary-light)); 
  border:none; 
  border-radius:12px; 
  color:#fff; 
  font-family:var(--font-display); 
  font-size:15px; 
  font-weight:700; 
  cursor:pointer; 
  text-decoration:none; 
  box-shadow:0 8px 28px rgba(0, 98, 255, 0.3); 
  transition:all .3s; 
}

.btn-hp:hover { 
  transform:translateY(-3px); 
  box-shadow:0 12px 36px rgba(0, 98, 255, 0.45); 
  color:#fff; 
}

.btn-ho { 
  display:inline-flex; 
  align-items:center; 
  gap:9px; 
  padding:14px 28px; 
  background:rgba(255, 255, 255, 0.05); 
  border:1.5px solid rgba(255, 255, 255, 0.15); 
  border-radius:12px; 
  color:#fff; 
  font-size:15px; 
  font-weight:600; 
  cursor:pointer; 
  text-decoration:none; 
  transition:all .3s; 
  backdrop-filter:blur(8px); 
}

.btn-ho:hover { 
  background:rgba(255, 255, 255, 0.1); 
  border-color:rgba(255, 255, 255, 0.3); 
  color:#fff; 
}

.hero-stats { 
  display:flex; 
  gap:32px; 
  margin-top:46px; 
  padding-top:26px; 
  border-top:1px solid rgba(255, 255, 255, 0.1); 
  flex-wrap:wrap; 
}

.hs .val { 
  font-family:var(--font-display); 
  font-size:28px; 
  font-weight:800; 
  color:var(--accent); 
  display:block; 
  line-height:1; 
}

.hs .lbl { 
  font-size:12px; 
  color:rgba(255, 255, 255, 0.5); 
  margin-top:3px; 
}


/* Hero right showcase */
.hero-right { position:relative; }
.showcase-box { background:rgba(255,255,255,.06); backdrop-filter:blur(20px); border:1px solid rgba(255,255,255,.12); border-radius:24px; padding:28px; }
.sc-title { font-family:var(--font-display); font-size:13px; font-weight:700; color:var(--accent); text-transform:uppercase; letter-spacing:1px; margin-bottom:18px; text-align:center; }
.sc-tabs { display:flex; justify-content:center; gap:6px; margin-bottom:20px; }
.sc-tab { padding:6px 14px; border-radius:8px; font-size:12px; font-weight:600; cursor:pointer; color:rgba(255,255,255,.5); background:none; border:1px solid transparent; transition:all .2s; }
.sc-tab.active,.sc-tab:hover { background:rgba(82,201,110,.15); border-color:rgba(82,201,110,.3); color:var(--accent); }
.sc-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.sc-item { background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); border-radius:13px; padding:15px; cursor:pointer; transition:all .2s; }
.sc-item:hover { background:rgba(82,201,110,.1); border-color:rgba(82,201,110,.25); }
.sc-item .ico { font-size:28px; margin-bottom:8px; }
.sc-item .nm  { font-size:13px; font-weight:600; color:#fff; }
.sc-item .pr  { font-size:12px; color:var(--accent); margin-top:2px; }
.sc-link { display:block; text-align:center; margin-top:14px; color:var(--accent); font-size:13px; font-weight:700; text-decoration:none; }
.float-chip { position:absolute; background:#fff; border-radius:12px; padding:10px 14px; box-shadow:0 8px 24px rgba(0,0,0,.2); display:flex; align-items:center; gap:10px; font-size:12.5px; font-weight:600; white-space:nowrap; }
.fc1 { top:-50px; right:-16px; color:var(--primary); animation:floatUp 3s ease-in-out infinite alternate; }
.fc2 { bottom:-16px; left:-16px; color:#7C3AED; animation:floatUp 3s ease-in-out infinite alternate 1.5s; }
@keyframes floatUp { from{transform:translateY(0)} to{transform:translateY(-8px)} }
.chip-ico { width:30px; height:30px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:14px; }
.chip-ico.g { background:var(--accent-muted); color:var(--primary); }
.chip-ico.p { background:rgba(139,92,246,.1); color:#7C3AED; }

/* ── SECTIONS ────────────────────────────────────────────────── */
section { padding:88px 0; }
.container { max-width:1280px; margin:0 auto; padding:0 28px; }
.sec-badge { display:inline-flex; align-items:center; gap:6px; background:var(--accent-muted); color:var(--primary); padding:5px 12px; border-radius:20px; font-size:11.5px; font-weight:700; text-transform:uppercase; letter-spacing:.8px; margin-bottom:12px; }
.sec-title { font-family:var(--font-display); font-size:clamp(26px,3vw,40px); font-weight:800; color:var(--text-dark); letter-spacing:-1px; line-height:1.15; margin-bottom:12px; }
.sec-title span { color:var(--primary-light); }
.sec-desc { font-size:16px; color:var(--text-muted); max-width:560px; line-height:1.75; }
.sec-hdr { text-align:center; margin-bottom:52px; }
.sec-hdr .sec-desc { margin:0 auto; }

/* Categories, Products etc - from index.html */
.cats { background:#fff; }
.cat-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.cat-card { background:var(--front-bg); border:1px solid var(--border); border-radius:var(--radius); padding:26px 18px; text-align:center; cursor:pointer; transition:all .3s; text-decoration:none; color:var(--text-dark); display:block; }
.cat-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); border-color:var(--accent); background:#fff; }
.cat-ico { width:62px; height:62px; border-radius:16px; background:var(--accent-muted); display:flex; align-items:center; justify-content:center; font-size:24px; color:var(--primary); margin:0 auto 14px; transition:all .3s; }
.cat-card:hover .cat-ico { background:linear-gradient(135deg,var(--primary-light),var(--accent)); color:#fff; transform:scale(1.08); }
.cat-card h3 { font-family:var(--font-display); font-size:15px; font-weight:700; margin-bottom:5px; }
.cat-card p  { font-size:12.5px; color:var(--text-muted); margin-bottom:10px; line-height:1.5; }
.cat-count { font-size:11.5px; font-weight:700; color:var(--primary); background:var(--accent-muted); padding:3px 10px; border-radius:20px; display:inline-block; }
.prods-bg { background:var(--front-bg); }
.prod-filter { display:flex; align-items:center; gap:8px; margin-bottom:32px; flex-wrap:wrap; }
.pf-btn { padding:7px 18px; border-radius:20px; border:1.5px solid var(--border); background:#fff; color:var(--text-muted); font-size:13px; font-weight:600; cursor:pointer; transition:all .2s; }
.pf-btn:hover,.pf-btn.active { background:var(--primary); color:#fff; border-color:var(--primary); }
.prod-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(270px,1fr)); gap:22px; }
.prod-card { background:#fff; border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; transition:all .3s; }
.prod-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); }
.prod-img { height:175px; background:var(--front-bg); display:flex; align-items:center; justify-content:center; font-size:60px; position:relative; }
.prod-img img { width:100%; height:100%; object-fit:contain; padding:16px; }
.prod-tag { position:absolute; top:12px; left:12px; font-size:10px; font-weight:700; padding:3px 9px; border-radius:20px; text-transform:uppercase; letter-spacing:.5px; }
.tag-hot  { background:#DC3545; color:#fff; }
.tag-new  { background:#17A2B8; color:#fff; }
.tag-sale { background:var(--primary-light); color:#fff; }
.tag-ent  { background:#8B5CF6; color:#fff; }
.prod-body { padding:17px; }
.prod-cat  { font-size:10.5px; font-weight:700; color:var(--primary); text-transform:uppercase; letter-spacing:.5px; margin-bottom:5px; }
.prod-name { font-family:var(--font-display); font-size:14.5px; font-weight:700; margin-bottom:7px; line-height:1.35; }
.prod-spec { font-size:12px; color:var(--text-muted); margin-bottom:12px; line-height:1.5; }
.prod-price { display:flex; align-items:baseline; gap:7px; margin-bottom:12px; }
.pp-main { font-family:var(--font-display); font-size:20px; font-weight:800; color:var(--primary); }
.pp-orig { font-size:13px; color:var(--text-muted); text-decoration:line-through; }
.pp-off  { font-size:10.5px; font-weight:700; color:var(--primary-light); background:var(--accent-muted); padding:2px 7px; border-radius:20px; }
.prod-foot { display:flex; gap:8px; }
.btn-enq { flex:1; padding:9px; background:var(--accent-muted); border:none; border-radius:10px; color:var(--primary); font-size:13px; font-weight:600; cursor:pointer; transition:all .2s; }
.btn-enq:hover { background:var(--primary); color:#fff; }
.btn-add { padding:9px 13px; background:linear-gradient(135deg,var(--primary-light),var(--accent)); border:none; border-radius:10px; color:#fff; cursor:pointer; font-size:14px; transition:all .2s; }
.btn-add:hover { opacity:.85; }

/* Why us, services, testimonials */
.why-bg { background:var(--primary-dark); }
.why-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.why-list { list-style:none; display:flex; flex-direction:column; gap:18px; }
.why-item { display:flex; gap:16px; align-items:flex-start; }
.why-ico  { width:48px; height:48px; background:rgba(82,201,110,.12); border:1px solid rgba(82,201,110,.2); border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:18px; color:var(--accent); flex-shrink:0; }
.why-item h4 { font-family:var(--font-display); font-size:16px; font-weight:700; color:#fff; margin-bottom:4px; }
.why-item p  { font-size:13.5px; color:rgba(255,255,255,.5); line-height:1.65; }
.why-metrics { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.met-card { background:rgba(255,255,255,.05); border:1px solid rgba(82,201,110,.12); border-radius:16px; padding:22px; text-align:center; }
.met-val  { font-family:var(--font-display); font-size:38px; font-weight:800; color:var(--accent); line-height:1; }
.met-lbl  { font-size:13px; color:rgba(255,255,255,.45); margin-top:5px; }
.svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.svc-card { background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:28px; transition:all .3s; }
.svc-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); border-color:var(--accent); }
.svc-ico { width:54px; height:54px; border-radius:14px; background:var(--accent-muted); display:flex; align-items:center; justify-content:center; font-size:22px; color:var(--primary); margin-bottom:16px; transition:all .3s; }
.svc-card:hover .svc-ico { background:var(--primary); color:#fff; }
.svc-card h3 { font-family:var(--font-display); font-size:16px; font-weight:700; margin-bottom:9px; }
.svc-card p  { font-size:13.5px; color:var(--text-muted); line-height:1.7; margin-bottom:14px; }
.svc-link { color:var(--primary); font-size:13px; font-weight:700; text-decoration:none; display:inline-flex; align-items:center; gap:5px; transition:gap .2s; }
.svc-link:hover { gap:9px; }
.testi-bg { background:#fff; }
.testi-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.testi-card { background:var(--front-bg); border:1px solid var(--border); border-radius:var(--radius); padding:26px; transition:all .3s; }
.testi-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.stars { color:#FFC107; font-size:14px; margin-bottom:12px; }
.testi-quote { font-size:14px; color:var(--text-muted); line-height:1.75; margin-bottom:18px; font-style:italic; }
.testi-auth { display:flex; align-items:center; gap:12px; }
.testi-av { width:44px; height:44px; border-radius:12px; background:linear-gradient(135deg,var(--accent),var(--primary)); display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-size:16px; font-weight:800; color:#fff; }
.testi-auth .nm { font-weight:700; font-size:14px; }
.testi-auth .co { font-size:12px; color:var(--text-muted); }
/* CTA, Contact, Newsletter */
.cta-banner { background:linear-gradient(135deg,var(--primary),var(--primary-light)); padding:60px 0; }
.cta-inner  { max-width:1280px; margin:0 auto; padding:0 28px; display:flex; align-items:center; justify-content:space-between; gap:32px; flex-wrap:wrap; }
.cta-inner h2 { font-family:var(--font-display); font-size:32px; font-weight:800; color:#fff; letter-spacing:-.5px; }
.cta-inner p  { color:rgba(255,255,255,.7); font-size:16px; margin-top:6px; }
.cta-btns { display:flex; gap:14px; flex-wrap:wrap; }
.cta-btns .btn-w { padding:13px 28px; background:#fff; border:none; border-radius:12px; color:var(--primary); font-family:var(--font-display); font-size:14px; font-weight:700; cursor:pointer; text-decoration:none; transition:all .2s; box-shadow:0 4px 16px rgba(0,0,0,.15); }
.cta-btns .btn-w:hover { transform:translateY(-2px); }
.cta-btns .btn-t { padding:13px 28px; background:rgba(255,255,255,.15); border:1.5px solid rgba(255,255,255,.4); border-radius:12px; color:#fff; font-family:var(--font-display); font-size:14px; font-weight:700; cursor:pointer; text-decoration:none; transition:all .2s; }
.cta-btns .btn-t:hover { background:rgba(255,255,255,.25); }
.contact-bg { background:var(--front-bg); }
.contact-grid { display:grid; grid-template-columns:1fr 1.2fr; gap:56px; align-items:start; }
.ci h2 { font-family:var(--font-display); font-size:clamp(24px,2.5vw,36px); font-weight:800; letter-spacing:-.5px; margin-bottom:14px; line-height:1.2; }
.ci p  { color:var(--text-muted); font-size:15px; line-height:1.7; margin-bottom:30px; }
.cdet  { display:flex; flex-direction:column; gap:14px; margin-bottom:28px; }
.cd-item { display:flex; gap:14px; align-items:flex-start; }
.cd-ico  { width:44px; height:44px; background:var(--accent-muted); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:16px; color:var(--primary); flex-shrink:0; }
.cd-lbl  { font-size:11px; color:var(--text-muted); text-transform:uppercase; letter-spacing:.6px; font-weight:700; }
.cd-val  { font-size:14.5px; font-weight:600; margin-top:2px; }
.cf-box  { background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:32px; box-shadow:var(--shadow); }
.cf-box h3 { font-family:var(--font-display); font-size:20px; font-weight:700; margin-bottom:22px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.fg { margin-bottom:15px; }
.fl { display:block; font-size:11.5px; font-weight:700; text-transform:uppercase; letter-spacing:.6px; color:var(--text-muted); margin-bottom:6px; }
.fi,.fs,.fta { width:100%; padding:11px 15px; background:var(--front-bg); border:1.5px solid var(--border); border-radius:10px; font-size:14px; color:var(--text-dark); outline:none; transition:all .2s; }
.fi:focus,.fs:focus,.fta:focus { border-color:var(--accent); background:#fff; box-shadow:0 0 0 3px rgba(82,201,110,.1); }
.fta { resize:vertical; min-height:95px; }
.btn-sub { width:100%; padding:14px; background:linear-gradient(135deg,var(--primary-light),var(--accent)); border:none; border-radius:12px; color:#fff; font-family:var(--font-display); font-size:15px; font-weight:700; cursor:pointer; transition:all .2s; box-shadow:0 6px 20px rgba(40,167,69,.3); }
.btn-sub:hover { transform:translateY(-2px); box-shadow:0 10px 28px rgba(40,167,69,.4); }

/* ── BRANDS ──────────────────────────────────────────────────── */
.brands-sec { background:#fff; padding:48px 0; }
.brands-inner { max-width:1280px; margin:0 auto; padding:0 28px; }
.brands-label { text-align:center; font-size:13px; font-weight:700; color:var(--text-muted); text-transform:uppercase; letter-spacing:1px; margin-bottom:28px; }
.brands-scroll { display:flex; gap:20px; align-items:center; justify-content:center; flex-wrap:wrap; }
.brand-pill { padding:10px 24px; background:var(--front-bg); border:1.5px solid var(--border); border-radius:12px; font-family:var(--font-display); font-size:14px; font-weight:700; color:var(--text-muted); transition:all .2s; cursor:default; }
.brand-pill:hover { border-color:var(--accent); color:var(--primary); background:var(--accent-muted); }

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media(max-width:1100px) { .cat-grid{grid-template-columns:repeat(2,1fr)} .svc-grid{grid-template-columns:repeat(2,1fr)} .testi-grid{grid-template-columns:1fr 1fr} .foot-grid{grid-template-columns:1fr 1fr} }
@media(max-width:900px)  { .hero-inner{grid-template-columns:1fr} .hero-right{display:none} .why-grid{grid-template-columns:1fr} .contact-grid{grid-template-columns:1fr} .nav-links{display:none} .hamburger{display:flex} .nav-actions .btn-ghost{display:none} }
@media(max-width:600px)  { .cat-grid{grid-template-columns:1fr 1fr;gap:12px} .prod-grid{grid-template-columns:1fr} .svc-grid{grid-template-columns:1fr} .testi-grid{grid-template-columns:1fr} .foot-grid{grid-template-columns:1fr} .form-row{grid-template-columns:1fr} .cta-inner{flex-direction:column;text-align:center} .hero-stats{gap:20px} }
