/* ─── CONSTITUTION ─── */

/* Language toggle tabs */
.const-lang-tab {
  flex: 1; padding: 15px 12px;
  border: none; background: none;
  font-family: 'Jost', sans-serif;
  font-weight: 500; font-size: 0.73rem;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink-muted);
  border-bottom: 2px solid transparent;
  cursor: pointer; transition: all 0.2s;
}
.const-lang-tab.active-tab { color: var(--forest); border-bottom-color: var(--forest); }
.const-lang-tab:hover:not(.active-tab) { color: var(--ink); }

/* Section nav tabs */
.const-nav-tab {
  display: inline-block;
  padding: 12px 18px;
  font-size: 0.68rem; font-weight: 500;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink-muted);
  border: none; border-bottom: 2px solid transparent;
  background: none; cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
  font-family: 'Jost', sans-serif;
}
.const-nav-tab:hover { color: var(--forest); border-bottom-color: var(--gold); }
.const-nav-tab.c-active { color: var(--forest); border-bottom-color: var(--forest); }

/* Content panels */
.const-content-panel {
  max-width: 860px;
  margin: 0 auto;
  padding: 60px 36px 100px;
}

/* Section blocks */
.cst-section {
  margin-bottom: 64px;
  scroll-margin-top: 120px;
}
.cst-eyebrow {
  font-size: 0.58rem; letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--gold); font-weight: 600; margin-bottom: 10px;
  display: flex; align-items: center; gap: 12px;
}
.cst-eyebrow::after { content: ''; flex: 1; height: 1px; background: var(--border); }
.cst-section h2 {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.5rem, 3.5vw, 2.2rem);
  font-weight: 600; color: var(--ink);
  margin-bottom: 24px; line-height: 1.2;
}

/* Bullet list */
.cst-list { list-style: none; padding: 0; margin: 0 0 14px; }
.cst-list li {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 10px 0; border-bottom: 1px solid var(--border);
  font-size: 0.88rem; line-height: 1.7; color: var(--ink-soft);
}
.cst-list li:last-child { border-bottom: none; }
.cst-list li::before {
  content: ''; display: block; width: 5px; height: 5px;
  border-radius: 50%; background: var(--gold);
  margin-top: 9px; flex-shrink: 0;
}

/* Info cards */
.cst-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1px; background: var(--border);
  border: 1px solid var(--border); margin-bottom: 24px;
}
.cst-card { background: var(--white); padding: 22px 20px; }
.cst-card-label {
  font-size: 0.58rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--gold); font-weight: 600; margin-bottom: 7px;
}
.cst-card-value {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.1rem; font-weight: 600; color: var(--ink);
}

/* Table */
.cst-table { width: 100%; border-collapse: collapse; font-size: 0.88rem; margin-bottom: 24px; }
.cst-table th {
  background: var(--forest); color: white;
  padding: 12px 16px; text-align: left;
  font-size: 0.65rem; font-weight: 500;
  letter-spacing: 0.14em; text-transform: uppercase;
}
.cst-table td { padding: 12px 16px; border-bottom: 1px solid var(--border); color: var(--ink-soft); }
.cst-table tr:last-child td { border-bottom: none; }
.cst-table tr:nth-child(even) td { background: var(--ivory); }
.cst-table .cst-amount {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.05rem; font-weight: 700; color: var(--forest);
}

/* Attire two-column */
.cst-attire-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 1px; background: var(--border);
  border: 1px solid var(--border); margin-bottom: 16px;
}
.cst-attire-col { background: var(--white); padding: 24px 20px; }
.cst-attire-col h4 {
  font-size: 0.65rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--gold); font-weight: 600; margin-bottom: 14px;
}

/* Highlight & warning boxes */
.cst-highlight {
  background: var(--warm); border-left: 3px solid var(--gold);
  border-radius: 2px; padding: 16px 20px;
  font-size: 0.88rem; line-height: 1.8; color: var(--ink-soft); margin-bottom: 16px;
}
.cst-warning {
  background: #fff8e1; border-left: 3px solid var(--gold);
  border-radius: 2px; padding: 16px 20px;
  font-size: 0.88rem; line-height: 1.8; color: #5a4200; margin-bottom: 16px;
}

/* Reg badge */
.cst-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--forest); color: var(--gold-lt);
  border-radius: 2px; padding: 8px 16px;
  font-size: 0.72rem; font-weight: 500;
  letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 28px;
}

/* Sub-colour label */
.cst-colour-label {
  font-size: 0.75rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--gold); font-weight: 600; margin: 28px 0 14px;
}

@media (max-width: 640px) {
  .const-content-panel { padding: 40px 20px 80px; }
  .cst-attire-grid { grid-template-columns: 1fr; }
}
