/* ════════════════════════════════════════════════════════════════
   JQTECH — Sistema de temas: Clásico (light) + Oscuro (dark)
   Default = Clásico (igual al PHP original)
   body.dark = Modo oscuro moderno
════════════════════════════════════════════════════════════════ */

/* ─── TEMA CLÁSICO (default, igual al PHP) ───────────────────── */
:root {
  --bg:           #ffffff;
  --bg2:          #f4f6f9;
  --bg3:          #eaecf0;
  --bg-alt:       #f8f9fa;
  --nav-bg:       rgba(255,255,255,0.95);
  --nav-border:   rgba(0,0,0,0.08);
  --nav-shadow:   0 2px 20px rgba(0,0,0,0.08);
  --accent:       #7c5ce7;
  --accent2:      #6c4fd6;
  --cart-accent:  #e84c3d;
  --text:         #1a1a2e;
  --text2:        #4a5568;
  --text3:        #718096;
  --card:         #ffffff;
  --card-hover:   #fafafa;
  --border:       rgba(0,0,0,0.10);
  --border2:      rgba(124,92,231,0.35);
  --shadow:       0 4px 24px rgba(0,0,0,0.08);
  --shadow-lg:    0 12px 48px rgba(0,0,0,0.12);
  --shadow-red:   0 12px 40px rgba(124,92,231,0.28);
  --radius:       16px;
  --radius-sm:    10px;
  --font:         'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --transition:   0.28s cubic-bezier(0.4,0,0.2,1);
  --hero-overlay: linear-gradient(135deg,rgba(0,0,0,0.40) 0%,rgba(10,10,26,0.30) 60%,rgba(0,0,0,0.50) 100%);
  --feat-card-bg: #ffffff;
  --feat-overlay: linear-gradient(to top,rgba(0,0,0,0.90) 0%,rgba(0,0,0,0.45) 55%,rgba(0,0,0,0.05) 100%);
  --service-bg:   #f8f9fc;
  --service-border: rgba(0,0,0,0.08);
  --footer-bg:    #1a1a2e;
  --footer-text:  rgba(255,255,255,0.6);
  --stats-bg:     #f4f6f9;
  --stats-text:   #1a1a2e;
  --cta-bg:       linear-gradient(135deg,#1a1a2e 0%,#2d2d5e 100%);
  --pill-bg:      rgba(124,92,231,0.08);
  --pill-border:  rgba(124,92,231,0.2);
}

/* ─── TEMA OSCURO ─────────────────────────────────────────────── */
body.dark {
  --bg:           #0a0a0a;
  --bg2:          #111122;
  --bg3:          #16162a;
  --bg-alt:       #0d0d1a;
  --nav-bg:       rgba(10,10,10,0.85);
  --nav-border:   rgba(255,255,255,0.07);
  --nav-shadow:   none;
  --text:         #ffffff;
  --text2:        #a0aab4;
  --text3:        #606878;
  --card:         rgba(255,255,255,0.04);
  --card-hover:   rgba(255,255,255,0.07);
  --border:       rgba(255,255,255,0.08);
  --shadow:       0 8px 32px rgba(0,0,0,0.5);
  --shadow-lg:    0 20px 60px rgba(0,0,0,0.6);
  --feat-card-bg: rgba(10,10,28,0.85);
  --feat-overlay: linear-gradient(to top,rgba(0,0,0,0.97) 0%,rgba(0,0,0,0.55) 55%,rgba(0,0,0,0.08) 100%);
  --service-bg:   rgba(255,255,255,0.04);
  --service-border: rgba(255,255,255,0.08);
  --footer-bg:    #0d0d1a;
  --footer-text:  rgba(255,255,255,0.45);
  --stats-bg:     #0d0d1a;
  --stats-text:   #ffffff;
  --cta-bg:       linear-gradient(135deg,#0d0d20 0%,#1a1a2e 100%);
  --pill-bg:      rgba(124,92,231,0.12);
  --pill-border:  rgba(124,92,231,0.25);
}

/* ─── Reset & Base ───────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
  overflow-x: hidden;
  transition: background var(--transition), color var(--transition);
}
a { text-decoration:none; color:inherit; }
img { max-width:100%; display:block; }

/* ─── Scrollbar ──────────────────────────────────────────────── */
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:var(--bg2); }
::-webkit-scrollbar-thumb { background:var(--accent); border-radius:3px; }

/* ════════════════════════════════════════════════════════════════
   NAVBAR
════════════════════════════════════════════════════════════════ */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 40px; height:68px;
  background: var(--nav-bg);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--nav-border);
  box-shadow: var(--nav-shadow);
  transition: background var(--transition), box-shadow var(--transition), border-color var(--transition);
}
body.dark .navbar.scrolled {
  background: rgba(10,10,10,0.97);
  box-shadow: 0 4px 30px rgba(0,0,0,0.5);
}
body:not(.dark) .navbar.scrolled {
  box-shadow: 0 4px 24px rgba(0,0,0,0.12);
}

/* Logo */
.nav-brand {
  font-size:22px; font-weight:900; letter-spacing:-0.5px;
  display:flex; align-items:center; gap:2px;
}
.nav-brand span { color:var(--accent); }
.nav-brand .dot {
  width:7px; height:7px; border-radius:50%;
  background:var(--accent); margin-left:4px;
  animation:pulse 2s infinite;
}

/* Links */
.nav-links { display:flex; align-items:center; gap:4px; list-style:none; }
.nav-links a {
  padding:8px 14px; border-radius:var(--radius-sm);
  font-size:14px; font-weight:500; color:var(--text2);
  transition:var(--transition);
}
.nav-links a:hover { color:var(--text); background:rgba(0,0,0,0.05); }
body.dark .nav-links a:hover { background:rgba(255,255,255,0.07); }
.nav-links a.active { color:var(--accent); font-weight:700; }

/* Acciones */
.nav-actions { display:flex; align-items:center; gap:10px; }

/* Botón tema */
.btn-theme {
  width:38px; height:38px; border-radius:50%;
  background:var(--bg2); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  color:var(--text2); font-size:18px;
  cursor:pointer; transition:var(--transition);
}
.btn-theme:hover { color:var(--accent); border-color:var(--border2); }
.icon-sun  { display:none; }
.icon-moon { display:block; }
body.dark .icon-sun  { display:block; }
body.dark .icon-moon { display:none; }

/* Carrito */
.btn-cart {
  position:relative; width:38px; height:38px; border-radius:50%;
  background:var(--bg2); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  color:var(--text2); font-size:18px; cursor:pointer; transition:var(--transition);
}
.btn-cart:hover { color:var(--cart-accent); border-color:rgba(232,76,61,0.35); }
.cart-badge {
  position:absolute; top:-4px; right:-4px;
  width:18px; height:18px; border-radius:50%;
  background:var(--accent); color:#fff;
  font-size:10px; font-weight:800;
  display:none; align-items:center; justify-content:center;
}

/* Login btn */
.btn-nav-login {
  padding:8px 20px; border-radius:30px;
  background:var(--accent); border:none;
  color:#fff; font-size:13px; font-weight:700;
  cursor:pointer; transition:var(--transition);
  display:flex; align-items:center; gap:6px;
}
.btn-nav-login:hover { background:var(--accent2); transform:translateY(-1px); }

/* User dropdown */
.nav-user {
  display:flex; align-items:center; gap:8px;
  padding:6px 14px; border-radius:30px;
  background:var(--bg2); border:1px solid var(--border);
  font-size:13px; font-weight:600; cursor:pointer; position:relative;
}
.nav-user-avatar {
  width:28px; height:28px; border-radius:50%;
  background:var(--accent); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:800;
}
.nav-dropdown {
  position:absolute; top:calc(100% + 10px); right:0;
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius-sm); min-width:180px;
  box-shadow:var(--shadow-lg); overflow:hidden;
  opacity:0; pointer-events:none; transform:translateY(-8px);
  transition:var(--transition);
}
.nav-user:hover .nav-dropdown { opacity:1; pointer-events:all; transform:translateY(0); }
.nav-dropdown a {
  display:flex; align-items:center; gap:10px;
  padding:12px 16px; font-size:13px; color:var(--text2); transition:var(--transition);
}
.nav-dropdown a:hover { background:var(--bg2); color:var(--text); }
.nav-dropdown .divider { height:1px; background:var(--border); }
.nav-dropdown a.danger { color:#e84c3d; }

/* Hamburger */
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:5px; }
.hamburger span { width:22px; height:2px; background:var(--text); border-radius:2px; transition:var(--transition); }

/* ════════════════════════════════════════════════════════════════
   HERO
════════════════════════════════════════════════════════════════ */
.hero {
  position:relative; height:100vh;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden; background:#000;
}
.hero-video {
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; opacity:1; z-index:1;
}
.hero-gradient {
  display:none;
}
.hero-bottom {
  display:none;
  position:absolute; bottom:0; left:0; right:0; height:180px; z-index:3;
  background:linear-gradient(to bottom, transparent, var(--bg));
  transition: background var(--transition);
}
.hero-content {
  position:relative; z-index:4; text-align:center;
  max-width:800px; padding:0 20px;
  animation:fadeUp 1s ease forwards;
}
.hero-tag {
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 18px; border-radius:30px;
  border:1px solid rgba(232,76,61,0.4); background:rgba(232,76,61,0.12);
  font-size:11px; font-weight:800; letter-spacing:2px; text-transform:uppercase;
  color:var(--accent); margin-bottom:24px;
}
.hero-tag .dot { width:6px; height:6px; border-radius:50%; background:var(--accent); animation:pulse 2s infinite; }
.hero h1 {
  font-size:clamp(36px,6vw,72px); font-weight:900;
  line-height:1.08; letter-spacing:-2px; margin-bottom:20px; color:#fff;
}
.hero h1 .highlight { color:var(--accent); }
.hero p { font-size:clamp(15px,2vw,19px); color:rgba(255,255,255,0.75); max-width:580px; margin:0 auto 36px; }
.hero-btns { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.btn-primary {
  padding:13px 30px; border-radius:30px;
  background:var(--accent); color:#fff;
  font-size:14px; font-weight:700; letter-spacing:0.3px;
  border:none; cursor:pointer; transition:var(--transition);
  display:inline-flex; align-items:center; gap:8px;
}
.btn-primary:hover { background:var(--accent2); transform:translateY(-2px); box-shadow:var(--shadow-red); }
.btn-outline {
  padding:13px 30px; border-radius:30px;
  background:rgba(255,255,255,0.1); color:#fff;
  font-size:14px; font-weight:600;
  border:1px solid rgba(255,255,255,0.3); cursor:pointer; transition:var(--transition);
  display:inline-flex; align-items:center; gap:8px;
}
.btn-outline:hover { background:rgba(255,255,255,0.18); transform:translateY(-2px); }

.hero-scroll {
  position:absolute; bottom:28px; left:50%; transform:translateX(-50%); z-index:4;
  display:flex; flex-direction:column; align-items:center; gap:8px;
  color:rgba(255,255,255,0.4); font-size:10px; letter-spacing:2px; text-transform:uppercase;
}
.hero-scroll-line {
  width:1px; height:36px;
  background:linear-gradient(to bottom, var(--accent), transparent);
  animation:scrollLine 2s ease infinite;
}

/* ════════════════════════════════════════════════════════════════
   COMMONS
════════════════════════════════════════════════════════════════ */
section { padding:100px 0; }
.container { max-width:1200px; margin:0 auto; padding:0 24px; }
.section-label {
  display:inline-block; font-size:11px; font-weight:800;
  letter-spacing:4px; text-transform:uppercase; color:var(--accent); margin-bottom:12px;
}
.section-title {
  font-size:clamp(28px,4vw,46px); font-weight:900;
  letter-spacing:-1px; line-height:1.1; margin-bottom:16px; color:var(--text);
  transition:color var(--transition);
}
.section-subtitle { font-size:16px; color:var(--text2); max-width:500px; transition:color var(--transition); }

/* ════════════════════════════════════════════════════════════════
   FEATURED PRODUCTS
════════════════════════════════════════════════════════════════ */
.feat-section { background:var(--bg-alt); padding:100px 0; transition:background var(--transition); }
.feat-header { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:48px; flex-wrap:wrap; gap:16px; }
.feat-view-all {
  display:inline-flex; align-items:center; gap:6px;
  padding:10px 22px; border-radius:30px;
  border:1px solid var(--border); color:var(--text2);
  font-size:13px; font-weight:600; transition:var(--transition);
}
.feat-view-all:hover { border-color:var(--border2); color:var(--accent); }

.feat-grid {
  display:grid;
  grid-template-columns:1.4fr 1fr;
  grid-template-rows:1fr 1fr;
  gap:16px; height:560px;
}
.feat-card {
  position:relative; border-radius:var(--radius); overflow:hidden;
  cursor:pointer; display:flex; flex-direction:column; justify-content:flex-end;
  border:1px solid var(--border);
  transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);
  text-decoration:none; background:var(--feat-card-bg);
}
.feat-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-red); border-color:var(--border2); }
.feat-card-main { grid-row:1/3; }
.feat-img-bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  transition:transform 0.6s cubic-bezier(0.4,0,0.2,1);
}
.feat-card:hover .feat-img-bg { transform:scale(1.06); }
.feat-overlay {
  position:absolute; inset:0;
  background:var(--feat-overlay);
  transition:var(--transition);
}
.feat-card:hover .feat-overlay { filter:brightness(1.05); }
.feat-badge {
  position:absolute; top:16px; left:16px; z-index:2;
  padding:5px 12px; border-radius:20px;
  font-size:10px; font-weight:800; letter-spacing:1px; text-transform:uppercase;
}
.badge-hot   { background:var(--accent); color:#fff; }
.badge-new   { background:#00c97a; color:#fff; }
.badge-trend { background:#f5a623; color:#fff; }
.feat-body { position:relative; z-index:2; padding:20px 24px 24px; }
.feat-cat { font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--accent); margin-bottom:6px; }
.feat-name { font-size:18px; font-weight:800; color:#fff; margin-bottom:4px; line-height:1.2; }
.feat-card-main .feat-name { font-size:26px; }
.feat-desc { font-size:13px; color:rgba(255,255,255,0.7); margin-bottom:16px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.feat-card-main .feat-desc { font-size:14px; }
.feat-footer-row { display:flex; align-items:center; justify-content:space-between; padding-top:14px; border-top:1px solid rgba(255,255,255,0.12); }
.feat-price { font-size:20px; font-weight:900; color:var(--accent); }
.feat-card-main .feat-price { font-size:28px; }
.feat-btn {
  display:flex; align-items:center; gap:6px;
  padding:9px 18px; border-radius:30px;
  background:rgba(255,255,255,0.12); border:1px solid rgba(255,255,255,0.2);
  color:#fff; font-size:12px; font-weight:700;
  cursor:pointer; transition:var(--transition);
}
.feat-btn:hover,.feat-card:hover .feat-btn { background:var(--accent); border-color:var(--accent); }
.feat-card-main .feat-btn { padding:11px 24px; font-size:13px; }
.feat-skeleton {
  background:linear-gradient(90deg,var(--bg2) 25%,var(--bg3) 50%,var(--bg2) 75%);
  background-size:200% 100%; animation:skeleton 1.5s infinite;
  border-radius:var(--radius);
}

/* ════════════════════════════════════════════════════════════════
   ABOUT (blanca en ambos temas)
════════════════════════════════════════════════════════════════ */
.about-section { background:var(--bg); padding:100px 0; transition:background var(--transition); }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.about-text p { color:var(--text2); font-size:15px; line-height:1.8; margin-bottom:16px; }

/* Sección parallax full-width (reemplaza el about-grid cuando se usa) */
.about-section.full-parallax {
  background-attachment:fixed;
  background-size:cover;
  background-position:center;
  position:relative;
  border:none;
}
.about-section.full-parallax::before {
  content:''; position:absolute; inset:0;
  background:rgba(10,10,30,0.72); z-index:0;
}
.about-section.full-parallax .container { position:relative; z-index:1; }
.about-section.full-parallax .about-text { max-width:680px; }
.about-section.full-parallax .about-text p { color:rgba(255,255,255,0.75); }
.about-section.full-parallax .about-text .section-title { color:#fff; }
.about-section.full-parallax .about-text strong { color:#fff; }
.about-section.full-parallax .pill { background:rgba(255,255,255,0.1); border-color:rgba(255,255,255,0.2); color:#fff; }

/* Feature section full-parallax */
.feature-section.full-parallax {
  background-attachment:fixed;
  background-size:cover;
  background-position:center;
  position:relative;
}
.feature-section.full-parallax::before {
  content:''; position:absolute; inset:0;
  background:transparent; z-index:0;
}
.feature-section.full-parallax .container { position:relative; z-index:1; }
.feature-section.full-parallax .feature-text { max-width:580px; }
.feature-section.full-parallax .feature-text p { color:#1a1a2e; }
.feature-section.full-parallax .feature-text .section-title { color:#0a0a1e; }
.feature-section.full-parallax .feature-list li { color:#1a1a2e; }
.about-img {
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  height:380px;
  background-image:url('../images/team-office.jpg');
  background-attachment:fixed;
  background-size:cover;
  background-position:center;
  transition:box-shadow var(--transition);
}
.about-img:hover { box-shadow:var(--shadow-red); }
.about-pills { display:flex; flex-wrap:wrap; gap:10px; margin-top:28px; }
.pill {
  padding:7px 16px; border-radius:30px;
  background:var(--pill-bg); border:1px solid var(--pill-border);
  color:var(--accent); font-size:13px; font-weight:600; transition:var(--transition);
}

/* ════════════════════════════════════════════════════════════════
   FEATURE (tilt card)
════════════════════════════════════════════════════════════════ */
.feature-section { background:var(--bg2); padding:100px 0; transition:background var(--transition); }
.feature-inner { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.feature-img-wrap {
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-lg);
  height:420px;
  position:relative;
}
.feature-img {
  position:absolute; inset:-60px 0;
  will-change:transform;
  transition:box-shadow 0.3s ease;
}
.feature-img-wrap:hover { box-shadow:var(--shadow-red); }
.feature-img img { width:100%; height:100%; object-fit:cover; display:block; }
.feature-img-fixed {
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  align-self:stretch;
  min-height:420px;
  background-image:url('../images/featue-bg.jpg');
  background-attachment:fixed;
  background-size:cover;
  background-position:center;
  transition:box-shadow var(--transition);
}
.feature-img-fixed:hover { box-shadow:var(--shadow-red); }
.feature-text p { color:var(--text2); font-size:15px; line-height:1.8; margin-bottom:16px; }
.feature-list { list-style:none; display:flex; flex-direction:column; gap:12px; margin-top:24px; }
.feature-list li { display:flex; align-items:center; gap:12px; color:var(--text2); font-size:14px; font-weight:500; }
.feature-list li ion-icon { color:var(--accent); font-size:20px; flex-shrink:0; }

/* ════════════════════════════════════════════════════════════════
   STATS
════════════════════════════════════════════════════════════════ */
.stats-section { background:var(--stats-bg); padding:60px 0; transition:background var(--transition); }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--border); }
.stat-item { background:var(--stats-bg); padding:40px; text-align:center; transition:background var(--transition); }
.stat-num { font-size:48px; font-weight:900; color:var(--accent); letter-spacing:-2px; line-height:1; }
.stat-label { font-size:13px; color:var(--stats-text); opacity:0.6; margin-top:8px; font-weight:500; }

/* ════════════════════════════════════════════════════════════════
   SERVICIOS
════════════════════════════════════════════════════════════════ */
.services-section { background:var(--bg); padding:100px 0; transition:background var(--transition); }
.services-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:60px; }
.service-card {
  background:var(--service-bg); border:1px solid var(--service-border);
  border-radius:var(--radius); padding:32px 24px;
  transition:var(--transition); cursor:default;
}
.service-card:hover { border-color:var(--border2); transform:translateY(-4px); box-shadow:var(--shadow); }
.service-icon {
  width:52px; height:52px; border-radius:14px;
  background:rgba(232,76,61,0.1); border:1px solid rgba(232,76,61,0.18);
  display:flex; align-items:center; justify-content:center;
  font-size:22px; color:var(--accent); margin-bottom:20px;
}
.service-card h4 { font-size:16px; font-weight:700; margin-bottom:10px; color:var(--text); transition:color var(--transition); }
.service-card p  { font-size:13px; color:var(--text2); line-height:1.6; }

/* ════════════════════════════════════════════════════════════════
   CTA
════════════════════════════════════════════════════════════════ */
.cta-section {
  background:var(--cta-bg); padding:100px 0;
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
}
.cta-bg {
  background-image:url('../images/call-to-action-bg.jpg') !important;
  background-attachment:fixed;
  background-size:cover;
  background-position:center;
  position:relative;
  border:none;
}
.cta-bg::before {
  content:''; position:absolute; inset:0;
  background:rgba(10,10,30,0.80); z-index:0;
}
.cta-bg .container { position:relative; z-index:1; }
.cta-inner { text-align:center; max-width:600px; margin:0 auto; }
.cta-inner h2 { font-size:clamp(28px,4vw,44px); font-weight:900; letter-spacing:-1px; margin-bottom:16px; color:#fff; }
.cta-inner p { color:rgba(255,255,255,0.65); margin-bottom:32px; font-size:16px; }

/* ════════════════════════════════════════════════════════════════
   PAGE HERO (páginas internas)
════════════════════════════════════════════════════════════════ */
.page-hero {
  padding: 140px 0 80px;
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
  transition: background var(--transition);
}
.page-hero-inner { max-width: 640px; }
.page-hero h1 { font-size: clamp(32px,5vw,52px); font-weight:900; color:var(--text); letter-spacing:-1.5px; margin-bottom:14px; }
.page-hero p  { font-size:17px; color:var(--text2); line-height:1.7; }
.breadcrumb-nav { display:flex; align-items:center; gap:6px; font-size:13px; color:var(--text3); margin-bottom:20px; }
.breadcrumb-nav a { color:var(--text2); } .breadcrumb-nav a:hover { color:var(--accent); }

/* Why cards */
.why-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:48px; }
.why-card {
  background:var(--card); border:1px solid var(--border); border-radius:var(--radius);
  padding:28px 24px; transition:var(--transition);
}
.why-card:hover { border-color:var(--border2); transform:translateY(-4px); box-shadow:var(--shadow); }
.why-card ion-icon { font-size:32px; color:var(--accent); margin-bottom:14px; display:block; }
.why-card h4 { font-size:16px; font-weight:700; color:var(--text); margin-bottom:8px; }
.why-card p  { font-size:14px; color:var(--text2); line-height:1.7; }

/* Counters row */
.counters-row { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--border); border-radius:var(--radius); overflow:hidden; margin:60px 0; }
.counter-item { background:var(--bg2); padding:36px 24px; text-align:center; transition:background var(--transition); }
.counter-num { font-size:42px; font-weight:900; color:var(--accent); letter-spacing:-2px; line-height:1; }
.counter-label { font-size:13px; color:var(--text2); margin-top:6px; font-weight:500; }

/* Tabs visión/misión */
.tabs-vmf { display:flex; flex-direction:column; gap:0; border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.tab-btns { display:flex; background:var(--bg2); border-bottom:1px solid var(--border); }
.tab-btn {
  flex:1; padding:14px; font-size:14px; font-weight:600; font-family:var(--font);
  border:none; background:none; cursor:pointer; color:var(--text2); transition:var(--transition);
}
.tab-btn.active { background:var(--card); color:var(--accent); box-shadow:inset 0 -2px 0 var(--accent); }
.tab-pane { display:none; padding:28px; background:var(--card); font-size:15px; color:var(--text2); line-height:1.8; }
.tab-pane.active { display:block; }

/* Proyectos grid */
.portfolio-filters { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:32px; }
.filter-btn {
  padding:8px 18px; border-radius:20px; font-size:13px; font-weight:600;
  border:1px solid var(--border); background:var(--card); color:var(--text2);
  cursor:pointer; font-family:var(--font); transition:var(--transition);
}
.filter-btn:hover, .filter-btn.active { background:var(--accent); color:#fff; border-color:var(--accent); }
.portfolio-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.portfolio-card {
  background:var(--card); border:1px solid var(--border); border-radius:var(--radius);
  overflow:hidden; transition:var(--transition); cursor:pointer;
}
.portfolio-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); border-color:var(--border2); }
.portfolio-img { height:200px; background:var(--bg3); overflow:hidden; position:relative; }
.portfolio-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.4s ease; }
.portfolio-card:hover .portfolio-img img { transform:scale(1.05); }
.portfolio-tag {
  position:absolute; top:12px; left:12px;
  padding:4px 10px; border-radius:20px; font-size:11px; font-weight:700;
  background:var(--accent); color:#fff;
}
.portfolio-body { padding:20px; }
.portfolio-body h4 { font-size:16px; font-weight:700; color:var(--text); margin-bottom:6px; }
.portfolio-body p  { font-size:13px; color:var(--text2); line-height:1.6; }

/* Contacto */
.contact-grid { display:grid; grid-template-columns:1fr 380px; gap:40px; align-items:start; }
.contact-info { display:flex; flex-direction:column; gap:16px; }
.contact-info-item {
  display:flex; align-items:center; gap:14px;
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius-sm); padding:18px 20px;
}
.contact-info-item ion-icon { font-size:22px; color:var(--accent); flex-shrink:0; }
.contact-info-item .ci-label { font-size:12px; color:var(--text3); font-weight:600; margin-bottom:2px; }
.contact-info-item .ci-val   { font-size:14px; color:var(--text); font-weight:600; }
.contact-social { display:flex; gap:10px; margin-top:8px; }
.contact-social a {
  width:42px; height:42px; border-radius:50%; border:1px solid var(--border);
  background:var(--card); display:flex; align-items:center; justify-content:center;
  font-size:18px; color:var(--text2); transition:var(--transition);
}
.contact-social a:hover { background:var(--accent); color:#fff; border-color:var(--accent); }

@media(max-width:900px) {
  .why-grid         { grid-template-columns:1fr 1fr; }
  .counters-row     { grid-template-columns:1fr 1fr; }
  .portfolio-grid   { grid-template-columns:1fr 1fr; }
  .contact-grid     { grid-template-columns:1fr; }
}
@media(max-width:600px) {
  .why-grid         { grid-template-columns:1fr; }
  .portfolio-grid   { grid-template-columns:1fr; }
}

/* ════════════════════════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════════════════════════ */
.footer { background:var(--footer-bg); border-top:1px solid rgba(255,255,255,0.06); padding:60px 0 30px; transition:background var(--transition); }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr; gap:60px; margin-bottom:48px; }
.footer-brand { font-size:22px; font-weight:900; color:#fff; margin-bottom:12px; }
.footer-brand span { color:var(--accent); }
.footer-desc { color:rgba(255,255,255,0.5); font-size:14px; line-height:1.7; }
.footer-col h5 { font-size:11px; font-weight:800; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,0.3); margin-bottom:20px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:12px; }
.footer-col a { font-size:14px; color:rgba(255,255,255,0.5); transition:var(--transition); }
.footer-col a:hover { color:#fff; }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.07); padding-top:24px; display:flex; align-items:center; justify-content:space-between; }
.footer-copy { font-size:13px; color:rgba(255,255,255,0.3); }
.footer-social { display:flex; gap:12px; }
.social-btn {
  width:36px; height:36px; border-radius:50%;
  background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.1);
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,0.5); font-size:16px; transition:var(--transition);
}
.social-btn:hover { background:var(--accent); border-color:var(--accent); color:#fff; }

/* ════════════════════════════════════════════════════════════════
   TOAST
════════════════════════════════════════════════════════════════ */
.toast-container { position:fixed; bottom:24px; right:24px; z-index:9999; display:flex; flex-direction:column; gap:10px; }
.toast {
  display:flex; align-items:center; gap:12px;
  padding:14px 20px; border-radius:var(--radius-sm);
  background:#fff; border:1px solid rgba(0,0,0,0.1);
  box-shadow:0 8px 32px rgba(0,0,0,0.15); font-size:14px; color:#1a1a2e;
  animation:slideIn 0.3s ease; min-width:260px;
}
body.dark .toast { background:var(--bg2); border-color:var(--border); color:var(--text); box-shadow:0 8px 32px rgba(0,0,0,0.5); }
.toast.success { border-left:3px solid #00c97a; }
.toast.error   { border-left:3px solid var(--accent); }
.toast-icon { font-size:18px; }
.toast.success .toast-icon { color:#00c97a; }
.toast.error   .toast-icon { color:var(--accent); }

/* ════════════════════════════════════════════════════════════════
   ANIMATIONS
════════════════════════════════════════════════════════════════ */
@keyframes fadeUp    { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }
@keyframes pulse     { 0%,100%{opacity:1} 50%{opacity:0.4} }
@keyframes scrollLine{ 0%,100%{opacity:0;transform:scaleY(0);transform-origin:top} 50%{opacity:1;transform:scaleY(1)} }
@keyframes skeleton  { 0%{background-position:200%} 100%{background-position:-200%} }
@keyframes slideIn   { from{opacity:0;transform:translateX(20px)} to{opacity:1;transform:translateX(0)} }

/* ════════════════════════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════════════════════════ */
@media (max-width:1024px) {
  .services-grid { grid-template-columns:repeat(2,1fr); }
  .stats-grid    { grid-template-columns:repeat(2,1fr); }
  .footer-grid   { grid-template-columns:1fr 1fr; gap:40px; }
  .about-grid    { grid-template-columns:1fr; gap:40px; }
  .feature-inner { grid-template-columns:1fr; gap:40px; }
  .feat-grid     { height:480px; }
}

/* Tablet */
@media (max-width:768px) {
  section { padding:70px 0; }
  .container { padding:0 16px; }
  .navbar { padding:0 16px; height:60px; }
  .nav-links {
    display:none; flex-direction:column;
    position:absolute; top:60px; left:0; right:0;
    background:var(--nav-bg); padding:16px;
    border-bottom:1px solid var(--border); gap:4px;
    backdrop-filter:blur(20px);
  }
  .nav-links.open { display:flex; }
  .nav-links a { padding:12px 16px; }
  .hamburger { display:flex; }
  .hero h1 { letter-spacing:-1px; }
  .hero-btns { flex-direction:column; align-items:center; }
  .btn-primary,.btn-outline { width:100%; max-width:280px; justify-content:center; }
  .feat-grid { grid-template-columns:1fr; grid-template-rows:320px 240px 240px; height:auto; }
  .feat-card-main { grid-row:auto; }
  .feat-header { flex-direction:column; align-items:flex-start; }
  .services-grid { grid-template-columns:1fr 1fr; }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .stat-num { font-size:36px; }
  .stat-item { padding:28px 16px; }
  .about-grid { grid-template-columns:1fr; gap:32px; }
  .about-img { height:260px; background-attachment:scroll; }
  .feature-inner { grid-template-columns:1fr; gap:32px; }
  .feature-img img { height:260px; }
  .footer-grid { grid-template-columns:1fr; gap:32px; }
  .footer-bottom { flex-direction:column; gap:16px; text-align:center; }
}

/* Mobile */
@media (max-width:480px) {
  .hero h1 { font-size:30px; letter-spacing:-0.5px; }
  .hero p  { font-size:14px; }
  .feat-grid { grid-template-rows:260px 200px 200px; gap:12px; }
  .feat-name { font-size:15px; }
  .feat-card-main .feat-name { font-size:19px; }
  .feat-price { font-size:16px; }
  .feat-card-main .feat-price { font-size:22px; }
  .services-grid { grid-template-columns:1fr; }
  .section-title { font-size:26px; }
  .nav-brand { font-size:19px; }
  .about-pills { gap:8px; }
  .pill { font-size:12px; padding:6px 14px; }
  .stats-grid { grid-template-columns:1fr 1fr; }
}

/* ════════════════════════════════════════════════════════════════
   TESTIMONIOS + STATS (igual al PHP)
════════════════════════════════════════════════════════════════ */
.testimonial-section {
  background: var(--stats-bg); padding: 100px 0;
  transition: background var(--transition);
}
.testimonial-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center;
}

/* Contadores */
.stats-col { display: flex; flex-direction: row; flex-wrap: wrap; gap: 40px 60px; }
.stat-counter { display: flex; flex-direction: column; gap: 6px; align-items: flex-start; }
.stat-icon { font-size: 28px; color: var(--accent); margin-bottom: 4px; }
.stat-num {
  font-size: 40px; font-weight: 900; color: var(--text);
  letter-spacing: -1px; line-height: 1;
  transition: color var(--transition);
}
.stat-label { font-size: 13px; color: var(--accent); font-weight: 600; }

/* Tarjeta testimonio */
.testimonial-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius); padding: 40px;
}
body:not(.dark) .testimonial-card {
  background: rgba(0,0,0,0.03);
  border-color: rgba(0,0,0,0.08);
}
.quote-icon {
  font-size: 40px; color: var(--accent); margin-bottom: 20px; display: block;
}
.quote-text {
  font-size: 16px; line-height: 1.75; color: var(--stats-text);
  opacity: 0.8; font-style: italic; margin-bottom: 28px;
}
body:not(.dark) .quote-text { opacity: 0.7; }
.quote-author { display: flex; align-items: center; gap: 14px; }
.author-photo {
  width: 52px; height: 52px; border-radius: 50%;
  object-fit: cover; flex-shrink: 0;
  border: 2px solid var(--border);
}
.author-name { font-size: 14px; font-weight: 700; color: var(--stats-text); }
.author-role { font-size: 12px; color: var(--accent); font-weight: 600; }

@media (max-width: 768px) {
  .testimonial-grid { grid-template-columns: 1fr; gap: 48px; }
  .stat-num { font-size: 32px; }
  .testimonial-card { padding: 28px 24px; }
  .stats-col { gap: 24px 40px; }
}
@media (max-width: 480px) {
  .stat-num { font-size: 28px; }
  .stat-icon { font-size: 22px; }
  .stats-col { gap: 20px 32px; }
}
