/* ═══════════════════════════════════════════════════════
   VPtelemetric — styles.css v3.0 (AGENTS.md compliant)
   Dark/Light · Glassmorphism · AI-First Industrial
═══════════════════════════════════════════════════════ */

/* ── 0. Design Tokens ──────────────────────────────── */
:root {
  --gold:           #F5C518;
  --gold-dim:       #c9a010;
  --gold-glow:      rgba(245,197,24,0.35);
  --gold-subtle:    rgba(245,197,24,0.12);
  --blue:           #00AAFF;
  --blue-dim:       #0088cc;
  --blue-glow:      rgba(0,170,255,0.35);
  --blue-subtle:    rgba(0,170,255,0.10);
  --green:          #22c55e;
  --green-subtle:   rgba(34,197,94,0.12);
  --red:            #ef4444;
  --orange:         #f97316;

  --bg:             #080c14;
  --bg-2:           #0d1421;
  --bg-3:           #111926;
  --surface:        rgba(255,255,255,0.05);
  --surface-hover:  rgba(255,255,255,0.09);
  --glass-border:   rgba(255,255,255,0.08);
  --glass-b-gold:   rgba(245,197,24,0.3);
  --glass-b-blue:   rgba(0,170,255,0.3);

  --text-primary:   #f0f4ff;
  --text-secondary: #9aaac0;
  --text-dim:       #5c6a80;
  --heading:        #ffffff;

  --radius:         20px;
  --radius-sm:      12px;
  --radius-xs:      8px;
  --tr:             0.3s cubic-bezier(0.4,0,0.2,1);
  --shadow-card:    0 4px 32px rgba(0,0,0,0.45), 0 1px 4px rgba(0,0,0,0.3);
  --shadow-gold:    0 0 40px rgba(245,197,24,0.25), 0 8px 32px rgba(0,0,0,0.4);

  --header-h:       70px;
}

[data-theme="light"] {
  --bg:             #f0f4fa;
  --bg-2:           #e6ecf5;
  --bg-3:           #dde5f0;
  --surface:        rgba(255,255,255,0.75);
  --surface-hover:  rgba(255,255,255,0.95);
  --glass-border:   rgba(0,0,0,0.08);
  --text-primary:   #0d1421;
  --text-secondary: #3a4a62;
  --text-dim:       #7a8ba0;
  --heading:        #06080f;
}

/* ── 1. Reset ──────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body { font-family:'Space Grotesk','Inter',system-ui,sans-serif; background:var(--bg); color:var(--text-primary); line-height:1.6; overflow-x:hidden; transition:background-color var(--tr),color var(--tr); }
img,svg { display:block; }
a { text-decoration:none; color:inherit; }
ul { list-style:none; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }
input,select,textarea { font-family:inherit; }

/* ── 2. Typography ────────────────────────────────── */
h1,h2,h3,h4 { color:var(--heading); font-weight:700; letter-spacing:-0.02em; line-height:1.1; }
.highlight-gradient { background:linear-gradient(135deg,var(--gold) 0%,#FFE066 50%,var(--blue) 100%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }

/* ── 3. Utility ───────────────────────────────────── */
.section-container { max-width:1200px; margin:0 auto; padding:0 24px; }
.section-label-wrap { margin-bottom:8px; }
.section-eyebrow { display:inline-flex; align-items:center; gap:8px; font-size:0.72rem; font-weight:700; letter-spacing:0.15em; text-transform:uppercase; color:var(--gold); margin-bottom:12px; }
.section-eyebrow::before { content:''; display:block; width:20px; height:2px; background:var(--gold); border-radius:1px; }
.section-title { font-size:clamp(1.8rem,3.5vw,2.8rem); margin-bottom:16px; }
.section-subtitle { font-size:1rem; color:var(--text-secondary); font-weight:300; max-width:600px; margin-bottom:48px; line-height:1.7; }
.desktop-br { display:block; }
.link-btn { background:none; border:none; color:var(--blue); cursor:pointer; font-size:0.9rem; padding:0; }
.link-btn:hover { text-decoration:underline; }
@media(max-width:768px){ .desktop-br { display:none; } }

/* ── 4. Buttons ───────────────────────────────────── */
.btn { display:inline-flex; align-items:center; gap:8px; padding:13px 24px; border-radius:var(--radius); font-size:0.9rem; font-weight:600; letter-spacing:0.01em; transition:all var(--tr); cursor:pointer; white-space:nowrap; border:2px solid transparent; position:relative; overflow:hidden; text-decoration:none; }
.btn-primary { background:linear-gradient(135deg,var(--gold) 0%,#ffd740 100%); color:#0d1421; box-shadow:0 4px 20px var(--gold-glow); }
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 40px var(--gold-glow),0 0 60px rgba(245,197,24,0.3); }
.btn-secondary { background:transparent; color:var(--text-primary); border-color:var(--glass-border); backdrop-filter:blur(10px); }
.btn-secondary:hover { border-color:var(--blue); color:var(--blue); background:var(--blue-subtle); transform:translateY(-2px); }
.btn-full { width:100%; justify-content:center; }
.btn-icon { width:18px; height:18px; flex-shrink:0; }
.btn-icon svg { width:100%; height:100%; }
.btn-arrow { margin-left:auto; transition:transform var(--tr); }
.btn:hover .btn-arrow { transform:translateX(4px); }
.required-note { font-size:0.72rem; color:var(--text-dim); font-weight:400; }

/* ── 5. HEADER ────────────────────────────────────── */
.site-header { position:fixed; top:0; left:0; right:0; z-index:1000; background:rgba(8,12,20,0.8); backdrop-filter:blur(20px) saturate(180%); -webkit-backdrop-filter:blur(20px) saturate(180%); border-bottom:1px solid rgba(255,255,255,0.10); transition:all var(--tr); }
[data-theme="light"] .site-header { background:rgba(240,244,250,0.85); border-bottom-color:rgba(0,0,0,0.08); }
.site-header.scrolled { background:rgba(8,12,20,0.97); box-shadow:0 8px 32px rgba(0,0,0,0.4); }
[data-theme="light"] .site-header.scrolled { background:rgba(240,244,250,0.98); box-shadow:0 4px 24px rgba(0,0,0,0.1); }
.header-inner { max-width:1400px; margin:0 auto; padding:0 24px; height:var(--header-h); display:flex; align-items:center; gap:24px; }

/* Logo */
.logo-wrap { display:flex; align-items:center; gap:10px; flex-shrink:0; }
.logo-icon { width:42px; height:42px; flex-shrink:0; }
.logo-icon svg { width:100%; height:100%; }
.logo-text { display:flex; flex-direction:column; }
.logo-name { font-size:1.05rem; font-weight:700; color:var(--heading); letter-spacing:-0.01em; line-height:1.2; }
.logo-tagline { font-size:0.6rem; font-weight:300; letter-spacing:0.14em; text-transform:uppercase; color:var(--gold); opacity:0.8; }

/* Nav */
.main-nav { flex:1; display:flex; justify-content:center; }
.main-nav ul { display:flex; gap:2px; }
.nav-link { display:inline-flex; align-items:center; gap:6px; padding:7px 12px; border-radius:var(--radius-xs); font-size:0.83rem; font-weight:500; color:var(--text-secondary); transition:all var(--tr); position:relative; cursor:pointer; }
.nav-link::after { content:''; position:absolute; bottom:3px; left:12px; right:12px; height:1.5px; background:var(--gold); border-radius:1px; transform:scaleX(0); transition:transform var(--tr); }
.nav-link:hover,.nav-link.active { color:var(--text-primary); background:var(--surface); }
.nav-link.active::after,.nav-link:hover::after { transform:scaleX(1); }
.nav-access-btn { background:var(--gold-subtle); border:1px solid var(--glass-b-gold); color:var(--gold); font-weight:600; border-radius:var(--radius); padding:7px 14px; gap:8px; }
.nav-access-btn:hover { background:var(--gold); color:#0d1421; }
.access-pulse { width:7px; height:7px; border-radius:50%; background:var(--green); box-shadow:0 0 6px var(--green); animation:pulse-dot 2s ease-in-out infinite; flex-shrink:0; }

/* Controls */
.header-controls { display:flex; align-items:center; gap:14px; flex-shrink:0; }
.theme-toggle-wrap { display:flex; align-items:center; gap:7px; }
.toggle-label { font-size:0.85rem; color:var(--text-dim); user-select:none; }
.theme-toggle { position:relative; width:50px; height:26px; background:var(--blue-subtle); border:1px solid var(--glass-b-gold); border-radius:13px; cursor:pointer; transition:all var(--tr); }
[data-theme="dark"] .theme-toggle { background:rgba(0,170,255,0.25); }
[data-theme="light"] .theme-toggle { background:rgba(245,197,24,0.35); }
.toggle-thumb { position:absolute; top:3px; left:3px; width:18px; height:18px; background:white; border-radius:50%; transition:transform var(--tr); box-shadow:0 2px 6px rgba(0,0,0,0.3); }
[data-theme="dark"] .toggle-thumb { transform:translateX(24px); }
[data-theme="light"] .toggle-thumb { transform:translateX(0); }
.hamburger { display:none; flex-direction:column; gap:5px; padding:4px; }
.hamburger span { display:block; width:22px; height:2px; background:var(--text-primary); border-radius:1px; transition:all var(--tr); }
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }
.mobile-nav { display:none; padding:12px 24px 20px; border-top:1px solid var(--glass-border); }
.mobile-nav.open { display:block; }
.mobile-nav ul { display:flex; flex-direction:column; gap:4px; }
.mobile-nav .nav-link { padding:10px 12px; font-size:1rem; }
.mobile-nav .nav-link::after { display:none; }
.mobile-access-btn { width:100%; justify-content:center; margin-top:8px; }

/* ── 6. HERO ──────────────────────────────────────── */
.hero { position:relative; min-height:100vh; display:flex; flex-direction:column; align-items:center; justify-content:center; overflow:hidden; background:radial-gradient(ellipse 80% 60% at 50% 40%,rgba(0,70,140,0.4) 0%,rgba(0,30,80,0.2) 40%,transparent 70%),var(--bg); }
#network-canvas { position:absolute; inset:0; width:100%; height:100%; z-index:0; }
.hero-vignette { position:absolute; inset:0; z-index:1; background:radial-gradient(ellipse 70% 80% at 50% 50%,transparent 40%,rgba(8,12,20,0.6) 100%),linear-gradient(to top,var(--bg) 0%,transparent 30%),linear-gradient(to bottom,rgba(8,12,20,0.85) 0%,transparent 20%); pointer-events:none; }
[data-theme="light"] .hero-vignette { background:radial-gradient(ellipse 70% 80% at 50% 50%,transparent 40%,rgba(240,244,250,0.5) 100%),linear-gradient(to top,var(--bg) 0%,transparent 30%),linear-gradient(to bottom,rgba(240,244,250,0.7) 0%,transparent 20%); }
.hero-content { position:relative; z-index:2; text-align:center; padding:100px 24px 220px; max-width:900px; animation:fadeUp 1s ease both; }
.hero-badge { display:inline-flex; align-items:center; gap:8px; background:var(--surface); border:1px solid var(--glass-border); backdrop-filter:blur(10px); padding:6px 16px; border-radius:20px; font-size:0.72rem; font-weight:500; color:var(--text-secondary); margin-bottom:28px; letter-spacing:0.05em; }
.badge-dot { width:7px; height:7px; border-radius:50%; background:var(--green); box-shadow:0 0 8px var(--green); animation:pulse-dot 2s ease-in-out infinite; flex-shrink:0; }
.hero-headline { font-size:clamp(2.2rem,5vw,4rem); font-weight:700; line-height:1.1; letter-spacing:-0.03em; margin-bottom:24px; }
.hero-subheadline { font-size:clamp(1rem,1.8vw,1.15rem); color:var(--text-secondary); font-weight:300; line-height:1.7; margin-bottom:40px; max-width:640px; margin-left:auto; margin-right:auto; }
.hero-subheadline strong { color:var(--text-primary); font-weight:500; }
.hero-ctas { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* Metrics Bar */
.metrics-bar { position:absolute; bottom:0; left:0; right:0; z-index:3; background:rgba(8,12,20,0.75); backdrop-filter:blur(20px) saturate(180%); -webkit-backdrop-filter:blur(20px) saturate(180%); border-top:1px solid rgba(255,255,255,0.08); padding:20px 0; }
[data-theme="light"] .metrics-bar { background:rgba(230,236,245,0.85); border-top-color:rgba(0,0,0,0.08); }
.metrics-inner { max-width:1100px; margin:0 auto; padding:0 24px; display:flex; align-items:center; justify-content:space-around; gap:12px; }
.metric-item { display:flex; align-items:center; gap:12px; flex:1; justify-content:center; }
.metric-icon { width:38px; height:38px; background:var(--blue-subtle); border:1px solid rgba(0,170,255,0.2); border-radius:var(--radius-sm); display:flex; align-items:center; justify-content:center; color:var(--blue); flex-shrink:0; }
.metric-icon svg { width:18px; height:18px; }
.uptime-icon { background:var(--green-subtle); border-color:rgba(34,197,94,0.3); color:var(--green); }
.metric-data { display:flex; flex-direction:column; gap:1px; }
.metric-value { font-size:1.5rem; font-weight:700; color:var(--heading); letter-spacing:-0.02em; line-height:1; font-variant-numeric:tabular-nums; }
.metric-label { font-size:0.68rem; font-weight:400; color:var(--text-dim); letter-spacing:0.06em; text-transform:uppercase; }
.metric-divider { width:1px; height:36px; background:var(--glass-border); flex-shrink:0; }

/* ── 7. CASES SECTION ─────────────────────────────── */
.cases-section { padding:100px 0; background:var(--bg-2); }
.cases-layout { max-width:1400px; margin:0 auto; padding:0 24px; display:grid; grid-template-columns:1fr 320px; gap:40px; align-items:start; }
.cases-main { min-width:0; }

/* Unlock Notice */
.unlock-notice { display:flex; align-items:center; gap:16px; background:var(--gold-subtle); border:1px solid var(--glass-b-gold); border-radius:var(--radius); padding:16px 20px; margin-bottom:32px; flex-wrap:wrap; }
.unlock-notice.hidden { display:none; }
.unlock-icon-sm { font-size:1.4rem; flex-shrink:0; }
.unlock-notice strong { color:var(--gold); display:block; font-size:0.95rem; margin-bottom:2px; }
.unlock-notice p { font-size:0.82rem; color:var(--text-secondary); font-weight:300; margin:0; }
.unlock-notice .btn { flex-shrink:0; margin-left:auto; }

/* Cases Grid */
.cases-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }

.case-card { position:relative; background:var(--surface); border:1px solid var(--glass-border); border-radius:var(--radius); overflow:hidden; transition:all var(--tr); cursor:pointer; display:flex; flex-direction:column; }
.case-card:hover { border-color:var(--glass-b-gold); transform:translateY(-4px); box-shadow:var(--shadow-card); }
.case-card.unlocked { border-color:rgba(34,197,94,0.3); }
.case-card.unlocked .case-lock-overlay { display:none; }
.case-card.unlocked .case-btn-unlock { display:none; }

/* Case Image — now uses real generated photos */
.case-img { position:relative; width:100%; height:180px; overflow:hidden; }
.case-img img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center; transition:transform 0.5s ease; }
.case-card:hover .case-img img { transform:scale(1.06); }
.case-img-overlay { position:absolute; inset:0; background:linear-gradient(to bottom,transparent 30%,rgba(8,12,20,0.75)); z-index:1; }
.case-img-pattern { position:absolute; inset:0; }

.case-img--water .case-img-pattern {
  background: linear-gradient(135deg,#001a3a 0%,#003366 40%,#0066aa 70%,#00aaff 100%);
  background-image: radial-gradient(circle at 20% 80%,rgba(0,170,255,0.5) 0%,transparent 50%),
    radial-gradient(circle at 80% 20%,rgba(245,197,24,0.3) 0%,transparent 40%),
    repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(0,170,255,0.08) 10px,rgba(0,170,255,0.08) 11px);
}
.case-img--waste .case-img-pattern {
  background: linear-gradient(135deg,#0a1a00 0%,#1a3300 40%,#2d5500 70%,#4a7c00 100%);
  background-image: radial-gradient(circle at 30% 70%,rgba(74,124,0,0.6) 0%,transparent 50%),
    radial-gradient(circle at 70% 30%,rgba(245,197,24,0.3) 0%,transparent 40%);
}
.case-img--contaminated .case-img-pattern {
  background: linear-gradient(135deg,#1a0a00 0%,#3a1500 40%,#6b2800 70%,#a03c00 100%);
  background-image: radial-gradient(circle at 50% 50%,rgba(239,68,68,0.4) 0%,transparent 60%),
    radial-gradient(circle at 20% 80%,rgba(249,115,22,0.3) 0%,transparent 40%);
}
.case-img--osmosis .case-img-pattern {
  background: linear-gradient(135deg,#001533 0%,#002266 40%,#0033aa 70%,#0055cc 100%);
  background-image: radial-gradient(circle at 60% 40%,rgba(0,170,255,0.6) 0%,transparent 50%),
    radial-gradient(circle at 20% 70%,rgba(100,200,255,0.3) 0%,transparent 40%),
    repeating-linear-gradient(90deg,transparent,transparent 8px,rgba(0,170,255,0.05) 8px,rgba(0,170,255,0.05) 9px);
}
.case-img--fleet .case-img-pattern {
  background: linear-gradient(135deg,#0a0a1a 0%,#1a1a3a 40%,#2d2d6b 70%,#4040a0 100%);
  background-image: radial-gradient(circle at 40% 60%,rgba(100,100,255,0.5) 0%,transparent 50%),
    radial-gradient(circle at 75% 25%,rgba(245,197,24,0.3) 0%,transparent 35%);
}
.case-img--lab .case-img-pattern {
  background: linear-gradient(135deg,#0a001a 0%,#1a0033 40%,#350070 70%,#5500aa 100%);
  background-image: radial-gradient(circle at 50% 50%,rgba(150,0,255,0.5) 0%,transparent 60%),
    radial-gradient(circle at 30% 70%,rgba(245,197,24,0.3) 0%,transparent 40%),
    repeating-linear-gradient(45deg,transparent,transparent 12px,rgba(150,0,255,0.07) 12px,rgba(150,0,255,0.07) 13px);
}

/* Lock overlay */
.case-lock-overlay { position:absolute; inset:0; background:rgba(8,12,20,0.65); backdrop-filter:blur(4px); z-index:5; display:flex; align-items:center; justify-content:center; border-radius:var(--radius); pointer-events:none; }
.case-lock-overlay span { font-size:2rem; }
.case-card.unlocked .case-lock-overlay { display:none; }

.case-meta { display:flex; gap:6px; flex-wrap:wrap; padding:12px 14px 0; }
.case-sector,.case-eff { font-size:0.68rem; font-weight:600; letter-spacing:0.06em; padding:3px 8px; border-radius:5px; }
.case-sector { background:var(--blue-subtle); color:var(--blue); border:1px solid rgba(0,170,255,0.2); }
.case-eff { background:var(--green-subtle); color:var(--green); border:1px solid rgba(34,197,94,0.2); }
.case-title { font-size:0.95rem; font-weight:700; padding:10px 14px 6px; line-height:1.3; color:var(--heading); }
.case-brief { font-size:0.8rem; color:var(--text-secondary); padding:0 14px 12px; line-height:1.55; font-weight:300; }
.case-actions { display:flex; gap:8px; padding:0 14px 14px; flex-wrap:wrap; margin-top:auto; }
.case-actions .btn { font-size:0.78rem; padding:8px 14px; border-radius:12px; flex:1; justify-content:center; min-width:0; }
.case-btn-explore { white-space:nowrap; }

/* ── SIDEBAR Actividad en Vivo ────────────────────── */
.live-sidebar { background:var(--surface); border:1px solid var(--glass-border); border-radius:var(--radius); padding:20px; position:sticky; top:calc(var(--header-h) + 20px); max-height:calc(100vh - var(--header-h) - 40px); overflow-y:auto; }
.live-sidebar::-webkit-scrollbar { width:4px; }
.live-sidebar::-webkit-scrollbar-thumb { background:var(--glass-border); border-radius:2px; }

.sidebar-header { display:flex; align-items:center; gap:8px; margin-bottom:20px; border-bottom:1px solid var(--glass-border); padding-bottom:14px; }
.sidebar-header h3 { font-size:0.85rem; font-weight:700; color:var(--heading); flex:1; }
.live-dot { width:8px; height:8px; border-radius:50%; background:var(--green); box-shadow:0 0 8px var(--green); animation:pulse-dot 2s ease-in-out infinite; flex-shrink:0; }
.refresh-countdown { font-size:0.65rem; color:var(--text-dim); font-variant-numeric:tabular-nums; }

.sidebar-metric { margin-bottom:16px; }
.sm-label { font-size:0.68rem; font-weight:600; letter-spacing:0.08em; text-transform:uppercase; color:var(--text-dim); margin-bottom:4px; }
.sm-value { font-size:1.8rem; font-weight:700; color:var(--heading); line-height:1; font-variant-numeric:tabular-nums; }

.sidebar-status-row { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; margin-bottom:16px; }
.sidebar-status-item { display:flex; align-items:center; gap:6px; background:var(--surface); border:1px solid var(--glass-border); border-radius:var(--radius-xs); padding:8px; }
.status-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.status-active .status-dot { background:var(--green); box-shadow:0 0 6px var(--green); }
.status-waiting .status-dot { background:var(--gold); box-shadow:0 0 6px var(--gold); }
.status-offline .status-dot { background:var(--red); }
.ss-val { font-size:0.9rem; font-weight:700; color:var(--heading); line-height:1; }
.ss-label { font-size:0.62rem; color:var(--text-dim); text-transform:uppercase; letter-spacing:0.06em; }

.sidebar-section { margin-bottom:16px; }
.sb-section-title { font-size:0.68rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-dim); margin-bottom:10px; }

/* Industry bars */
.industry-list { display:flex; flex-direction:column; gap:8px; }
.industry-row { display:flex; align-items:center; gap:8px; font-size:0.75rem; color:var(--text-secondary); }
.industry-row span:first-child { width:56px; flex-shrink:0; }
.industry-bar-wrap { flex:1; height:4px; background:rgba(255,255,255,0.08); border-radius:2px; overflow:hidden; }
.industry-bar { height:100%; background:var(--gold); border-radius:2px; transition:width 1s ease; }
.industry-bar--blue { background:var(--blue); }
.industry-bar--green { background:var(--green); }
.industry-val { font-size:0.72rem; font-weight:600; color:var(--text-primary); width:32px; text-align:right; flex-shrink:0; }

/* Stats 2col */
.sidebar-2col { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-bottom:16px; }
.sidebar-stat { background:var(--surface); border:1px solid var(--glass-border); border-radius:var(--radius-xs); padding:10px; text-align:center; }
.sidebar-stat-icon { font-size:1.2rem; margin-bottom:4px; }
.sidebar-stat-val { font-size:1rem; font-weight:700; color:var(--heading); line-height:1; }
.sidebar-stat-label { font-size:0.62rem; color:var(--text-dim); text-transform:uppercase; letter-spacing:0.05em; margin-top:2px; }

/* Uptime Chart */
.uptime-target-label { font-size:0.72rem; color:var(--text-dim); margin-bottom:8px; }
.uptime-target-label strong { color:var(--gold); }
.uptime-chart { position:relative; display:flex; align-items:flex-end; gap:4px; height:72px; padding-top:8px; }
.uptime-bar-wrap { flex:1; display:flex; flex-direction:column; align-items:center; gap:2px; height:100%; justify-content:flex-end; }
.uptime-bar { width:100%; border-radius:3px 3px 0 0; transition:height 0.8s ease; position:relative; }
.uptime-bar.above-target { background:linear-gradient(to top,var(--green),rgba(34,197,94,0.6)); }
.uptime-bar.below-target { background:linear-gradient(to top,var(--red),rgba(239,68,68,0.6)); }
/* Line connecting bar tops */
.uptime-line-svg { position:absolute; top:0; left:0; width:100%; height:100%; pointer-events:none; overflow:visible; }
.uptime-line-path { fill:none; stroke:rgba(245,197,24,0.6); stroke-width:1.5; stroke-dasharray:3 2; }
.uptime-months { display:flex; gap:4px; margin-top:4px; }
.uptime-month-label { flex:1; text-align:center; font-size:0.58rem; color:var(--text-dim); }

/* ── 8. CLIENTS SECTION ───────────────────────────── */
.clients-section {
  padding: 28px 0;
  border-top: 1px solid var(--glass-border);
  border-bottom: 1px solid var(--glass-border);
  background: var(--bg);
  overflow: hidden;
}

.clients-label {
  text-align: center;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-dim);
  margin-bottom: 20px;
}

/* Marquee */
.marquee-wrapper {
  overflow: hidden;
  -webkit-mask-image: linear-gradient(to right, transparent, black 5%, black 95%, transparent);
  mask-image: linear-gradient(to right, transparent, black 5%, black 95%, transparent);
}

.marquee-track {
  display: flex;
  gap: 0;
  white-space: nowrap;
  animation: marquee 38s linear infinite;
  width: max-content;
}

.marquee-track:hover { animation-play-state: paused; }

/* Logos — colores originales, sin recorte */
.client-logo-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 180px;
  flex-shrink: 0;
  padding: 6px 12px;
  transition: opacity 0.2s;
  opacity: 0.9;
}

.client-logo-wrap:hover { opacity: 1; }

.client-logo-wrap img {
  width: 100%;
  height: auto;
  max-height: 48px;
  object-fit: contain;
  object-position: center;
  display: block;
}

@keyframes marquee { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }


/* ── 9. NEWS SECTION ──────────────────────────────── */
.news-section { padding:100px 0; background:var(--bg-3); }
.news-header-row { display:flex; align-items:flex-end; gap:20px; flex-wrap:wrap; margin-bottom:0; }
.news-header-row .section-title { margin-bottom:0; }
.news-update-badge { display:inline-flex; align-items:center; gap:6px; font-size:0.68rem; font-weight:500; color:var(--text-dim); background:var(--surface); border:1px solid var(--glass-border); border-radius:20px; padding:4px 10px; white-space:nowrap; margin-bottom:6px; flex-shrink:0; }
.news-update-badge::before { content:''; display:block; width:6px; height:6px; border-radius:50%; background:var(--green); flex-shrink:0; }
.news-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }

.news-card { background:var(--surface); border:1px solid var(--glass-border); border-radius:var(--radius); overflow:hidden; transition:all var(--tr); cursor:pointer; display:flex; flex-direction:column; }
.news-card:hover { border-color:var(--glass-b-blue); transform:translateY(-4px); box-shadow:var(--shadow-card); }
.nc-img { width:100%; height:160px; object-fit:cover; flex-shrink:0; background:var(--bg-3); }
.nc-img img { width:100%; height:100%; object-fit:cover; }
.nc-img-placeholder { width:100%; height:160px; display:flex; align-items:center; justify-content:center; font-size:2.5rem; background:linear-gradient(135deg,var(--bg-2),var(--bg-3)); }
.nc-body { padding:16px; flex:1; display:flex; flex-direction:column; }
.nc-source { font-size:0.65rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--blue); margin-bottom:8px; display:flex; align-items:center; gap:6px; }
.nc-source-logo { width:14px; height:14px; object-fit:contain; border-radius:2px; }
.nc-date { font-size:0.65rem; color:var(--text-dim); margin-left:auto; }
.nc-title { font-size:0.9rem; font-weight:700; color:var(--heading); margin-bottom:8px; line-height:1.35; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.nc-desc { font-size:0.8rem; color:var(--text-secondary); line-height:1.55; font-weight:300; flex:1; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; margin-bottom:12px; }
.nc-cta { font-size:0.78rem; font-weight:600; color:var(--blue); display:inline-flex; align-items:center; gap:4px; transition:gap var(--tr); }
.nc-cta:hover { gap:8px; }
.nc-fuente { font-size:0.65rem; color:var(--text-dim); margin-top:4px; }

/* Skeleton */
.news-card.skeleton { pointer-events:none; }
.sk-box { background:linear-gradient(90deg,var(--surface) 0%,var(--surface-hover) 50%,var(--surface) 100%); background-size:200% 100%; animation:shimmer 1.5s infinite; height:160px; }
.sk-line { height:12px; border-radius:4px; margin-bottom:8px; background:linear-gradient(90deg,var(--surface) 0%,var(--surface-hover) 50%,var(--surface) 100%); background-size:200% 100%; animation:shimmer 1.5s infinite; }
.sk-line--short { width:40%; }
@keyframes shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

.news-error { text-align:center; padding:40px 20px; color:var(--text-secondary); font-size:0.9rem; }

/* ── 10. CONTACT ──────────────────────────────────── */
.contact-section { padding:100px 0; background:var(--bg-2); }
.contact-grid { display:grid; grid-template-columns:1fr 1.4fr; gap:64px; align-items:start; }
.contact-title { font-size:clamp(1.6rem,2.8vw,2.3rem); margin-bottom:16px; }
.contact-desc { color:var(--text-secondary); font-weight:300; line-height:1.7; margin-bottom:28px; }
.contact-details { display:flex; flex-direction:column; gap:12px; }
.contact-item { display:flex; align-items:center; gap:10px; font-size:0.88rem; color:var(--text-secondary); }
.contact-icon { font-size:1rem; flex-shrink:0; }

.contact-form { background:var(--surface); border:1px solid var(--glass-border); border-radius:var(--radius); padding:36px; backdrop-filter:blur(10px); display:flex; flex-direction:column; gap:18px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-group { display:flex; flex-direction:column; gap:5px; }
.form-group label { font-size:0.78rem; font-weight:500; color:var(--text-secondary); }
.form-group input,.form-group select,.form-group textarea { background:rgba(255,255,255,0.04); border:1px solid var(--glass-border); border-radius:var(--radius-sm); padding:11px 14px; font-size:0.88rem; color:var(--text-primary); transition:all var(--tr); outline:none; resize:vertical; }
[data-theme="light"] .form-group input,[data-theme="light"] .form-group select,[data-theme="light"] .form-group textarea { background:rgba(255,255,255,0.8); }
.form-group input::placeholder,.form-group textarea::placeholder { color:var(--text-dim); }
.form-group select option { background:var(--bg-2); color:var(--text-primary); }
.form-group input:focus,.form-group select:focus,.form-group textarea:focus { border-color:var(--blue); box-shadow:0 0 0 3px var(--blue-subtle); }
.field-hint { font-size:0.72rem; margin-top:2px; }
.field-hint.error { color:var(--red); }
.field-hint.ok { color:var(--green); }
.form-privacy { text-align:center; font-size:0.72rem; color:var(--text-dim); }

/* ── 11. MODALS ───────────────────────────────────── */
.modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.75); backdrop-filter:blur(8px); z-index:2000; display:flex; align-items:center; justify-content:center; padding:20px; opacity:0; pointer-events:none; transition:opacity var(--tr); }
.modal-overlay.open { opacity:1; pointer-events:all; }
.modal-box { background:var(--bg-2); border:1px solid var(--glass-border); border-radius:var(--radius); padding:36px; max-width:480px; width:100%; position:relative; max-height:90vh; overflow-y:auto; animation:modalIn 0.3s ease; }
@keyframes modalIn { from{transform:translateY(20px);opacity:0} to{transform:translateY(0);opacity:1} }
.modal-close { position:absolute; top:16px; right:16px; font-size:1rem; color:var(--text-dim); transition:color var(--tr); line-height:1; padding:4px 8px; }
.modal-close:hover { color:var(--text-primary); }
.modal-header { text-align:center; margin-bottom:28px; }
.modal-header h2 { font-size:1.4rem; margin-bottom:8px; }
.modal-header p { font-size:0.88rem; color:var(--text-secondary); }
.modal-logo-icon { width:48px; height:48px; margin:0 auto 16px; }
.modal-logo-icon svg { width:100%; height:100%; }
.modal-icon { font-size:2.5rem; margin-bottom:12px; display:block; }
.unlock-icon { display:block; text-align:center; }
.modal-divider { display:flex; align-items:center; gap:12px; color:var(--text-dim); font-size:0.8rem; margin:16px 0; }
.modal-divider::before,.modal-divider::after { content:''; flex:1; height:1px; background:var(--glass-border); }
.modal-back-note { margin-bottom:16px; }

/* ── 12. FOOTER ───────────────────────────────────── */
.site-footer { background:var(--bg-3); border-top:1px solid var(--glass-border); padding:64px 0 0; }
.footer-inner { max-width:1200px; margin:0 auto; padding:0 24px; display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; }
.footer-brand .logo-name { font-size:1.1rem; display:block; margin-bottom:4px; }
.footer-brand .logo-tagline { display:block; margin-bottom:14px; }
.footer-desc { font-size:0.85rem; color:var(--text-secondary); font-weight:300; line-height:1.7; max-width:260px; }
.footer-links h4 { font-size:0.72rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:var(--text-dim); margin-bottom:14px; }
.footer-links ul { display:flex; flex-direction:column; gap:9px; }
.footer-links a { font-size:0.85rem; color:var(--text-secondary); transition:color var(--tr); }
.footer-links a:hover { color:var(--gold); }
.footer-bottom { max-width:1200px; margin:48px auto 0; padding:18px 24px; border-top:1px solid var(--glass-border); font-size:0.78rem; color:var(--text-dim); }

/* ── 13. ANIMATIONS ───────────────────────────────── */
@keyframes fadeUp { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }
@keyframes pulse-dot { 0%,100%{box-shadow:0 0 4px currentColor} 50%{box-shadow:0 0 14px currentColor,0 0 24px currentColor} }

.reveal { opacity:0; transform:translateY(25px); transition:opacity 0.65s ease,transform 0.65s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-delay-1 { transition-delay:0.08s; }
.reveal-delay-2 { transition-delay:0.16s; }
.reveal-delay-3 { transition-delay:0.24s; }
.reveal-delay-4 { transition-delay:0.32s; }
.reveal-delay-5 { transition-delay:0.4s; }
.reveal-delay-6 { transition-delay:0.48s; }

/* ── 14. RESPONSIVE ───────────────────────────────── */
@media(max-width:1200px) {
  .cases-layout { grid-template-columns:1fr 280px; }
  .cases-grid { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:1024px) {
  .cases-layout { grid-template-columns:1fr; }
  .live-sidebar { position:relative; top:auto; max-height:none; }
  .news-grid { grid-template-columns:repeat(2,1fr); }
  .footer-inner { grid-template-columns:1fr 1fr; gap:32px; }
}
@media(max-width:900px) {
  .cases-grid { grid-template-columns:repeat(2,1fr); }
  .contact-grid { grid-template-columns:1fr; gap:40px; }
}
@media(max-width:768px) {
  .main-nav { display:none; }
  .hamburger { display:flex; }
  .metrics-inner { display:grid; grid-template-columns:1fr 1fr; gap:16px; justify-items:center; }
  .metric-divider { display:none; }
  .hero-content { padding-bottom:260px; }
  .news-grid { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
  .footer-inner { grid-template-columns:1fr 1fr; }
  .footer-brand { grid-column:span 2; }
}
@media(max-width:560px) {
  .cases-grid { grid-template-columns:1fr; }
  .hero-headline { font-size:1.9rem; }
  .hero-ctas { flex-direction:column; align-items:center; }
  .btn { max-width:320px; }
  .footer-inner { grid-template-columns:1fr; }
  .footer-brand { grid-column:span 1; }
  .contact-form { padding:20px; }
  .metric-value { font-size:1.2rem; }
  .hero-content { padding-bottom:300px; }
}

/* NEWS MODAL PLACEHOLDER */
