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

:root {
    --dark: #1f4b50;
    --deeper: #0d2b2e;
    --mid: #2d6b72;
    --tint: #5aa8b2;
    --light: #a8d5da;
    --pale: #dff0f2;
    --bg: #f5fafb;
    --acc: #d97b2a;
    --acc-l: #e8993f;
    --acc-pale: #fdf0e0;
    --ink: #0d1f21;
    --gray: #5a6e70;
    --border: #c8dfe2;
    --font-d: 'Playfair Display', Georgia, serif;
    --font-b: 'Source Sans 3', system-ui, sans-serif;
}

.toc-links a.primary:hover {
    background: var(--deeper);
}

.toc-links a.secondary:hover {
  background: var(--border);
}

.toc-links svg {
    width: 13px;
    height: 13px;
    flex-shrink: 0;
}

body {
    font-family: var(--font-b);
    background: var(--bg);
    color: var(--ink);
    line-height: 1.7
}

/* ── PAGE HEADER ── */
.page-header {
    background: linear-gradient(140deg, var(--dark) 0%, var(--deeper) 100%);
    padding: 3rem 2rem 4.5rem;
    position: relative;
    overflow: hidden
}

.page-header::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 10% 80%, rgba(90, 168, 178, .1) 0%, transparent 55%), radial-gradient(circle at 90% 15%, rgba(217, 123, 42, .07) 0%, transparent 50%);
    pointer-events: none
}

.ph-inner {
    max-width: 1100px;
  margin: -2rem auto 0;
  position: relative;
  padding: 0 2rem;
}

.ph-inner-container {
  padding: 0 2.75rem;
}

.ph-label {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: rgba(255, 255, 255, .1);
    border: 1px solid rgba(255, 255, 255, .18);
    padding: .35rem .9rem;
    border-radius: 2rem;
    color: rgba(255, 255, 255, .7);
    font-size: .78rem;
    font-weight: 600;
    letter-spacing: .04em;
    margin-bottom: 1.25rem
}

.ph-label svg {
    width: 13px;
    height: 13px
}

.page-header h1 {
    font-family: var(--font-d);
    font-size: clamp(1.9rem, 4vw, 2.8rem);
    font-weight: 900;
    color: #fff;
    line-height: 1.15;
    margin-bottom: .75rem
}

.ph-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    font-size: .85rem;
    color: rgba(255, 255, 255, .5);
    margin-top: .5rem
}

.ph-meta span {
    display: flex;
    align-items: center;
    gap: .35rem
}

.ph-meta svg {
    width: 14px;
    height: 14px
}

/* ── LAYOUT ── */
.main-wrap {
    max-width: 1100px;
    margin: -2rem auto 3rem;
    padding: 0 2rem;
    display: grid;
    grid-template-columns: 1fr 260px;
    gap: 2.5rem;
    align-items: start
}

.policy-content {
    background: #fff;
    border-radius: 1rem;
    border: 1px solid var(--border);
    padding: 2.5rem 2.75rem
}

.sidebar {
    position: sticky;
    top: calc(88px + 1.5rem)
}

/* ── TOC SIDEBAR ── */
.toc {
    background: #fff;
    border-radius: 1rem;
    border: 1px solid var(--border);
    padding: 1.25rem
}

.toc-title {
    font-size: .82rem;
    font-weight: 700;
    color: var(--gray);
    text-transform: uppercase;
    letter-spacing: .08em;
    margin-bottom: .85rem
}

.toc-list {
    list-style: none
}

.toc-list li {
    margin-bottom: .15rem
}

.toc-list a {
    display: block;
    font-size: .82rem;
    color: var(--gray);
    text-decoration: none;
    padding: .3rem .5rem;
    border-radius: .4rem;
    border-left: 2px solid transparent;
    transition: all .2s;
    line-height: 1.4
}

.toc-list a:hover {
    color: var(--dark);
    background: var(--pale);
    border-left-color: var(--tint)
}

.toc-list a.active {
    color: var(--dark);
    font-weight: 600;
    background: var(--pale);
    border-left-color: var(--dark)
}

.toc-dl {
    background: var(--pale);
    border-radius: .75rem;
    padding: 1rem;
    margin-top: 1rem;
    text-align: center
}

.toc-dl p {
    font-size: .78rem;
    color: var(--gray);
    margin-bottom: .6rem
}

.toc-dl a {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .55rem 1rem;
    background: var(--dark);
    color: #fff;
    border-radius: 7px;
    text-decoration: none;
    font-size: .8rem;
    font-weight: 600;
    transition: background .2s
}

.toc-dl a:hover {
    background: var(--deeper)
}

.toc-dl svg {
    width: 13px;
    height: 13px
}

/* ── POLICY CONTENT ── */
.policy-content h2 {
    font-family: var(--font-d);
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--deeper);
    margin: 2.5rem 0 .75rem;
    padding-top: .5rem;
    border-top: 1px solid var(--pale)
}

.policy-content h2:first-child {
    margin-top: 0;
    border-top: none
}

.policy-content h3 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--dark);
    margin: 1.5rem 0 .5rem
}

.policy-content p {
    font-size: .95rem;
    color: #2a3a3c;
    margin-bottom: .85rem;
    line-height: 1.75
}

.policy-content ul {
    margin: .5rem 0 .85rem 1.25rem
}

.policy-content ul li {
    font-size: .95rem;
    color: #2a3a3c;
    margin-bottom: .4rem;
    line-height: 1.65
}

.policy-content ul li ul {
    margin: .25rem 0 .25rem 1.25rem
}

.policy-content ul li ul li {
    font-size: .88rem;
    color: var(--gray)
}

.policy-content a {
    color: var(--dark);
    font-weight: 500
}

.policy-content a:hover {
    color: var(--mid)
}

.policy-content strong {
    font-weight: 600;
    color: var(--ink)
}

/* ── INFO BOX ── */
.info-box {
    border-left: 3px solid var(--acc);
    background: var(--acc-pale);
    border-radius: 0 .75rem .75rem 0;
    padding: 1rem 1.25rem;
    margin: 1rem 0 1.25rem;
    font-size: .9rem;
    color: #4a2e0d
}

.info-box p {
    margin-bottom: .3rem;
    color: #4a2e0d
}

.info-box p:last-child {
    margin-bottom: 0
}

.info-box.teal {
    border-left-color: var(--tint);
    background: var(--pale);
    color: var(--deeper)
}

.info-box.teal p {
    color: var(--deeper)
}

.no-box {
    border-left: 3px solid var(--red, #ef4444);
    background: #fef2f2;
    border-radius: 0 .75rem .75rem 0;
    padding: 1rem 1.25rem;
    margin: 1rem 0 1.25rem;
    font-size: .9rem
}

.no-box p {
    color: #7f1d1d;
    margin-bottom: .3rem
}

.no-box p:last-child {
    margin-bottom: 0
}

.no-box strong {
    color: #991b1b
}

/* ── TABLES ── */
.tbl-wrap {
    overflow-x: auto;
    margin: 1rem 0 1.25rem;
    border-radius: .75rem;
    border: 1px solid var(--border)
}

table {
    width: 100% !important;
    border-collapse: collapse !important;
    font-size: .88rem;
    table-layout: fixed;
}

thead tr {
    background: var(--dark);
    color: #fff
}

thead th {
    padding: .75rem 1rem;
    text-align: left;
    font-weight: 600;
    font-size: .82rem;
    letter-spacing: .03em;
    word-break: break-word;
    overflow-wrap: break-word;
}

tbody tr {
    border-bottom: 1px solid var(--pale)
}

tbody tr:last-child {
    border-bottom: none
}

tbody tr:nth-child(even) {
    background: #f8fcfc
}

tbody td {
    padding: .75rem 1rem;
    color: #2a3a3c;
    line-height: 1.55;
    word-break: break-word;
    overflow-wrap: break-word;
}

tbody td:first-child {
    font-weight: 500;
    color: var(--deeper)
}

/* ── HIGHLIGHT DATE ── */
.doc-version {
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    padding: 1rem 1.25rem;
    background: var(--pale);
    border-radius: .75rem;
    margin-bottom: 2rem;
    font-size: .85rem
}

.doc-version span {
    display: flex;
    align-items: center;
    gap: .4rem;
    color: var(--gray)
}

.doc-version svg {
    width: 14px;
    height: 14px;
    color: var(--tint);
    flex-shrink: 0
}

.doc-version strong {
    color: var(--darker, var(--ink))
}

/* ── SECTION ANCHOR ── */
.section-anchor {
    scroll-margin-top: calc(88px + 1.5rem)
}

.key-box {
  background: linear-gradient(135deg,var(--pale) 0%,#fff 100%);
  border: 1px solid var(--border);
  border-radius: 1rem;
  padding: 1.25rem 1.5rem;
  margin: 1.25rem 0;
}

.toc-links {
  margin-top: 1rem;
  display: flex;
  flex-direction: column;
  gap: .5rem;
}
.toc-links a.primary {
  background: var(--dark);
  color: #fff;
}
.toc-links a {
  display: flex;
  align-items: center;
  gap: .4rem;
  padding: .55rem .85rem;
  border-radius: 8px;
  text-decoration: none;
  font-size: .8rem;
  font-weight: 600;
  transition: all .2s;
}

.toc-links a.secondary {
  background: var(--pale);
  color: var(--dark);
  border: 1px solid var(--border);
}


@media(max-width:900px) {
    .main-wrap {
        grid-template-columns: 1fr;
        gap: 1.5rem
    }

    .sidebar {
        position: static
    }

    .policy-content {
        padding: 1.5rem
    }
}

@media(max-width:640px) {
    .main-wrap {
        padding: 0 1rem
    }

    .tbl-wrap {
        font-size: .8rem
    }

     .levels-grid {
    grid-template-columns: 1fr
  }

  .page-header {
  background: linear-gradient(140deg, var(--dark) 0%, var(--deeper) 100%);
  padding: 3rem 0 4.5rem;
  }

  .ph-inner {
  padding: 0 1.5rem;
}
}

/* ── LEVELS TABLE ── */

.levels-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: .85rem;
  margin: 1rem 0 1.25rem
}

.level-card {
  border: 1px solid var(--border);
  border-radius: .85rem;
  overflow: hidden
}

.level-card-hdr {
  background: var(--dark);
  padding: .65rem 1rem
}

.level-card-hdr h4 {
  font-size: .85rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: .15rem
}

.level-card-hdr p {
  font-size: .75rem;
  color: var(--light)
}

.level-card-body {
  padding: .85rem 1rem;
  font-size: .82rem;
  color: var(--gray)
}

.level-card-body li {
  margin-bottom: .25rem;
  list-style: none;
  display: flex;
  gap: .4rem
}

.level-card-body li::before {
  content: '✓';
  color: var(--tint);
  font-weight: 700;
  flex-shrink: 0
}
