/* ============================================================
   FUSIONAR – Dark Theme
   Replaces: bootstrap.css, style.css, skin-blue.css
   ============================================================ */

/* ── VARIABLES ── */
:root {
  --bg:    #070c18;
  --bg-s:  #0b1220;
  --bg-c:  #0e1828;
  --bg-ch: #12203a;
  --bd:    rgba(0,200,255,.1);
  --bds:   rgba(0,200,255,.22);
  --bdh:   rgba(0,200,255,.4);
  --cy:    #00c8ff;
  --cy-g:  rgba(0,200,255,.07);
  --cy-gg: rgba(0,200,255,.13);
  --t1:    #eef3ff;
  --t2:    rgba(190,210,240,.65);
  --tm:    rgba(160,185,220,.67);
  --grd:   linear-gradient(135deg,#00c8ff 0%,#0090e0 100%);
}

/* ── RESET / BASE ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  font-family:'Inter',sans-serif;
  background:var(--bg);
  color:var(--t1);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  font-size:14px;
  line-height:1.6;
}
a { color:var(--cy); text-decoration:none; }
a:hover { text-decoration:underline; }
img { max-width:100%; height:auto; display:block; }
ul { list-style:none; }
h1,h2,h3,h4,h5 { font-family:'Space Grotesk',sans-serif; color:var(--t1); line-height:1.15; letter-spacing:-.3px; }

/* ── ACCENT LINE ── */
.accent-line {
  height:2px;
  background:linear-gradient(90deg,transparent 0%,#00c8ff 30%,#0070d4 70%,transparent 100%);
}

/* ── TOPBAR ── */
.topbar {
  background:rgba(7,12,24,.97);
  border-bottom:1px solid var(--bd);
  padding:6px 0;
}
.topbar-i {
  max-width:1200px; margin:0 auto; padding:0 32px;
  display:flex; justify-content:space-between; align-items:center;
}
.topbar-contacts { display:flex; gap:20px; }
.topbar-contacts span {
  display:inline-flex; align-items:center; gap:5px;
  color:var(--tm); font-size:11px;
}
.topbar-socials { display:flex; gap:8px; }
.topbar-socials a {
  width:24px; height:24px;
  border:1px solid var(--bd); border-radius:5px;
  display:flex; align-items:center; justify-content:center;
  color:var(--tm); font-size:10px; font-weight:700; transition:.2s;
}
.topbar-socials a:hover { border-color:var(--cy); color:var(--cy); background:var(--cy-g); text-decoration:none; }

/* ── NAVBAR ── */
.site-nav {
  background:rgba(7,12,24,.92);
  border-bottom:1px solid var(--bd);
  position:sticky; top:0; z-index:200;
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
}
.nav-i {
  max-width:1200px; margin:0 auto; padding:0 32px;
  display:flex; align-items:center; justify-content:space-between;
  height:66px;
}
.nav-logo img {
  height:36px; width:auto;
  filter:drop-shadow(0 0 8px rgba(0,200,255,.15));
}
.nav-links { display:flex; align-items:center; gap:1px; }
.nav-links a {
  padding:7px 13px; border-radius:6px;
  color:var(--t2); font-size:11.5px; font-weight:500;
  text-transform:uppercase; letter-spacing:.9px;
  white-space:nowrap; transition:.15s;
}
.nav-links a:hover,
.nav-links a:not(.nav-cta).nav-active { color:var(--cy); background:var(--cy-g); text-decoration:none; }
.nav-links a.nav-cta.nav-active { background:var(--cy); color:#fff !important; text-decoration:none; }
.nav-cta {
  margin-left:10px; padding:8px 20px;
  background:var(--cy); color:#fff !important;
  border-radius:6px; font-size:11.5px; font-weight:800;
  letter-spacing:.4px; text-transform:uppercase; transition:.15s;
}
.nav-cta:hover { filter:brightness(1.1); box-shadow:0 4px 18px rgba(0,200,255,.3); }

/* Hamburger */
.nav-hamburger {
  display:none; flex-direction:column; gap:5px; cursor:pointer;
  padding:8px; border:1px solid var(--bd); border-radius:6px;
  background:transparent;
}
.nav-hamburger span { width:20px; height:2px; background:var(--t2); border-radius:2px; display:block; transition:.2s; }

/* Mobile menu */
.nav-mobile-menu {
  display:none;
  position:fixed; top:0; left:0; right:0; bottom:0;
  background:rgba(7,12,24,.98);
  z-index:300; flex-direction:column;
  align-items:center; justify-content:center; gap:8px;
}
.nav-mobile-menu.open { display:flex; }
.nav-mobile-menu a {
  font-size:18px; font-weight:600; color:var(--t2);
  padding:12px 24px; border-radius:8px;
  text-transform:uppercase; letter-spacing:1px; transition:.15s;
}
.nav-mobile-menu a:hover { color:var(--cy); background:var(--cy-g); }
.nav-mobile-close {
  position:absolute; top:20px; right:20px;
  background:transparent; border:1px solid var(--bd);
  color:var(--t2); font-size:20px; cursor:pointer;
  width:40px; height:40px; border-radius:8px;
  display:flex; align-items:center; justify-content:center;
}

/* ── LAYOUT UTILITIES ── */
.container { max-width:1200px; margin:0 auto; padding:0 32px; }
.section { padding:80px 0; }
.section-alt { background:var(--bg-s); border-top:1px solid var(--bd); border-bottom:1px solid var(--bd); }

/* Section header */
.s-label {
  display:inline-block; color:var(--cy);
  font-size:10px; font-weight:700; letter-spacing:3px; text-transform:uppercase;
  margin-bottom:10px;
}
.s-divider { width:36px; height:3px; background:var(--cy); border-radius:2px; margin-bottom:14px; box-shadow:0 0 10px rgba(0,200,255,.4); }
.s-title { font-size:31px; font-weight:700; margin-bottom:13px; }
.s-subtitle { color:var(--t2); font-size:15px; line-height:1.75; max-width:560px; }
.s-head { margin-bottom:48px; }

/* ── BUTTONS ── */
.btn-a {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--grd); color:#fff;
  padding:13px 26px; border-radius:7px;
  font-weight:800; font-size:13px; letter-spacing:.2px;
  box-shadow:0 4px 20px rgba(0,200,255,.25); transition:.2s;
}
.btn-a:hover { filter:brightness(1.08); transform:translateY(-1px); box-shadow:0 6px 28px rgba(0,200,255,.35); text-decoration:none; color:#fff; }
.btn-b {
  display:inline-flex; align-items:center; gap:8px;
  border:1px solid rgba(0,200,255,.28); color:var(--cy);
  padding:13px 26px; border-radius:7px;
  font-weight:600; font-size:13px; transition:.2s;
}
.btn-b:hover { background:var(--cy-g); border-color:rgba(0,200,255,.5); transform:translateY(-1px); text-decoration:none; }

/* ── HERO (homepage only) ── */
.hero {
  display:grid; grid-template-columns:1fr 1fr;
  min-height:620px; position:relative; overflow:hidden;
}
.hero-bg { position:absolute; inset:0; pointer-events:none; }
.hero-bg-grid {
  position:absolute; inset:0;
  background-image:linear-gradient(rgba(0,200,255,.032) 1px,transparent 1px),
    linear-gradient(90deg,rgba(0,200,255,.032) 1px,transparent 1px);
  background-size:50px 50px;
}
.hero-glow1 {
  position:absolute; top:-120px; left:-80px;
  width:560px; height:460px;
  background:radial-gradient(ellipse,rgba(0,140,255,.11) 0%,transparent 65%);
}
.hero-glow2 {
  position:absolute; bottom:-80px; right:0;
  width:400px; height:320px;
  background:radial-gradient(ellipse,rgba(0,200,255,.06) 0%,transparent 65%);
}
.hero-left {
  padding:72px 56px 72px 64px;
  display:flex; flex-direction:column; justify-content:center;
  position:relative; z-index:1;
}
.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(0,200,255,.07); border:1px solid rgba(0,200,255,.2);
  color:var(--cy); font-size:10px; font-weight:600;
  letter-spacing:2px; text-transform:uppercase;
  padding:5px 14px; border-radius:20px; width:fit-content; margin-bottom:26px;
}
.hero-badge-dot {
  width:6px; height:6px; border-radius:50%; background:var(--cy);
  flex-shrink:0; animation:badge-pulse 2s infinite;
}
@keyframes badge-pulse {
  0%,100%{ opacity:1; box-shadow:0 0 0 0 rgba(0,200,255,.5); }
  50%{ opacity:.4; box-shadow:0 0 0 4px rgba(0,200,255,0); }
}
.hero-title {
  font-size:clamp(30px,3vw,50px); font-weight:700;
  line-height:1.08; margin-bottom:20px; letter-spacing:-.5px;
}
.hero-title-accent {
  background:linear-gradient(90deg,#00c8ff,#4ab8ff);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
}
.hero-desc { color:var(--t2); font-size:15px; line-height:1.75; margin-bottom:36px; max-width:400px; }
.hero-ctas { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:48px; }
.hero-stats { display:flex; gap:36px; flex-wrap:wrap; }
.hero-stat { position:relative; }
.hero-stat + .hero-stat::before {
  content:''; position:absolute; left:-18px; top:4px;
  height:28px; width:1px; background:rgba(255,255,255,.08);
}
.hero-stat-num { font-family:'Space Grotesk',sans-serif; font-size:28px; font-weight:700; line-height:1; }
.hero-stat-num em { color:var(--cy); font-style:normal; }
.hero-stat-lbl { font-size:10.5px; color:var(--tm); text-transform:uppercase; letter-spacing:1.2px; margin-top:4px; }

/* Hero right – product tiles */
.hero-right {
  border-left:1px solid var(--bd);
  display:grid; grid-template-columns:1fr 1fr; grid-auto-rows:1fr;
  position:relative; z-index:1;
}
.hero-tile {
  border:1px solid var(--bd); border-top:none; border-right:none;
  padding:32px 28px; display:flex; flex-direction:column; gap:12px;
  cursor:pointer; transition:background .2s; position:relative; overflow:hidden;
}
.hero-tile::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(0,200,255,.2),transparent);
  opacity:0; transition:opacity .2s;
}
.hero-tile::after {
  content:''; position:absolute; bottom:0; left:0;
  width:0; height:2px; background:var(--cy); transition:width .35s ease;
}
.hero-tile:hover { background:var(--cy-g); }
.hero-tile:hover::before { opacity:1; }
.hero-tile:hover::after { width:100%; }
.hero-tile-icon {
  width:54px; height:54px;
  background:rgba(0,200,255,.08); border:1px solid var(--bds);
  border-radius:12px; display:flex; align-items:center; justify-content:center;
  font-size:26px; flex-shrink:0; transition:.2s;
}
.hero-tile:hover .hero-tile-icon { background:rgba(0,200,255,.15); border-color:var(--cy); box-shadow:0 0 16px rgba(0,200,255,.12); }
.hero-tile-name { font-size:17px; font-weight:700; color:var(--t1); line-height:1.2; }
.hero-tile-desc { font-size:12.5px; color:var(--t2); line-height:1.6; flex:1; }
.hero-tile-link { font-size:12px; color:var(--cy); font-weight:600; letter-spacing:.3px; margin-top:2px; display:flex; align-items:center; gap:4px; }
.hero-tile-link::after { content:'→'; transition:transform .2s; }
.hero-tile:hover .hero-tile-link::after { transform:translateX(4px); }

/* ── PAGE HEADER (inner pages) ── */
.page-header {
  background:var(--bg-s); border-bottom:1px solid var(--bd);
  padding:52px 0 48px; position:relative; overflow:hidden;
}
.page-header::before {
  content:''; position:absolute; inset:0;
  background-image:linear-gradient(rgba(0,200,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(0,200,255,.025) 1px,transparent 1px);
  background-size:50px 50px; pointer-events:none;
}
.page-header::after {
  content:''; position:absolute; top:-100px; left:-60px;
  width:400px; height:300px;
  background:radial-gradient(ellipse,rgba(0,120,255,.08) 0%,transparent 65%);
  pointer-events:none;
}
.page-header-inner { position:relative; z-index:1; }
.page-header-label {
  display:inline-block; color:var(--cy); font-size:10px;
  font-weight:700; letter-spacing:3px; text-transform:uppercase; margin-bottom:10px;
}
.page-header-title { font-size:clamp(24px,3vw,38px); font-weight:700; margin-bottom:10px; }
.page-header-desc { color:var(--t2); font-size:15px; line-height:1.7; max-width:600px; }
.breadcrumb-nav { display:flex; gap:6px; align-items:center; margin-top:16px; font-size:12px; color:var(--tm); }
.breadcrumb-nav a { color:var(--tm); }
.breadcrumb-nav a:hover { color:var(--cy); }
.breadcrumb-nav .sep { color:var(--tm); }

/* ── SERVICE CARDS ── */
.svc-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1px; background:var(--bd); border:1px solid var(--bd);
  border-radius:14px; overflow:hidden;
}
.svc-card {
  background:var(--bg-c); padding:38px 32px;
  display:flex; flex-direction:column; gap:16px;
  transition:background .2s; position:relative; overflow:hidden;
}
.svc-card::after {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:var(--grd); transform:scaleX(0); transform-origin:left; transition:transform .3s;
}
.svc-card:hover { background:var(--bg-ch); }
.svc-card:hover::after { transform:scaleX(1); }
.svc-icon {
  width:52px; height:52px;
  background:rgba(0,200,255,.07); border:1px solid var(--bds);
  border-radius:12px; display:flex; align-items:center; justify-content:center;
  font-size:24px; transition:.2s;
}
.svc-card:hover .svc-icon { background:rgba(0,200,255,.14); border-color:var(--cy); }
.svc-name { font-size:18px; font-weight:700; }
.svc-desc { font-size:13.5px; color:var(--t2); line-height:1.65; }
.svc-link { font-size:12px; color:var(--cy); margin-top:auto; font-weight:600; display:flex; align-items:center; gap:4px; }
.svc-link::after { content:'→'; transition:transform .2s; }
.svc-card:hover .svc-link::after { transform:translateX(4px); }

/* ── TESTIMONIAL CARDS ── */
.tst-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.tst-card {
  background:var(--bg-c); border:1px solid var(--bd);
  border-radius:14px; padding:30px;
  display:flex; flex-direction:column; gap:16px;
  position:relative; overflow:hidden;
  transition:border-color .2s, transform .2s, box-shadow .2s;
}
.tst-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--cy),transparent); opacity:.6;
}
.tst-card:hover { border-color:var(--bds); transform:translateY(-3px); box-shadow:0 10px 36px rgba(0,200,255,.07); }
.tst-quote { font-size:36px; color:var(--cy); opacity:.6; line-height:1; font-family:Georgia,serif; }
.tst-text { font-size:14px; color:var(--t2); line-height:1.75; font-style:italic; flex:1; }
.tst-author { display:flex; align-items:center; gap:12px; margin-top:auto; padding-top:16px; border-top:1px solid var(--bd); }
.tst-avatar {
  width:40px; height:40px; flex-shrink:0;
  background:linear-gradient(135deg,rgba(0,200,255,.18),rgba(0,80,180,.18));
  border:1px solid var(--bds); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:13px; font-weight:700; color:var(--cy);
}
.tst-name { font-size:13.5px; font-weight:600; }
.tst-company { font-size:11px; color:var(--tm); margin-top:2px; }

/* ── PRODUCT CARDS (catalog grid) ── */
.prod-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.prod-card {
  background:var(--bg-c); border:1px solid var(--bd);
  border-radius:12px; padding:22px 18px;
  display:flex; flex-direction:column; align-items:center; gap:11px;
  text-align:center; cursor:pointer; transition:all .22s; position:relative;
}
.prod-card::after { content:''; position:absolute; inset:0; border-radius:12px; box-shadow:inset 0 0 0 1px transparent; transition:box-shadow .22s; }
.prod-card:hover { background:rgba(0,200,255,.06); transform:translateY(-4px); box-shadow:0 12px 36px rgba(0,200,255,.1); }
.prod-card:hover::after { box-shadow:inset 0 0 0 1px var(--cy); }
.prod-card-img {
  width:80px; height:80px;
  border-radius:10px; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  background:rgba(0,200,255,.05); border:1px solid var(--bd);
  transition:.22s;
}
.prod-card-img img { width:100%; height:100%; object-fit:contain; }
.prod-card:hover .prod-card-img { border-color:var(--bds); }
.prod-card-name { font-size:13px; font-weight:700; }
.prod-card-cat { font-size:10px; color:var(--tm); text-transform:uppercase; letter-spacing:1px; }
.prod-card-link { font-size:11.5px; color:var(--cy); font-weight:600; margin-top:auto; }
.prod-more { text-align:center; margin-top:30px; color:var(--tm); font-size:13.5px; }
.prod-more a { color:var(--cy); font-weight:600; }

/* Hardware filter buttons */
.filter-bar { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:32px; }
.filter-btn {
  padding:7px 16px; border-radius:6px;
  border:1px solid var(--bd); background:transparent;
  color:var(--t2); font-size:12px; font-weight:600;
  cursor:pointer; transition:.15s; font-family:'Inter',sans-serif;
}
.filter-btn:hover, .filter-btn.selected { border-color:var(--cy); color:var(--cy); background:var(--cy-g); }

/* ── PARTNERS ── */
.partners-label { text-align:center; font-size:10.5px; color:var(--tm); text-transform:uppercase; letter-spacing:3px; margin-bottom:30px; }
.partners-row { display:flex; justify-content:center; align-items:center; gap:16px; flex-wrap:wrap; }
.partner-chip {
  height:44px; padding:6px 20px;
  background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.07);
  border-radius:8px; display:flex; align-items:center; justify-content:center;
  transition:.2s;
}
.partner-chip img { height:28px; width:auto; filter:grayscale(1) brightness(1.8) opacity(.55); transition:.2s; }
.partner-chip:hover { border-color:rgba(0,200,255,.28); }
.partner-chip:hover img { filter:none; opacity:1; }

/* ── CTA BAND ── */
.cta-band {
  background:linear-gradient(135deg,rgba(0,200,255,.055),rgba(0,110,210,.07));
  border-top:1px solid var(--bd); border-bottom:1px solid var(--bd);
  padding:60px 0; text-align:center; position:relative; overflow:hidden;
}
.cta-band::before {
  content:''; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:600px; height:300px;
  background:radial-gradient(ellipse,rgba(0,200,255,.05) 0%,transparent 65%);
  pointer-events:none;
}
.cta-band-title { font-size:30px; font-weight:700; margin-bottom:12px; letter-spacing:-.3px; }
.cta-band-sub { color:var(--t2); margin-bottom:30px; font-size:15px; }
.cta-band-btns { display:flex; justify-content:center; gap:14px; flex-wrap:wrap; }

/* ── FOOTER ── */
.site-footer {
  background:var(--bg-s); border-top:1px solid var(--bd);
  padding:56px 0 28px; position:relative;
}
.site-footer::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(0,200,255,.25),transparent);
}
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:48px; margin-bottom:48px; }
.footer-logo img { height:28px; width:auto; margin-bottom:16px; opacity:.9; }
.footer-desc { font-size:13px; color:var(--tm); line-height:1.75; }
.footer-col-title { font-size:10.5px; font-weight:700; color:rgba(190,210,240,.7); text-transform:uppercase; letter-spacing:2px; margin-bottom:14px; }
.footer-links { list-style:none; display:flex; flex-direction:column; gap:9px; }
.footer-links li a { font-size:13.5px; color:var(--tm); transition:.15s; }
.footer-links li a:hover { color:var(--cy); }
.footer-contact-item { display:flex; gap:9px; align-items:flex-start; margin-bottom:11px; }
.footer-contact-icon { color:var(--cy); font-size:13px; margin-top:2px; flex-shrink:0; opacity:.8; }
.footer-contact-text { font-size:13px; color:var(--tm); line-height:1.55; }
.footer-bottom { border-top:1px solid var(--bd); padding-top:20px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:10px; }
.footer-copy { font-size:12px; color:var(--tm); }
.footer-copy em { color:var(--cy); font-style:normal; }

/* ── BACK TO TOP ── */
#back-top {
  position:fixed; bottom:28px; right:28px;
  width:42px; height:42px;
  background:rgba(0,200,255,.12); border:1px solid var(--bds);
  border-radius:10px; display:flex; align-items:center; justify-content:center;
  color:var(--cy); font-size:18px; cursor:pointer;
  transition:.2s; backdrop-filter:blur(8px); z-index:99;
  text-decoration:none; display:none;
}
#back-top:hover { background:rgba(0,200,255,.2); transform:translateY(-2px); box-shadow:0 4px 16px rgba(0,200,255,.2); }

/* ── FORMS ── */
.form-section { padding:56px 0; }
.form-grid { display:grid; grid-template-columns:1.4fr 1fr; gap:48px; }
.form-title { font-size:22px; font-weight:700; margin-bottom:24px; }
.form-field { margin-bottom:18px; }
.form-field label { display:block; font-size:12px; font-weight:600; color:var(--t2); letter-spacing:.5px; text-transform:uppercase; margin-bottom:6px; }
.form-field input,
.form-field textarea,
.form-field select {
  width:100%; padding:11px 14px;
  background:rgba(255,255,255,.04); border:1px solid var(--bd);
  border-radius:7px; color:var(--t1);
  font-family:'Inter',sans-serif; font-size:14px;
  transition:border-color .2s, box-shadow .2s;
  -webkit-appearance:none;
}
.form-field select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2300c8ff' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 38px;
}
.form-field input::placeholder, .form-field textarea::placeholder { color:var(--tm); }
.form-field input:focus, .form-field textarea:focus, .form-field select:focus {
  outline:none; border-color:var(--cy);
  box-shadow:0 0 0 3px rgba(0,200,255,.1);
  background:rgba(255,255,255,.05);
}
.form-field input.error, .form-field textarea.error, .form-field select.error { border-color:#ff4d4d; box-shadow:0 0 0 3px rgba(255,77,77,.1); }
.form-field textarea { resize:vertical; min-height:130px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-submit { margin-top:8px; }
.form-submit input[type=submit] {
  padding:12px 32px; background:var(--cy); color:#060b16;
  border:none; border-radius:7px; font-weight:800; font-size:14px;
  cursor:pointer; transition:.2s; font-family:'Inter',sans-serif;
  box-shadow:0 4px 20px rgba(0,200,255,.25);
}
.form-submit input[type=submit]:hover { filter:brightness(1.08); transform:translateY(-1px); }
.form-success {
  display:none; padding:14px 18px;
  background:rgba(0,200,70,.08); border:1px solid rgba(0,200,70,.25);
  border-radius:8px; color:#4ade80; font-size:14px; margin-bottom:20px;
}
.contact-info-title { font-size:18px; font-weight:700; margin-bottom:18px; }
.contact-info-item { display:flex; gap:10px; align-items:flex-start; margin-bottom:14px; }
.contact-info-icon { color:var(--cy); font-size:15px; margin-top:2px; flex-shrink:0; }
.contact-info-text { font-size:14px; color:var(--t2); line-height:1.6; }
.map-container { border-radius:10px; overflow:hidden; border:1px solid var(--bd); margin-top:24px; }
.map-container iframe { width:100%; height:280px; border:0; display:block; pointer-events:none; }
.map-container.active iframe { pointer-events:all; }

/* ── EMPRESA / CONTENT CARDS ── */
.content-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-bottom:32px; }
.content-card {
  background:var(--bg-c); border:1px solid var(--bd);
  border-radius:12px; padding:30px;
  display:flex; flex-direction:column; gap:12px;
}
.content-card-title { font-size:17px; font-weight:700; color:var(--cy); }
.content-card-text { font-size:14px; color:var(--t2); line-height:1.7; }
.policy-block {
  background:var(--bg-c); border:1px solid var(--bd);
  border-left:3px solid var(--cy); border-radius:0 10px 10px 0;
  padding:28px 32px; font-size:14px; color:var(--t2); line-height:1.8;
}
.policy-block p + p { margin-top:14px; }

/* ── SOFTWARE PRODUCT CARDS ── */
.software-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.sw-card {
  background:var(--bg-c); border:1px solid var(--bd);
  border-radius:14px; padding:32px; display:flex; flex-direction:column; gap:16px;
  transition:border-color .2s, box-shadow .2s;
}
.sw-card:hover { border-color:var(--bds); box-shadow:0 8px 32px rgba(0,200,255,.07); }
.sw-card-img { width:100%; height:160px; object-fit:cover; border-radius:8px; border:1px solid var(--bd); }
.sw-card-title { font-size:20px; font-weight:700; }
.sw-card-desc { font-size:13.5px; color:var(--t2); line-height:1.7; flex:1; }
.sw-card-link { font-size:13px; color:var(--cy); font-weight:600; margin-top:auto; }

/* ── NOVEDADES / ARTICLE ── */
.article-grid { display:grid; grid-template-columns:1fr 1.5fr; gap:48px; align-items:start; }
.article-img { border-radius:12px; border:1px solid var(--bd); overflow:hidden; }
.article-img img { width:100%; height:auto; display:block; }
.article-title { font-size:24px; font-weight:700; margin-bottom:16px; }
.article-body { font-size:14.5px; color:var(--t2); line-height:1.8; }
.article-body p + p { margin-top:14px; }
.article-body a { color:var(--cy); }

/* Novedades index cards */
.novedades-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.novedad-card {
  background:var(--bg-c); border:1px solid var(--bd);
  border-radius:12px; overflow:hidden;
  transition:border-color .2s, transform .2s;
}
.novedad-card:hover { border-color:var(--bds); transform:translateY(-3px); }
.novedad-card-img { width:100%; height:160px; object-fit:cover; }
.novedad-card-body { padding:20px; display:flex; flex-direction:column; gap:10px; }
.novedad-card-title { font-size:16px; font-weight:700; }
.novedad-card-desc { font-size:13px; color:var(--t2); line-height:1.6; }
.novedad-card-link { font-size:12px; color:var(--cy); font-weight:600; margin-top:auto; }

/* ── PRODUCT DETAIL PAGE ── */
.product-detail-grid { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start; }
.product-detail-img { border-radius:12px; border:1px solid var(--bd); overflow:hidden; }
.product-detail-img img { width:100%; height:auto; }
.product-detail-title { font-size:28px; font-weight:700; margin-bottom:16px; }
.product-detail-body { font-size:14.5px; color:var(--t2); line-height:1.8; }
.product-detail-body p + p { margin-top:12px; }
.product-back { display:inline-flex; align-items:center; gap:6px; color:var(--tm); font-size:13px; margin-bottom:28px; transition:.15s; }
.product-back:hover { color:var(--cy); }

/* ── PORTFOLIO (soluciones) ── */
.portfolio-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.portfolio-item {
  border-radius:10px; overflow:hidden;
  border:1px solid var(--bd); position:relative; cursor:pointer;
  transition:border-color .2s, transform .2s;
}
.portfolio-item:hover { border-color:var(--bds); transform:translateY(-2px); }
.portfolio-item img { width:100%; height:200px; object-fit:cover; display:block; }

/* PrettyPhoto overlay restyle */
div.pp_overlay { background:#070c18 !important; }
div.pp_pic_holder { border:1px solid var(--bd) !important; border-radius:10px; }
.pp_close { color:var(--cy) !important; }

/* ── MISC UTILITIES ── */
.text-cyan { color:var(--cy); }
.text-muted { color:var(--tm); }
.mt-8 { margin-top:8px; } .mt-16 { margin-top:16px; } .mt-24 { margin-top:24px; } .mt-32 { margin-top:32px; }
.mb-8 { margin-bottom:8px; } .mb-16 { margin-bottom:16px; } .mb-24 { margin-bottom:24px; }
