/* ====================================================================
   Estilos compartidos para las páginas legales de taller.bike
   Paleta y tipografía heredadas del index.html (tema oscuro + naranja)
   ==================================================================== */

:root {
  --paper: #121316;        /* fondo de página — carbón neutro */
  --paper-2: #1A1C20;      /* tarjetas elevadas */
  --paper-3: #0C0D0F;      /* superficie más profunda */
  --ink: #F2F3F5;          /* texto primario — blanco neutro */
  --ink-2: #C7CAD1;        /* texto secundario */
  --ink-3: #82868F;        /* texto atenuado */
  --rule: #262A30;         /* líneas finas */
  --rule-2: #353A42;       /* bordes más fuertes */
  --shop: #FB923C;         /* naranja — acento de marca */
  --shop-2: #F97316;
  --signal: #F0B429;       /* amarillo señalización */
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; scrollbar-width: thin; scrollbar-color: var(--rule-2) transparent; }
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--rule-2); border-radius: 9999px; border: 2px solid transparent; background-clip: padding-box; }
::-webkit-scrollbar-thumb:hover { background: var(--ink-3); background-clip: padding-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: 'ss01', 'cv01';
  line-height: 1.7;
}

body {
  overflow-x: hidden;
  background:
    radial-gradient(ellipse 1200px 800px at 20% -10%, rgba(251, 146, 60, 0.07), transparent 60%),
    radial-gradient(ellipse 1000px 700px at 90% 20%, rgba(251, 146, 60, 0.04), transparent 65%),
    radial-gradient(ellipse 1200px 900px at 50% 110%, rgba(240, 180, 41, 0.035), transparent 60%),
    var(--paper);
  background-attachment: fixed;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
::selection { background: var(--signal); color: #121316; }

.mono { font-family: 'JetBrains Mono', monospace; }

/* ========== HEADER ========== */
.legal-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(12, 13, 15, 0.82);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--rule);
}
.legal-header-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 18px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.legal-logo { height: 40px; width: auto; }
.legal-back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--ink-2);
  border: 1px solid var(--rule-2);
  border-radius: 99px;
  padding: 9px 16px;
  transition: color .2s ease, border-color .2s ease;
}
.legal-back:hover { color: var(--shop); border-color: var(--shop); }
.legal-back svg { flex-shrink: 0; }

/* ========== CONTENIDO ========== */
.legal-content {
  flex: 1;
  width: 100%;
  max-width: 760px;
  margin: 0 auto;
  padding: 64px 24px 88px;
}
.legal-title {
  font-size: clamp(32px, 5vw, 44px);
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--ink);
  margin: 0 0 12px;
  line-height: 1.1;
}
.legal-updated {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12.5px;
  letter-spacing: 0.04em;
  color: var(--ink-3);
  margin: 0 0 44px;
}

.legal-section {
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: 16px;
  padding: 30px 32px;
  margin-bottom: 22px;
}
.legal-section h2 {
  font-size: 19px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin: 0 0 16px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.legal-section h2 .num {
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  border: 1.5px solid var(--shop);
  color: var(--shop);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px;
  font-weight: 600;
}
.legal-section p {
  margin: 0 0 12px;
  color: var(--ink-2);
  font-size: 15px;
}
.legal-section p:last-child { margin-bottom: 0; }
.legal-section ul,
.legal-section ol {
  margin: 12px 0 12px 4px;
  padding-left: 22px;
  color: var(--ink-2);
  font-size: 15px;
}
.legal-section li { margin-bottom: 8px; }
.legal-section strong { color: var(--ink); font-weight: 700; }
.legal-section a { color: var(--shop); border-bottom: 1px solid transparent; transition: border-color .2s ease; }
.legal-section a:hover { border-color: var(--shop); }

.highlight {
  background: color-mix(in oklab, var(--shop) 9%, transparent);
  border-left: 3px solid var(--shop);
  padding: 16px 20px;
  border-radius: 0 12px 12px 0;
  margin: 16px 0;
}
.highlight p { margin: 0; color: var(--ink); }

.warning {
  background: color-mix(in oklab, var(--signal) 10%, transparent);
  border-left: 3px solid var(--signal);
  padding: 16px 20px;
  border-radius: 0 12px 12px 0;
  margin: 16px 0;
}
.warning p { margin: 0; color: var(--ink); }

/* Tabla de planes */
.plans-table {
  width: 100%;
  border-collapse: collapse;
  margin: 16px 0;
  font-size: 14px;
}
.plans-table th,
.plans-table td {
  padding: 12px 14px;
  text-align: left;
  border-bottom: 1px solid var(--rule);
  color: var(--ink-2);
}
.plans-table th {
  background: var(--paper-3);
  font-weight: 600;
  color: var(--ink);
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.plans-table tr:last-child td { border-bottom: none; }
.plans-table td strong { color: var(--ink); }

.contact-box {
  background: var(--paper-3);
  border: 1px solid var(--rule);
  border-radius: 12px;
  padding: 20px 22px;
  margin-top: 16px;
}
.contact-box p { margin: 0 0 8px; color: var(--ink-2); }
.contact-box p:last-child { margin-bottom: 0; }
.contact-box a { color: var(--shop); }
.contact-box a:hover { border-bottom: 1px solid var(--shop); }

/* Navegación entre páginas legales */
.legal-nav {
  margin-top: 40px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  font-size: 13.5px;
}
.legal-nav .lbl {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.legal-nav a {
  color: var(--ink-2);
  border: 1px solid var(--rule-2);
  border-radius: 99px;
  padding: 8px 14px;
  transition: color .2s ease, border-color .2s ease;
}
.legal-nav a:hover { color: var(--shop); border-color: var(--shop); }

/* ========== FOOTER ========== */
.legal-footer {
  background: var(--paper-2);
  border-top: 1px solid var(--rule);
  padding: 48px 0 36px;
}
.legal-footer-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 22px;
  text-align: center;
}
.legal-footer img { height: 50px; width: auto; }
.legal-footer-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 22px;
  font-size: 13px;
}
.legal-footer-links a { color: var(--ink-3); transition: color .2s ease; }
.legal-footer-links a:hover { color: var(--shop); }
.legal-footer-copy {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--ink-3);
}
.legal-footer-copy a { color: var(--ink-2); border-bottom: 1px solid var(--rule-2); }

/* ========== RESPONSIVE ========== */
@media (max-width: 600px) {
  .legal-section { padding: 24px 20px; }
  .legal-content { padding: 44px 18px 72px; }
  .legal-header-inner { padding: 16px 18px; }
}
