/* ═══════════════════════════════════════
   GOMIGO — styles.css
   Hoja de estilos unificada
   ═══════════════════════════════════════ */

:root {
  --primary:      #FFB300;
  --primary-dark: #E6A000;
  --primary-light:#FFF8E1;
  --dark:         #1A1A1A;
  --gray-dark:    #4A4A4A;
  --gray:         #6B7280;
  --gray-light:   #F5F5F5;
  --border:       #E5E7EB;
  --white:        #ffffff;
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family:'Inter','Segoe UI',system-ui,sans-serif;
  color:var(--dark); background:var(--white);
}

/* ── SKIP LINK ── */
.skip-link {
  position:absolute; top:-40px; left:6px;
  background:var(--primary); color:var(--dark);
  padding:8px 14px; border-radius:6px; font-weight:700; font-size:.85rem;
  text-decoration:none; z-index:200; transition:top .2s;
}
.skip-link:focus { top:8px; }

/* ═══════════════════════════════════════
   NAVEGACIÓN COMPARTIDA
   ═══════════════════════════════════════ */

/* — index.html usa <nav id="navbar"> — */
nav#navbar,
.site-header {
  position:fixed; top:0; left:0; right:0; z-index:100;
  background:rgba(255,255,255,0.97);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
  height:68px;
  transition:box-shadow .3s;
}
nav#navbar {
  padding:0 6%;
  display:flex; align-items:center; justify-content:space-between;
}
nav#navbar.scrolled,
.site-header.scrolled { box-shadow:0 2px 20px rgba(0,0,0,0.08); }

/* Logo index */
.logo { display:flex; align-items:center; gap:10px; text-decoration:none; }
.logo-icon { width:44px; height:44px; border-radius:10px; overflow:hidden; flex-shrink:0; }
.logo-icon img { width:100%; height:100%; object-fit:cover; }
.logo-text { font-size:1.3rem; font-weight:800; color:var(--dark); letter-spacing:-.5px; }

/* Nav links index */
.nav-links { display:flex; gap:32px; list-style:none; }
.nav-links a { text-decoration:none; color:var(--gray); font-size:.95rem; font-weight:500; transition:color .2s; }
.nav-links a:hover { color:var(--dark); }
.nav-cta {
  background:var(--primary); color:var(--dark);
  padding:10px 22px; border-radius:8px;
  text-decoration:none; font-weight:700; font-size:.9rem;
  transition:background .2s, transform .2s;
}
.nav-cta:hover { background:var(--primary-dark); transform:translateY(-1px); }

/* Logo páginas legales */
.container { max-width:900px; margin:0 auto; padding:0 6%; }
.header-inner {
  display:flex; align-items:center; justify-content:space-between;
  height:68px; padding:0 6%;
}
.brand { display:flex; align-items:center; gap:10px; text-decoration:none; }
.brand-mark { border-radius:8px; object-fit:cover; display:block; }
.brand-text { font-size:1.2rem; font-weight:800; color:var(--dark); letter-spacing:-.5px; }
.brand--footer .brand-text { color:#fff; }

.nav { display:flex; gap:28px; }
.nav a { text-decoration:none; color:var(--gray); font-size:.9rem; font-weight:500; transition:color .2s; }
.nav a:hover { color:var(--dark); }

/* ═══════════════════════════════════════
   BOTONES GLOBALES
   ═══════════════════════════════════════ */
.btn-primary {
  display:inline-flex; align-items:center; gap:10px;
  background:var(--primary); color:var(--dark);
  padding:14px 28px; border-radius:8px; text-decoration:none;
  font-weight:700; font-size:1rem;
  transition:background .2s, transform .2s, box-shadow .2s;
  box-shadow:0 4px 14px rgba(255,179,0,0.35);
}
.btn-primary:hover {
  background:var(--primary-dark); transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(255,179,0,0.4);
}
.btn-secondary {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--white); border:2px solid var(--border); color:var(--dark);
  padding:14px 28px; border-radius:8px; text-decoration:none;
  font-weight:600; font-size:1rem;
  transition:border-color .2s, background .2s;
}
.btn-secondary:hover { border-color:var(--primary); background:var(--primary-light); }

/* ═══════════════════════════════════════
   HERO (index)
   ═══════════════════════════════════════ */
#inicio {
  min-height:100vh;
  background:var(--white);
  display:flex; align-items:center;
  padding:100px 6% 60px;
  position:relative; overflow:hidden;
  border-bottom:1px solid var(--border);
}
.hero-accent {
  position:absolute; top:0; right:0;
  width:50%; height:100%;
  background:var(--gray-light);
  clip-path:polygon(12% 0, 100% 0, 100% 100%, 0% 100%);
  z-index:0;
}
.hero-content { max-width:520px; z-index:1; }
.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--primary-light); border:1px solid var(--primary);
  color:var(--dark); padding:6px 14px; border-radius:6px;
  font-size:.82rem; font-weight:700;
  margin-bottom:24px; text-transform:uppercase; letter-spacing:.5px;
}
.hero-badge span {
  width:8px; height:8px; background:var(--primary);
  border-radius:50%; animation:pulse 2s infinite;
}
@keyframes pulse {
  0%,100% { opacity:1; transform:scale(1); }
  50%     { opacity:.5; transform:scale(1.3); }
}
h1 {
  font-size:clamp(2.2rem,4.5vw,3.4rem);
  font-weight:800; line-height:1.15;
  color:var(--dark); margin-bottom:20px; letter-spacing:-.5px;
}
h1 em { font-style:normal; color:var(--primary); }
.hero-sub {
  font-size:1.05rem; color:var(--gray);
  line-height:1.75; margin-bottom:36px; max-width:440px;
}
.hero-btns { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:16px; }
.platform-hints { display:flex; gap:10px; margin-bottom:32px; flex-wrap:wrap; }
.platform-pill {
  display:inline-flex; align-items:center; gap:6px;
  padding:5px 12px; border-radius:50px; font-size:.8rem; font-weight:600;
  border: 1px solid var(--border);
}
.platform-pill--active {
  background:var(--primary-light); border-color:var(--primary);
  color:var(--dark);
}
.platform-pill--soon {
  background:var(--gray-light); border-color:var(--border);
  color:var(--gray);
}

.hero-visual {
  flex:1; display:flex; justify-content:center;
  align-items:center; z-index:1; padding-left:40px;
}
.phone-mockup {
  width:250px; height:490px;
  background:var(--white);
  border-radius:36px; border:2px solid var(--border);
  box-shadow:0 32px 64px rgba(0,0,0,0.12), 0 0 0 1px rgba(0,0,0,0.04);
  padding:18px 14px;
  animation:float 4s ease-in-out infinite;
}
@keyframes float {
  0%,100% { transform:translateY(0); }
  50%     { transform:translateY(-10px); }
}
.phone-notch { width:70px; height:7px; background:var(--border); border-radius:50px; margin:0 auto 14px; }
.phone-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.phone-logo { font-size:.85rem; font-weight:800; color:var(--dark); }
.phone-logo span { color:var(--primary); }
.phone-avatar { width:26px; height:26px; border-radius:50%; background:var(--primary); }
.event-card {
  background:var(--gray-light); border:1px solid var(--border);
  border-radius:12px; padding:10px 12px; margin-bottom:8px;
  transition:transform .2s, border-color .2s;
}
.event-card:hover { transform:scale(1.02); border-color:var(--primary); }
.event-tag { font-size:.62rem; color:var(--primary-dark); font-weight:700; text-transform:uppercase; letter-spacing:.5px; margin-bottom:3px; }
.event-title { font-size:.78rem; color:var(--dark); font-weight:600; margin-bottom:3px; }
.event-meta { font-size:.68rem; color:var(--gray); }
.join-btn {
  width:100%; margin-top:10px;
  background:var(--primary); color:var(--dark);
  border:none; border-radius:8px; padding:10px;
  font-size:.8rem; font-weight:700; cursor:pointer; transition:background .2s;
}
.join-btn:hover { background:var(--primary-dark); }

/* ═══════════════════════════════════════
   SECCIONES COMUNES (index)
   ═══════════════════════════════════════ */
section { padding:80px 6%; }
.section-tag {
  display:inline-block; background:var(--primary-light); color:var(--primary-dark);
  padding:5px 14px; border-radius:6px; font-size:.78rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.5px; margin-bottom:14px;
}
h2 {
  font-size:clamp(1.8rem,3.5vw,2.4rem);
  font-weight:800; line-height:1.2; margin-bottom:14px; letter-spacing:-.3px;
}
.section-sub { font-size:1rem; color:var(--gray); max-width:520px; line-height:1.75; margin-bottom:48px; }

/* Features */
#caracteristicas { background:var(--gray-light); }
.features-header { text-align:center; }
.features-header .section-sub { margin:0 auto 48px; }
.features-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:20px; max-width:1100px; margin:0 auto;
}
.feature-card {
  background:var(--white); border-radius:12px; padding:28px;
  border:1px solid var(--border);
  transition:transform .3s, box-shadow .3s, border-color .3s;
}
.feature-card:hover { transform:translateY(-4px); box-shadow:0 12px 32px rgba(0,0,0,0.08); border-color:var(--primary); }
.feature-icon {
  width:48px; height:48px; border-radius:10px;
  background:var(--primary-light); display:flex; align-items:center;
  justify-content:center; font-size:1.4rem; margin-bottom:16px; transition:background .3s;
}
.feature-card:hover .feature-icon { background:var(--primary); }
.feature-card h3 { font-size:1rem; font-weight:700; margin-bottom:8px; }
.feature-card p { font-size:.88rem; color:var(--gray); line-height:1.65; }

/* How it works */
#como-funciona { background:var(--white); }
.hiw-inner { display:flex; gap:60px; align-items:center; flex-wrap:wrap; max-width:1100px; margin:0 auto; }
.hiw-steps { flex:1; min-width:280px; }
.step { display:flex; gap:18px; margin-bottom:28px; align-items:flex-start; }
.step-num {
  width:42px; height:42px; border-radius:10px;
  background:var(--primary); color:var(--dark);
  font-size:1rem; font-weight:800;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.step-content h3 { font-size:1rem; font-weight:700; margin-bottom:4px; }
.step-content p { font-size:.88rem; color:var(--gray); line-height:1.65; }
.hiw-visual { flex:1; min-width:260px; display:flex; justify-content:center; }
.hiw-card {
  background:var(--gray-light); border-radius:16px; padding:28px;
  border:1px solid var(--border); width:100%; max-width:320px;
}
.hiw-card h3 { font-size:.95rem; font-weight:700; color:var(--dark); margin-bottom:20px; }
.timeline { position:relative; padding-left:24px; }
.timeline::before {
  content:''; position:absolute; left:6px; top:0; bottom:0;
  width:2px; background:linear-gradient(to bottom, var(--primary), transparent);
}
.tl-item { position:relative; margin-bottom:18px; }
.tl-dot {
  position:absolute; left:-20px; top:5px;
  width:9px; height:9px; border-radius:50%;
  background:var(--primary); box-shadow:0 0 0 3px var(--primary-light);
}
.tl-text { font-size:.88rem; color:var(--dark); font-weight:600; }
.tl-time { font-size:.75rem; color:var(--gray); margin-top:2px; }

/* CTA */
#descargar { background:var(--dark); text-align:center; padding:80px 6%; }
#descargar h2 { color:#fff; margin-bottom:14px; }
#descargar p { color:rgba(255,255,255,0.5); font-size:1rem; margin-bottom:36px; }

/* ═══════════════════════════════════════
   FOOTER COMPARTIDO
   ═══════════════════════════════════════ */

/* Footer index */
footer {
  background:var(--dark); padding:0 6% 28px;
  border-top:1px solid rgba(255,255,255,0.08);
}
.footer-inner {
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:20px; padding:28px 0 20px;
}
.footer-logo { display:flex; align-items:center; gap:10px; }
.footer-logo .fi { width:36px; height:36px; border-radius:8px; overflow:hidden; }
.footer-logo .fi img { width:100%; height:100%; object-fit:cover; }
.footer-logo span { color:#fff; font-weight:800; font-size:1.05rem; }
.footer-links { display:flex; gap:24px; flex-wrap:wrap; }
.footer-links a { color:rgba(255,255,255,0.4); text-decoration:none; font-size:.85rem; transition:color .2s; }
.footer-links a:hover { color:var(--primary); }
.footer-social { display:flex; gap:16px; align-items:center; }
.footer-social a {
  color:rgba(255,255,255,0.4); display:flex; align-items:center;
  transition:color .2s;
}
.footer-social a:hover { color:var(--primary); }
.footer-copy {
  color:rgba(255,255,255,0.2); font-size:.78rem; text-align:center;
  padding-top:20px; border-top:1px solid rgba(255,255,255,0.07);
}

/* Footer páginas legales */
.site-footer {
  background:var(--dark); padding:28px 0;
  border-top:1px solid rgba(255,255,255,0.08);
}
.footer-grid {
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:16px; padding:0 6%;
}
.footer-nav { display:flex; gap:24px; }
.footer-nav a { color:rgba(255,255,255,0.4); text-decoration:none; font-size:.85rem; transition:color .2s; }
.footer-nav a:hover,
.footer-nav a[aria-current="page"] { color:var(--primary); }
.site-footer .small { color:rgba(255,255,255,0.25); font-size:.78rem; }

/* ═══════════════════════════════════════
   PÁGINAS LEGALES (privacy / terms)
   ═══════════════════════════════════════ */
.section { padding:100px 0 80px; }

.back-home { margin-bottom:32px; }
.back-home a {
  color:var(--gray); text-decoration:none; font-size:.9rem;
  font-weight:500; transition:color .2s;
}
.back-home a:hover { color:var(--primary-dark); }

.document { display:flex; flex-direction:column; gap:20px; }

.doc-header { margin-bottom:8px; }
.section-title {
  font-size:clamp(1.6rem,3vw,2.2rem);
  font-weight:800; color:var(--dark);
  display:flex; align-items:center; gap:12px; margin-bottom:10px;
}
.bar {
  display:inline-block; width:5px; height:1.1em;
  background:var(--primary); border-radius:3px; flex-shrink:0;
}
.muted { color:var(--gray); }
.small { font-size:.82rem; }

.badge {
  display:inline-block; padding:3px 10px; border-radius:6px;
  font-size:.78rem; font-weight:700;
}
.badge--brand { background:var(--primary-light); color:var(--primary-dark); }

/* Cards legales */
.card {
  background:var(--white); border:1px solid var(--border);
  border-radius:14px; padding:28px 32px;
  transition:border-color .2s, box-shadow .2s;
}
.card:hover { border-color:var(--primary); box-shadow:0 6px 24px rgba(0,0,0,0.06); }

.doc-intro p { font-size:1rem; color:var(--gray-dark); line-height:1.75; }
.doc-intro a { color:var(--primary-dark); font-weight:600; }

.doc-single h3 { font-size:1rem; font-weight:700; margin-bottom:10px; color:var(--dark); }
.doc-single p  { font-size:.92rem; color:var(--gray-dark); line-height:1.75; }
.doc-single p + p { margin-top:10px; }
.doc-single a  { color:var(--primary-dark); font-weight:600; }

.doc-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:20px;
  background:transparent; border:none; padding:0; box-shadow:none;
}
.doc-grid:hover { border-color:transparent; box-shadow:none; }

.doc-block {
  background:var(--white); border:1px solid var(--border);
  border-radius:14px; padding:24px 28px;
  transition:border-color .2s, box-shadow .2s;
}
.doc-block:hover { border-color:var(--primary); box-shadow:0 6px 24px rgba(0,0,0,0.06); }
.doc-block h3 { font-size:1rem; font-weight:700; margin-bottom:12px; color:var(--dark); }
.doc-block p  { font-size:.88rem; color:var(--gray-dark); line-height:1.75; }
.doc-block p + p { margin-top:8px; }
.doc-block a  { color:var(--primary-dark); font-weight:600; }

.checklist { list-style:none; display:flex; flex-direction:column; gap:8px; margin-bottom:10px; }
.checklist li {
  font-size:.88rem; color:var(--gray-dark); line-height:1.65;
  padding-left:20px; position:relative;
}
.checklist li::before {
  content:'✓'; position:absolute; left:0;
  color:var(--primary); font-weight:800; font-size:.85rem;
}
.checklist a { color:var(--primary-dark); font-weight:600; }
.checklist a:hover { color:var(--primary); }

/* ═══════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════ */
@media(max-width:768px) {
  #inicio { flex-direction:column; text-align:center; padding-top:90px; }
  .hero-accent { display:none; }
  .hero-btns { justify-content:center; }
  .platform-hints { justify-content:center; }
  .hero-visual { padding-left:0; margin-top:40px; }
  .nav-links { display:none; }
  .hiw-inner { flex-direction:column; }
  .doc-grid { grid-template-columns:1fr; }
  .footer-grid { flex-direction:column; text-align:center; }
  .footer-nav { justify-content:center; }
}