/* ============================================================
   XCLUSIVE COLOMBIA — Global Stylesheet
   ============================================================ */

:root {
  --gold: #c8a96e;
  --gold2: #e2c98a;
  --dark: #0a0a0a;
  --dark2: #0d0d0d;
  --dark3: #111111;
  --dark4: #161616;
  --border: #1e1e1e;
  --muted: #777777;
  --muted2: #aaaaaa;
  --white: #ffffff;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Georgia, sans-serif;
  background: var(--dark);
  color: var(--white);
  overflow-x: hidden;
}

/* ── TEXTURE BACKGROUND ── */
.texture-bg {
  background-image:
    linear-gradient(rgba(200,169,110,0.13) 1px, transparent 1px),
    linear-gradient(90deg, rgba(200,169,110,0.13) 1px, transparent 1px),
    linear-gradient(rgba(200,169,110,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(200,169,110,0.05) 1px, transparent 1px);
  background-size: 60px 60px, 60px 60px, 30px 30px, 30px 30px;
  background-color: var(--dark2);
}

/* ── NAVBAR ── */
.nav {
  position: sticky; top: 0; z-index: 999;
  background: rgba(10,10,10,0.97);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  padding: 0 48px;
  display: flex; align-items: center; justify-content: space-between;
  height: 72px;
}
.nav-logo { line-height: 1; }
.nav-logo-main { color: var(--gold); font-size: 22px; font-weight: 700; letter-spacing: 5px; display: block; }
.nav-logo-sub { color: #3a3a3a; font-size: 8px; letter-spacing: 4px; text-transform: uppercase; display: block; margin-top: 2px; }
.nav-links { display: flex; gap: 32px; align-items: center; }
.nav-links a { color: #666; font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; text-decoration: none; transition: color .2s; cursor: pointer; }
.nav-links a:hover, .nav-links a.active { color: var(--gold); }
.nav-cta { background: transparent; border: 1px solid var(--gold); color: var(--gold); font-size: 10px; letter-spacing: 2px; text-transform: uppercase; padding: 9px 22px; cursor: pointer; transition: all .2s; text-decoration: none; display: inline-block; }
.nav-cta:hover { background: var(--gold); color: #000; }
.nav-toggle { display: none; background: transparent; border: none; color: var(--gold); font-size: 24px; cursor: pointer; }

/* ── PAGE HERO ── */
.page-hero {
  position: relative; min-height: 360px;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.page-hero::after { content:''; position: absolute; inset: 0; background: linear-gradient(to bottom, transparent 40%, var(--dark) 100%); }
.page-hero-content { position: relative; z-index: 2; text-align: center; padding: 60px 24px; }
.breadcrumb { color: #444; font-size: 10px; letter-spacing: 3px; text-transform: uppercase; margin-bottom: 20px; }
.breadcrumb span { color: var(--gold); }
.page-hero h1 { font-size: clamp(32px, 5vw, 52px); font-weight: 700; letter-spacing: 3px; text-transform: uppercase; margin-bottom: 8px; }
.page-hero h1 em { color: var(--gold); font-style: normal; }
.page-hero p { color: var(--muted); font-size: 14px; line-height: 1.8; max-width: 520px; margin: 0 auto; }

/* ── UTILITIES ── */
.gold-bar { width: 48px; height: 1px; background: var(--gold); margin: 16px auto; }
.gold-bar-left { width: 48px; height: 1px; background: var(--gold); margin: 16px 0; }
.section-tag { color: var(--gold); font-size: 10px; letter-spacing: 4px; text-transform: uppercase; margin-bottom: 12px; display: block; }
.section-head { text-align: center; margin-bottom: 56px; }
.section-head h2 { font-size: clamp(22px, 3.5vw, 30px); font-weight: 700; letter-spacing: 1px; }
.section-head p { color: var(--muted); font-size: 14px; margin-top: 12px; line-height: 1.8; }

/* ── BUTTONS ── */
.btn-primary { background: var(--gold); color: #000; font-size: 11px; letter-spacing: 2.5px; text-transform: uppercase; padding: 14px 36px; border: none; cursor: pointer; font-weight: 700; transition: background .2s; text-decoration: none; display: inline-block; }
.btn-primary:hover { background: var(--gold2); }
.btn-outline { background: transparent; border: 1px solid #333; color: #888; font-size: 11px; letter-spacing: 2.5px; text-transform: uppercase; padding: 14px 36px; cursor: pointer; transition: all .2s; text-decoration: none; display: inline-block; }
.btn-outline:hover { border-color: var(--gold); color: var(--gold); }
.btn-group { display: flex; gap: 16px; flex-wrap: wrap; }

/* ── STATS BAR ── */
.stats-bar { display: grid; grid-template-columns: repeat(4,1fr); background: var(--dark3); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.stat { padding: 36px 20px; text-align: center; border-right: 1px solid var(--border); }
.stat:last-child { border-right: none; }
.stat-num { font-size: 38px; font-weight: 700; color: var(--gold); line-height: 1; }
.stat-label { color: var(--muted); font-size: 10px; letter-spacing: 2px; text-transform: uppercase; margin-top: 8px; }

/* ── FOOTER ── */
footer { background: #000; border-top: 1px solid #111; padding: 36px 48px; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 20px; }
.footer-logo { color: var(--gold); font-size: 16px; font-weight: 700; letter-spacing: 4px; }
.footer-copy { color: #2a2a2a; font-size: 10px; letter-spacing: 1px; margin-top: 5px; }
.footer-links { display: flex; gap: 28px; flex-wrap: wrap; }
.footer-links a { color: #333; font-size: 10px; letter-spacing: 1px; text-transform: uppercase; text-decoration: none; transition: color .2s; }
.footer-links a:hover { color: var(--gold); }

/* ── MODAL ── */
.modal-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.92); z-index: 2000; align-items: center; justify-content: center; padding: 24px; }
.modal-overlay.open { display: flex; }
.modal-box { background: var(--dark3); border: 1px solid #222; width: 100%; max-width: 700px; position: relative; animation: modalIn .3s ease; overflow: hidden; }
@keyframes modalIn { from { opacity:0; transform: translateY(14px); } to { opacity:1; transform: translateY(0); } }
.modal-close { position: absolute; top: 14px; right: 16px; background: transparent; border: none; color: #555; font-size: 22px; cursor: pointer; transition: color .2s; z-index: 10; }
.modal-close:hover { color: var(--gold); }

/* ── WA FLOAT ── */
.wa-float { position: fixed; bottom: 28px; right: 28px; background: #25D366; border: none; border-radius: 50%; width: 56px; height: 56px; display: flex; align-items: center; justify-content: center; cursor: pointer; box-shadow: 0 4px 20px rgba(37,211,102,0.35); transition: transform .2s; z-index: 998; font-size: 26px; text-decoration: none; }
.wa-float:hover { transform: scale(1.1); }

/* ── RESPONSIVE ── */
@media (max-width: 900px) {
  .nav { padding: 0 20px; }
  .nav-links { display: none; flex-direction: column; position: absolute; top: 72px; left: 0; right: 0; background: rgba(10,10,10,0.98); padding: 24px; gap: 20px; border-bottom: 1px solid var(--border); }
  .nav-links.open { display: flex; }
  .nav-toggle { display: block; }
  .stats-bar { grid-template-columns: repeat(2,1fr); }
  .stat { border-right: none; border-bottom: 1px solid var(--border); }
  footer { flex-direction: column; text-align: center; padding: 28px 20px; }
}

/* ── LOGO IMAGE ── */
.nav-logo img {
  height: 44px;
  width: auto;
  display: block;
  transition: opacity .2s;
}
.nav-logo img:hover { opacity: .85; }

/* ── IMPROVED MOBILE RESPONSIVE ── */
@media (max-width: 480px) {
  .nav { padding: 0 16px; height: 64px; }
  .nav-logo img { height: 36px; }
  .hero { min-height: 100svh; }
  .hero h1 { font-size: 36px; letter-spacing: 2px; }
  .hero-desc { font-size: 13px; padding: 0 8px; }
  .btn-group { flex-direction: column; align-items: center; }
  .btn-primary, .btn-outline { width: 100%; max-width: 320px; text-align: center; padding: 16px 24px; font-size: 12px; }
  .about-left, .about-right { padding: 40px 20px; }
  .services-section, .why-section, .testimonials, .cta-section { padding: 48px 20px; }
  .services-grid { grid-template-columns: 1fr; }
  .why-grid { grid-template-columns: 1fr; gap: 40px; }
  .test-grid { grid-template-columns: 1fr; }
  .why-stats { grid-template-columns: 1fr 1fr; }
  .stats-bar { grid-template-columns: 1fr 1fr; }
  .stat { border-right: none !important; border-bottom: 1px solid var(--border); }
  .stat:nth-child(odd) { border-right: 1px solid var(--border) !important; }
  .stat:last-child, .stat:nth-last-child(2):nth-child(odd) { border-bottom: none; }
  footer { padding: 28px 20px; flex-direction: column; text-align: center; gap: 16px; }
  .footer-links { justify-content: center; }
  /* Contact form */
  .main-grid { grid-template-columns: 1fr; }
  .form-side { padding: 36px 20px; }
  .form-row { grid-template-columns: 1fr; }
  .quick-strip { grid-template-columns: 1fr 1fr; }
  /* Gallery */
  .team-strip { grid-template-columns: repeat(4, 1fr); padding: 0 16px 3px; }
  .masonry-wrap { columns: 2; padding: 0 16px 32px; }
  /* About */
  .mission-grid { grid-template-columns: 1fr; }
  .story-steps { grid-template-columns: 1fr 1fr; gap: 24px; }
  .team-grid-4 { grid-template-columns: 1fr 1fr; }
  .team-grid-3 { grid-template-columns: 1fr 1fr; max-width: 100%; }
  /* Services */
  .featured-srv { grid-template-columns: 1fr; }
  .feat-visual { min-height: 200px; }
  .feat-content { padding: 32px 20px; }
  .process-steps { grid-template-columns: 1fr 1fr; gap: 24px; }
  .guarantee-grid { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  .nav-links { display: none; flex-direction: column; position: absolute; top: 64px; left: 0; right: 0; background: rgba(8,8,8,0.98); padding: 20px; gap: 16px; border-bottom: 1px solid var(--border); z-index: 998; }
  .nav-links.open { display: flex; }
  .nav-toggle { display: block; padding: 8px; }
  .nav-logo img { height: 40px; }
  /* Stats 2x2 on mobile */
  .stats-bar { grid-template-columns: 1fr 1fr; }
  .stat:nth-child(1), .stat:nth-child(3) { border-right: 1px solid var(--border); }
  .stat:nth-child(2), .stat:nth-child(3), .stat:nth-child(4) { border-right: none; }
  .stat:nth-child(1), .stat:nth-child(2) { border-bottom: 1px solid var(--border); }
  /* CTA contacts stack */
  .cta-contacts { flex-direction: column; gap: 16px; }
  /* Gallery team strip */
  .team-strip { grid-template-columns: repeat(3, 1fr); }
  /* Section padding */
  .section-label { padding: 24px 20px 12px; }
  .masonry-wrap { padding: 0 20px 32px; }
  /* Offices */
  .offices { padding: 24px 20px; }
  .offices-grid { grid-template-columns: 1fr 1fr; }
  /* Social strip */
  .social-strip { padding: 20px; flex-direction: column; gap: 14px; text-align: center; }
  /* FAQ */
  .faq-grid { grid-template-columns: 1fr; }
  .faq-section { padding: 48px 20px; }
  /* Partners */
  .partners-row { gap: 12px; }
  .partner-box { padding: 18px 20px; min-width: 140px; }
}

@media (min-width: 769px) and (max-width: 1024px) {
  .nav { padding: 0 28px; }
  .nav-links { gap: 20px; }
  .services-grid { grid-template-columns: 1fr 1fr; }
  .test-grid { grid-template-columns: 1fr 1fr; }
  .about-left, .about-right { padding: 52px 36px; }
  .about-right { grid-template-columns: 1fr 1fr; }
  .team-grid-4 { grid-template-columns: repeat(2, 1fr); }
  .team-grid-3 { grid-template-columns: repeat(3, 1fr); max-width: 100%; }
  .masonry-wrap { columns: 3; }
  .team-strip { grid-template-columns: repeat(4, 1fr); padding: 0 24px 3px; }
}

/* ══════════════════════════════════════════════════════════
   FLOATING BUTTONS — WhatsApp x2 + Instagram
   ══════════════════════════════════════════════════════════ */
.float-btns {
  position: fixed;
  bottom: 28px;
  right: 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  z-index: 999;
}

.float-btn {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  transition: transform .2s, box-shadow .2s;
  position: relative;
}

.float-btn:hover { transform: scale(1.12); }

/* Tooltip */
.float-btn::before {
  content: attr(title);
  position: absolute;
  right: 60px;
  background: rgba(10,10,10,0.95);
  color: #c8a96e;
  font-size: 10px;
  letter-spacing: 1px;
  white-space: nowrap;
  padding: 6px 12px;
  border: 1px solid #1e1e1e;
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s;
}
.float-btn:hover::before { opacity: 1; }

/* Instagram */
.float-ig {
  background: linear-gradient(135deg, #833ab4, #fd1d1d, #fcb045);
  color: #fff;
  box-shadow: 0 4px 18px rgba(131,58,180,0.4);
}

/* WhatsApp Colombia */
.float-wa {
  background: #25D366;
  color: #fff;
  box-shadow: 0 4px 18px rgba(37,211,102,0.4);
}

/* WhatsApp Internacional */
.float-wa2 {
  background: #128C7E;
  color: #fff;
  box-shadow: 0 4px 18px rgba(18,140,126,0.35);
}

/* Label badge under each button */
.float-wa::after  { content: 'COL'; position:absolute; bottom:-6px; left:50%; transform:translateX(-50%); background:#128C7E; color:#fff; font-size:7px; padding:1px 5px; border-radius:3px; letter-spacing:1px; }
.float-wa2::after { content: 'INT'; position:absolute; bottom:-6px; left:50%; transform:translateX(-50%); background:#075E54; color:#fff; font-size:7px; padding:1px 5px; border-radius:3px; letter-spacing:1px; }

@media(max-width:480px){
  .float-btns { bottom:16px; right:14px; gap:10px; }
  .float-btn  { width:46px; height:46px; }
  .float-btn::before { display:none; }
}
