/* =========================================================
   ETN Turistar — Terms & Conditions (terms.css)
   Tipografía clara, secciones modulares y TOC elegante
   ========================================================= */

/* ===== Design tokens (alineados a ETN) ===== */
:root{
  --etn-blue:#0c2d5e;
  --etn-teal:#0097a9;
  --ink:#1d2b3a;
  --muted:#5c6b78;
  --bg:#f7f9fb;
  --card:#ffffff;
  --border:#e6edf3;
  --radius:12px;
  --shadow:0 6px 18px rgba(0,0,0,.06);
}

/* ===== Base ===== */
html,body{margin:0;padding:0}
body{
  font-family: "Helvetica Neue", Arial, system-ui, sans-serif;
  background: var(--bg);
  color: var(--ink);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

main{
  max-width: 1100px;
  margin: 0 auto;
  padding: 2rem 1rem 3rem;
}

h1,h2,h3,h4{
  color: var(--etn-blue);
  line-height: 1.25;
  margin: 0 0 .65rem;
  font-weight: 700;
}

h1{ font-size: clamp(1.9rem, 3vw, 2.4rem); text-align:center; margin-bottom:1.2rem; }
h2{ font-size: clamp(1.25rem, 2.2vw, 1.6rem); }
h3{ font-size: 1.05rem; color:#142b47; margin-top:.6rem; }
h4{ font-size:.98rem; color:#1f3959; }

p{ margin: 0 0 1rem; color:#324758; }
strong{ color:#0a2b4f; }
a{ color: var(--etn-teal); text-decoration: none; }
a:hover{ text-decoration: underline; }

/* ===== Containers (secciones) ===== */
.container{
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.6rem;
  margin: 0 0 1.2rem;
  box-shadow: var(--shadow);
}

.container > p:last-child,
.container > ul:last-child,
.container > ol:last-child{ margin-bottom: 0; }

/* ===== Índice (TOC) ===== */
#toc-h2{
  display:flex; align-items:center; gap:.5rem;
  border-left: 4px solid var(--etn-teal);
  padding-left:.6rem;
}
.container ol{
  margin:.2rem 0 0;
  padding-left: 1.2rem;
}
.container ol li{
  margin:.25rem 0;
  color: var(--muted);
}
.container ol li a{
  font-weight:600; color:#0f4b66;
}
.container ol li a:hover{ color: var(--etn-teal); }

/* ===== Listas y texto ===== */
ul, ol{ color:#2b3f51; }
ul{ padding-left: 1.1rem; }
ul li{ margin: .45rem 0; }
li > ul{ margin-top:.35rem; }

.note, .warn{
  border-radius: 10px;
  padding:.9rem 1rem;
  margin: .8rem 0;
  border:1px solid var(--border);
}
.note{ background:#f0fbff; border-color:#cfe9f1; }
.warn{ background:#fff5f3; border-color:#ffd7cf; }

/* ===== Subtítulos con acento ===== */
.container h2{
  border-left:4px solid var(--etn-teal);
  padding-left:.6rem;
}

/* ===== Tablas (si llegas a usarlas) ===== */
.table{
  width:100%;
  border-collapse: collapse;
  margin: .8rem 0;
  font-size:.98rem;
}
.table th, .table td{
  border:1px solid var(--border);
  padding:.6rem .7rem;
  vertical-align: top;
}
.table th{
  background:#f3f8fb;
  text-align:left;
  color:#14395a;
  font-weight:700;
}

/* ===== Enlaces largos ===== */
a[rel~="noopener"]{ word-break: break-word; }

/* ===== Info legal pequeña ===== */
.small{
  font-size:.9rem; color: var(--muted);
}

/* ===== Responsive ===== */
@media (min-width: 768px){
  main{ padding: 3rem 2rem; }
  .container{ padding: 2rem; }
}

@media (min-width: 1024px){
  .container{ padding: 2.2rem 2.4rem; }
}

/* ===== Accesibilidad / foco ===== */
:focus-visible{
  outline: 2px solid var(--etn-teal);
  outline-offset: 2px;
}

/* ===== Anclas suaves (si activas scroll suave en HTML) ===== */
html{ scroll-behavior: smooth; }



/* ====== General Table Wrap ====== */
.table-wrap {
  margin: 2rem 0;
}

.table-title {
  font-size: 1.25rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
  text-align: left;
  color: #003366; /* azul corporativo */
}

/* ====== Table Base ====== */
.rule-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.95rem;
  line-height: 1.4;
  background-color: #fff;
  border: 1px solid #ddd;
}

.rule-table th,
.rule-table td {
  border: 1px solid #ddd;
  padding: 0.75rem;
  text-align: center;
}

.rule-table th {
  background-color: #f2f6fa;
  color: #003366;
  font-weight: 600;
  text-transform: uppercase;
}

.rule-table tr:nth-child(even) {
  background
