:root {
  --sky: #b7dfea;
  --sky-soft: #dff0f5;
  --nav: #15385b;
  --nav-muted: rgba(21, 56, 91, 0.76);
  --ink: #17304a;
  --body: #5e676c;
  --muted: #7f8d94;
  --panel: #ffffff;
  --pale-panel: #f1f3f8;
  --line: #d9e1e6;
  --dark-gray: #56575b;
  --shadow: 0 12px 32px rgba(25, 52, 74, 0.12);
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  color: var(--ink);
  background: #fff;
  font-family: "Helvetica Neue", Arial, sans-serif;
  letter-spacing: 0;
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input {
  font: inherit;
}

.app-shell {
  min-height: 100vh;
  display: grid;
  grid-template-rows: auto auto 1fr auto;
}

.practice-header {
  background: #fff;
  border-top: 1px solid #d7d7d7;
}

.header-inner {
  max-width: 1460px;
  min-height: 96px;
  margin: 0 auto;
  padding: 20px 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.practice-logo {
  display: grid;
  gap: 4px;
  color: var(--nav);
}

.brand-name {
  font-size: 28px;
  font-weight: 300;
  line-height: 1;
}

.brand-subline {
  color: #908270;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1;
  text-transform: uppercase;
}

.header-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
}

.header-language-switcher {
  margin: 0;
}

.language-options {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--nav);
  background: #fff;
}

.language-options button {
  min-height: 42px;
  border: 0;
  border-right: 1px solid var(--nav);
  background: transparent;
  color: var(--nav);
  padding: 9px 14px;
  font: inherit;
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
  cursor: pointer;
}

.language-options button:last-child {
  border-right: 0;
}

.language-options button.is-active {
  background: var(--nav);
  color: #fff;
}

.language-options button:focus-visible {
  outline: 2px solid var(--sky);
  outline-offset: 2px;
}

.overview-link {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 16px;
  border: 1px solid var(--nav);
  color: var(--nav);
  background: #fff;
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
}

.overview-link:hover,
.overview-link:focus-visible {
  background: var(--nav);
  color: #fff;
  outline: 2px solid transparent;
}

.hero {
  min-height: 260px;
  background: linear-gradient(180deg, #ffffff 0%, #f7fbfc 54%, var(--sky-soft) 100%);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid #cfe4ec;
  position: relative;
  overflow: hidden;
}

.hero::after {
  content: none;
}

.hero-overlay {
  max-width: 1460px;
  margin: 0 auto;
  min-height: 260px;
  padding: 50px 48px 58px;
  display: grid;
  align-content: center;
  justify-items: start;
  color: var(--nav);
}

.hero-overlay p {
  margin: 0 0 8px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 700;
  font-size: 13px;
  color: #908270;
}

.hero-overlay h1 {
  margin: 0;
  font-size: clamp(34px, 4vw, 58px);
  line-height: 1.04;
  font-weight: 300;
}

.portal-page {
  background: #fff;
}

.topic-band {
  background: var(--sky);
  min-height: 260px;
  position: relative;
}

.topic-band::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -1px;
  transform: translateX(-50%);
  border-left: 22px solid transparent;
  border-right: 22px solid transparent;
  border-bottom: 22px solid #fff;
}

.topic-inner {
  max-width: 1460px;
  margin: 0 auto;
  padding: 54px 48px;
  display: grid;
  grid-template-columns: minmax(500px, 1fr) minmax(360px, 520px);
  gap: 70px;
  align-items: start;
}

.topic-title {
  display: block;
  color: #fff;
  padding-left: 24px;
  border-left: 4px solid rgba(255, 255, 255, 0.82);
}

.label,
.breadcrumb,
.section-kicker {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
}

.label {
  margin: 0 0 7px;
  color: rgba(255, 255, 255, 0.84);
  font-size: 13px;
}

.topic-title h2 {
  margin: 0;
  font-size: clamp(28px, 3.2vw, 42px);
  line-height: 1.05;
  font-weight: 300;
}

.topic-nav {
  display: grid;
  gap: 12px;
}

.segment {
  display: block;
  border: 0;
  background: transparent;
  color: var(--nav);
  min-height: 42px;
  padding: 10px 14px;
  text-align: left;
  text-transform: uppercase;
  font-weight: 600;
  font-size: 15px;
  cursor: pointer;
  text-decoration: none;
}

.segment.is-active,
.overview-segment:hover,
.overview-segment:focus-visible {
  background: var(--nav);
  color: #fff;
  outline: 2px solid transparent;
}

.breadcrumb {
  max-width: 1460px;
  margin: 0 auto;
  padding: 16px 48px 0;
  color: #9aa8af;
  font-size: 12px;
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.breadcrumb a {
  color: var(--nav);
  text-decoration: underline;
}

.workspace {
  max-width: 1460px;
  margin: 0 auto;
  padding: 46px 48px 54px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 300px;
  gap: 42px;
  align-items: start;
}

.card-meta {
  display: none;
}

.detail {
  min-width: 0;
}

.detail-head {
  position: relative;
  padding-bottom: 20px;
  border-bottom: 1px solid #e3e7ea;
}

.section-kicker {
  color: var(--nav);
  font-size: 20px;
  margin: 0 0 54px;
}

.detail-head h3 {
  margin: 0 0 18px;
  color: var(--sky);
  font-size: 20px;
  line-height: 1.2;
  text-transform: uppercase;
  font-weight: 700;
}

.summary {
  color: var(--body);
  font-size: 18px;
  line-height: 1.45;
  margin: 0;
}

.status-badge {
  position: absolute;
  right: 0;
  top: 0;
  color: var(--muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.info-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin: 26px 0;
}

.info-box {
  border-top: 2px solid var(--nav);
  padding-top: 13px;
}

.info-box h4 {
  margin: 0 0 10px;
  color: var(--nav);
  font-size: 15px;
  text-transform: uppercase;
}

.info-box p,
.info-box li {
  color: var(--body);
  font-size: 16px;
  line-height: 1.45;
}

.info-box p,
.info-box ul {
  margin: 0;
}

.info-box ul {
  padding-left: 18px;
}

.content-tabs {
  position: sticky;
  top: 0;
  z-index: 5;
  margin: 24px 0 24px;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.96);
  display: none;
  align-items: center;
  gap: 0;
  overflow-x: auto;
}

.content-tabs a {
  padding: 13px 15px;
  color: var(--nav);
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  white-space: nowrap;
  border-right: 1px solid var(--line);
}

.content-tabs a:hover {
  background: var(--sky-soft);
}

.portal-content {
  display: grid;
  gap: 34px;
}

.content-section {
  scroll-margin-top: 72px;
}

.section-heading {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: 12px;
  align-items: baseline;
  margin-bottom: 16px;
  border-bottom: 2px solid var(--nav);
  padding-bottom: 7px;
}

.section-heading p {
  margin: 0;
  color: var(--sky);
  font-size: 21px;
  font-weight: 700;
}

.section-heading h4 {
  margin: 0;
  color: var(--nav);
  font-size: 18px;
  line-height: 1.25;
  text-transform: uppercase;
}

.fact-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 20px;
}

.fact-card {
  background: var(--sky-soft);
  border-left: 4px solid var(--sky);
  padding: 13px 14px;
  min-height: 94px;
}

.fact-card span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 0.06em;
  margin-bottom: 8px;
}

.fact-card strong {
  display: block;
  color: var(--nav);
  font-size: 15px;
  line-height: 1.25;
}

.text-block-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.text-block-grid article {
  border: 1px solid var(--line);
  padding: 16px;
  background: #fff;
}

.text-block-grid h5 {
  margin: 0 0 9px;
  color: var(--sky);
  font-size: 15px;
  line-height: 1.25;
  text-transform: uppercase;
}

.text-block-grid p {
  margin: 0;
  color: var(--body);
  font-size: 16px;
  line-height: 1.5;
}

.schema-card {
  margin: 22px 0 0;
  border: 1px solid var(--line);
  background: #fff;
  box-shadow: 0 10px 26px rgba(25, 52, 74, 0.08);
  padding: 18px;
}

.implant-schema {
  display: block;
  width: 100%;
  height: auto;
  max-height: 620px;
}

.schema-card figcaption {
  margin: 12px 0 0;
  padding-top: 10px;
  border-top: 1px solid var(--line);
  color: var(--body);
  font-size: 15px;
  line-height: 1.45;
}

.visual-launcher {
  border: 1px solid var(--line);
  background: #f7fbfc;
  padding: 18px;
  margin: 20px 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: center;
}

.visual-kicker {
  display: block;
  color: var(--sky);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  margin-bottom: 7px;
}

.visual-launcher h3 {
  margin: 0 0 7px;
  color: var(--nav);
  font-size: 18px;
}

.visual-launcher p {
  margin: 0;
  color: var(--body);
  line-height: 1.45;
}

.visual-actions {
  display: grid;
  gap: 8px;
  min-width: 190px;
}

.visual-link,
.visual-controls button,
.visual-close {
  font: inherit;
}

.visual-link {
  border: 1px solid var(--nav);
  background: #fff;
  color: var(--nav);
  padding: 10px 12px;
  text-align: left;
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
  cursor: pointer;
}

.visual-link:hover,
.visual-link:focus-visible {
  background: var(--nav);
  color: #fff;
}

.has-visual-modal {
  overflow: hidden;
}

.visual-modal {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 28px;
}

.visual-modal.is-open {
  display: flex;
}

.visual-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(9, 21, 34, 0.72);
}

.visual-dialog {
  position: relative;
  z-index: 1;
  width: min(1120px, calc(100vw - 44px));
  max-height: calc(100vh - 44px);
  overflow: auto;
  background: #fff;
  border: 1px solid var(--nav);
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.34);
  padding: 20px;
}

.visual-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 38px;
  height: 38px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--nav);
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
}

.visual-copy {
  padding-right: 50px;
  margin-bottom: 14px;
}

.visual-copy h3 {
  margin: 0 0 8px;
  color: var(--nav);
  font-size: 24px;
}

.visual-copy p {
  max-width: 860px;
  margin: 0;
  color: var(--body);
  line-height: 1.5;
}

.visual-frame {
  margin: 0;
  border: 1px solid var(--line);
  background: #f5f7f8;
}

.visual-frame img {
  display: block;
  width: 100%;
  max-height: 68vh;
  object-fit: contain;
  background: #edf4f6;
}

.visual-frame figcaption {
  padding: 12px 14px;
  color: var(--nav);
  font-weight: 700;
  line-height: 1.4;
  border-top: 1px solid var(--line);
  background: #fff;
}

.visual-controls {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-top: 14px;
}

.visual-controls button {
  border: 1px solid var(--nav);
  background: var(--nav);
  color: #fff;
  padding: 10px 14px;
  font-weight: 800;
  text-transform: uppercase;
  cursor: pointer;
}

.visual-controls button:disabled {
  opacity: 0.38;
  cursor: default;
}

.visual-controls span {
  color: var(--body);
  font-weight: 800;
}

.gingiva {
  fill: #d9edf2;
  stroke: #9dcbd8;
  stroke-width: 3;
}

.bone {
  fill: #eef6f8;
  stroke: #b8d9e2;
  stroke-width: 3;
}

.bone-lines {
  fill: none;
  stroke: #d1e5eb;
  stroke-width: 4;
  stroke-linecap: round;
}

.crown {
  fill: url("#crownShade");
  stroke: var(--nav);
  stroke-width: 4;
}

.crown-detail {
  fill: none;
  stroke: #a8c7d2;
  stroke-width: 3;
  stroke-linecap: round;
}

.abutment {
  fill: url("#metalShade");
  stroke: var(--nav);
  stroke-width: 4;
  stroke-linejoin: round;
}

.abutment-highlight {
  fill: rgba(255, 255, 255, 0.55);
}

.implant-body {
  fill: url("#metalShade");
}

.implant-thread-fill {
  fill: url("#threadPattern");
  opacity: 0.58;
}

.implant-outline {
  fill: none;
  stroke: var(--nav);
  stroke-width: 4;
}

.screw {
  fill: #dbe7ec;
  stroke: #405d72;
  stroke-width: 3;
}

.screw-head {
  fill: #f8fbfc;
  stroke: #405d72;
  stroke-width: 3;
}

.screw-slot {
  fill: none;
  stroke: #405d72;
  stroke-width: 4;
  stroke-linecap: round;
}

.labels path {
  fill: none;
  stroke: var(--nav);
  stroke-width: 2.5;
  stroke-linecap: round;
}

.labels text {
  fill: var(--nav);
  font-family: "Helvetica Neue", Arial, sans-serif;
  font-size: 20px;
  font-weight: 700;
}

.timeline {
  list-style: none;
  counter-reset: step;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 11px;
}

.timeline li {
  counter-increment: step;
  display: grid;
  grid-template-columns: 172px minmax(0, 1fr);
  gap: 16px;
  border: 1px solid var(--line);
  background: #fff;
  padding: 13px 15px;
  position: relative;
}

.timeline li::before {
  content: counter(step, decimal-leading-zero);
  position: absolute;
  left: -1px;
  top: -1px;
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  background: var(--nav);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
}

.timeline span {
  padding-left: 34px;
  color: var(--nav);
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1.3;
}

.timeline p {
  margin: 0;
  color: var(--body);
  line-height: 1.45;
}

table {
  width: 100%;
  border-collapse: collapse;
  margin: 0;
  color: var(--body);
  font-size: 15px;
  line-height: 1.4;
}

th {
  background: var(--nav);
  color: #fff;
  padding: 10px 12px;
  text-align: left;
  font-weight: 700;
}

td {
  border: 1px solid var(--line);
  padding: 11px 12px;
  vertical-align: top;
}

tr:nth-child(even) td {
  background: #f8fbfc;
}

.risk-table th:first-child,
.risk-table td:first-child {
  width: 30%;
  color: var(--nav);
  font-weight: 700;
}

.ana-table th:first-child,
.ana-table td:first-child {
  width: 20%;
  color: var(--nav);
  font-weight: 700;
}

.ana-table th:nth-child(2),
.ana-table td:nth-child(2) {
  width: 58%;
}

.ana-table th:nth-child(3),
.ana-table td:nth-child(3) {
  width: 22%;
}

.pain-table {
  margin-top: 18px;
}

.aftercare-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.aftercare-list li {
  border: 1px solid var(--line);
  padding: 12px 14px 12px 38px;
  color: var(--body);
  line-height: 1.4;
  position: relative;
}

.aftercare-list li::before {
  content: "□";
  position: absolute;
  left: 15px;
  top: 12px;
  color: var(--nav);
}

.callout {
  margin-top: 18px;
  padding: 16px 18px;
  background: var(--sky-soft);
  border-left: 5px solid var(--sky);
}

.callout.warning {
  background: #f2f3f5;
  border-left-style: dashed;
  border-left-color: var(--nav);
}

.callout strong {
  display: block;
  color: var(--nav);
  margin-bottom: 6px;
}

.callout p {
  margin: 0;
  color: var(--body);
  line-height: 1.45;
}

.faq-list {
  display: grid;
  gap: 10px;
}

.faq-list details {
  border: 1px solid var(--line);
  background: #fff;
}

.faq-list summary {
  cursor: pointer;
  padding: 13px 15px;
  color: var(--nav);
  font-weight: 700;
}

.faq-list p {
  margin: 0;
  padding: 0 15px 15px;
  color: var(--body);
  line-height: 1.45;
}

.source-section {
  padding-top: 8px;
}

.source-full-content {
  margin-top: 18px;
  border: 1px solid var(--line);
  background: #fff;
  padding: 26px;
}

.source-content-inner {
  display: block;
}

.source-page {
  padding: 0;
  border-bottom: 0;
  color: var(--body);
  font-size: 15px;
  line-height: 1.48;
}

.source-page + .source-page {
  margin-top: 18px;
}

.source-page h1,
.source-page h2,
.source-page h3,
.source-page h4 {
  color: var(--nav);
  line-height: 1.2;
}

.source-page h1 {
  font-size: 25px;
  margin: 0 0 18px;
}

.source-page h2 {
  margin: 24px 0 12px;
  padding-bottom: 6px;
  border-bottom: 2px solid var(--nav);
  font-size: 20px;
  text-transform: uppercase;
}

.source-page h3,
.source-page h4 {
  margin: 16px 0 8px;
  font-size: 16px;
}

.source-page p {
  margin: 0 0 12px;
}

.source-page ul,
.source-page ol {
  margin: 0 0 14px;
  padding-left: 22px;
}

.source-page li {
  margin-bottom: 6px;
}

.source-page table {
  margin: 12px 0 18px;
}

.source-page .row,
.source-page .grid2,
.source-page .grid-2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 12px 0;
}

.source-page .row-3,
.source-page .grid3,
.source-page .grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.source-page .row-13 {
  grid-template-columns: minmax(0, 1fr);
}

.source-page .timeline {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 12px 0 4px;
  padding: 0;
}

.source-page .timeline::before {
  display: none;
}

.source-page .tl-item {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr);
  grid-template-rows: auto 1fr;
  gap: 4px 10px;
  align-items: start;
  min-width: 0;
  border: 1px solid var(--line);
  background: #fff;
  padding: 11px 10px;
  text-align: left;
}

.source-page .tl-day {
  width: 44px;
  height: 44px;
  grid-row: 1 / span 2;
  margin: 0;
  display: grid;
  place-items: center;
  border: 2px solid var(--nav);
  background: var(--sky-soft);
  color: var(--nav);
  font-weight: 800;
  font-size: 15px;
  line-height: 1;
}

.source-page .tl-label {
  grid-column: 2;
  color: var(--sky);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.source-page .tl-text {
  grid-column: 2;
  border: 0;
  background: transparent;
  padding: 0;
  color: var(--body);
  font-size: 14px;
  line-height: 1.42;
  text-align: left;
}

.source-page .card,
.source-page .rule-card,
.source-page .faq-item,
.source-page .tip,
.source-page .caution,
.source-page .warning,
.source-page .warn,
.source-page .intro-box,
.source-page .info-box,
.source-page .kazanjian-box,
.source-page .summary-box,
.source-page .provisorium-box {
  border: 1px solid var(--line);
  background: #fff;
  padding: 13px 15px;
  margin: 10px 0;
}

.source-page .tip,
.source-page .intro-box {
  background: var(--sky-soft);
  border-left: 5px solid var(--sky);
}

.source-page .caution,
.source-page .warning,
.source-page .warn {
  background: #f3f4f6;
  border-left: 5px dashed var(--nav);
}

.source-page .notruf,
.source-page .em-notruf,
.source-page .call {
  background: var(--nav);
  color: #fff;
  padding: 14px 16px;
  margin: 14px 0;
  font-weight: 700;
}

.source-page .notruf *,
.source-page .em-notruf *,
.source-page .call * {
  color: #fff;
}

.source-page .card-title,
.source-page .faq-q,
.source-page .risk-head,
.source-page .vork-title,
.source-page .kaz-title,
.source-page .summary-title,
.source-page .provisorium-title {
  color: var(--nav);
  font-weight: 700;
  margin-bottom: 6px;
}

.source-page .flow,
.source-page .two-col,
.source-page .three-col,
.source-page .rules-grid,
.source-page .implant-basics-grid,
.source-page .risk-grid,
.source-page .risiko-grid,
.source-page .vork-grid,
.source-page .faq-grid,
.source-page .checklist-grid,
.source-page .summary-grid,
.source-page .check-grid,
.source-page .steps-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 12px 0;
}

.source-page .three-col,
.source-page .row-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.source-page .flow-5 {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.source-page .flow-step,
.source-page .step,
.source-page .timeline-item,
.source-page .implant-basics-item,
.source-page .risk-card,
.source-page .risiko-item,
.source-page .vork-item,
.source-page .check-item {
  border: 1px solid var(--line);
  padding: 12px;
  background: #fff;
}

.source-page .risiko-head {
  display: block;
  color: var(--nav);
  font-weight: 800;
  margin-bottom: 7px;
  padding-bottom: 5px;
  border-bottom: 1px solid var(--line);
}

.source-page .risiko-text {
  color: var(--body);
  font-size: 14px;
  line-height: 1.5;
}

.source-page .ib-head {
  display: block;
  color: var(--nav);
  font-weight: 800;
  margin-bottom: 7px;
  padding-bottom: 5px;
  border-bottom: 1px solid var(--line);
}

.source-page .implant-basics-item p {
  margin: 0;
  color: var(--body);
  font-size: 14px;
  line-height: 1.5;
}

.source-page .flow-num,
.source-page .num,
.source-page .sn,
.source-page .notruf-num {
  color: var(--nav);
  font-weight: 700;
}

.source-content-inner[data-procedure="implantat"] .source-page .row-2 {
  grid-template-columns: minmax(0, 1fr);
}

.source-content-inner[data-procedure="implantat"] .source-page .check-grid,
.source-content-inner[data-procedure="implantat"] .source-page .implant-basics-grid,
.source-content-inner[data-procedure="implantat"] .source-page .steps-list,
.source-content-inner[data-procedure="implantat"] .source-page .summary-grid {
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.source-content-inner[data-procedure="implantat"] .source-page .implant-basics-grid {
  gap: 10px;
}

.source-content-inner[data-procedure="implantat"] .source-page .summary-grid {
  column-gap: 34px;
  row-gap: 12px;
}

.source-content-inner[data-procedure="implantat"] .source-page .check-grid {
  column-gap: 34px;
  row-gap: 14px;
}

.source-content-inner[data-procedure="implantat"] .source-page .steps-list {
  list-style: none;
  padding-left: 0;
}

.source-content-inner[data-procedure="implantat"] .source-page .steps-list .sn {
  display: inline-block;
  min-width: 1.35em;
  margin-right: 0.25em;
}

.source-content-inner[data-procedure="implantat"] .source-page .flow-5 {
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.source-content-inner[data-procedure="implantat"] .source-page .risk-grid,
.source-content-inner[data-procedure="implantat"] .source-page .risiko-grid,
.source-content-inner[data-procedure="implantat"] .source-page .faq-grid {
  grid-template-columns: repeat(auto-fit, minmax(270px, 1fr));
}

.source-content-inner[data-procedure="implantat"] .source-page .risiko-grid {
  gap: 10px;
}

.source-loading,
.source-error {
  padding: 18px;
  color: var(--body);
}

.source-error a {
  display: inline-block;
  margin-left: 8px;
  color: var(--nav);
  text-decoration: underline;
}

.source-embed-note {
  margin-bottom: 14px;
  padding: 12px 14px;
  border-left: 5px solid var(--sky);
  background: var(--sky-soft);
  color: var(--body);
  font-size: 14px;
  line-height: 1.45;
}

.source-embed-note code {
  color: var(--nav);
  font-weight: 700;
}

.source-frame {
  width: 100%;
  min-height: 1180px;
  border: 1px solid var(--line);
  background: #fff;
}

.empty-state {
  color: var(--body);
  line-height: 1.45;
}

.section-nav {
  display: grid;
  gap: 0;
  padding: 8px 0 8px;
}

.section-nav a {
  display: block;
  margin: 0 16px;
  padding: 8px 8px;
  border-bottom: 1px solid rgba(111, 122, 131, 0.22);
  color: #4f626f;
  text-decoration: none;
  font-size: 16px;
  line-height: 1.25;
}

.section-nav a:hover,
.section-nav a:focus-visible {
  background: rgba(21, 56, 91, 0.08);
  color: var(--nav);
  outline: 2px solid transparent;
}

.more-info {
  background: var(--pale-panel);
  color: #6f7a83;
  position: sticky;
  top: 18px;
}

.more-head {
  background: var(--dark-gray);
  color: #fff;
  padding: 10px 16px;
  font-size: 18px;
  font-weight: 700;
}

.overview-panel-link {
  display: block;
  margin: 13px 16px 4px;
  padding: 0 8px 10px;
  border-bottom: 1px solid rgba(111, 122, 131, 0.22);
  color: var(--nav);
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
}

.overview-panel-link:hover,
.overview-panel-link:focus-visible {
  color: #0f2b47;
  outline: 2px solid transparent;
}

.more-info button {
  display: block;
  width: calc(100% - 32px);
  margin: 11px 16px 0;
  border: 0;
  border-bottom: 1px solid rgba(111, 122, 131, 0.38);
  background: transparent;
  color: #697883;
  text-align: left;
  text-decoration: none;
  padding: 4px 8px 7px;
  cursor: pointer;
  font-size: 16px;
}

.more-info button[hidden] {
  display: none !important;
}

.more-info button::before {
  content: "▣ ";
  text-decoration: none;
}

.more-info button:hover,
.more-info button:focus-visible {
  background: rgba(21, 56, 91, 0.08);
  color: var(--nav);
  outline: 2px solid transparent;
}

.source-link {
  display: block;
  margin: 18px 16px 0;
  padding: 4px 8px;
  color: #4f626f;
  text-decoration: none;
  font-size: 14px;
}

.source-link:hover,
.source-link:focus-visible {
  background: rgba(21, 56, 91, 0.08);
  color: var(--nav);
  outline: 2px solid transparent;
}

.source-link[hidden] {
  display: none !important;
}

.emergency {
  margin: 20px 16px 18px;
  padding: 13px 14px;
  background: var(--nav);
  color: #fff;
}

.emergency > strong {
  display: block;
  margin-bottom: 8px;
}

.emergency p {
  margin: 0;
  font-size: 14px;
  line-height: 1.45;
}

.footer {
  border-top: 1px solid var(--line);
  padding: 18px 48px;
  color: #7a858c;
  display: flex;
  justify-content: space-between;
  gap: 24px;
  font-size: 13px;
}

@media (max-width: 1180px) {
  .header-inner {
    gap: 22px;
  }

  .workspace {
    grid-template-columns: minmax(0, 1fr);
  }

  .more-info {
    grid-column: 1 / -1;
    max-width: 520px;
    position: static;
  }

  .content-tabs {
    display: flex;
  }

  .fact-grid,
  .text-block-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  .header-inner,
  .hero-overlay,
  .topic-inner,
  .breadcrumb,
  .workspace,
  .footer {
    padding-left: 20px;
    padding-right: 20px;
  }

  .hero {
    min-height: 240px;
  }

  .hero-overlay {
    min-height: 240px;
  }

  .header-inner {
    align-items: start;
    display: grid;
  }

  .header-actions {
    justify-content: start;
  }

  .topic-inner,
  .workspace,
  .info-grid,
  .fact-grid,
  .text-block-grid,
  .aftercare-list {
    grid-template-columns: 1fr;
  }

  .timeline li {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .source-page {
    padding: 0;
  }

  .source-full-content {
    padding: 16px;
  }

  .visual-launcher {
    grid-template-columns: 1fr;
  }

  .visual-actions {
    min-width: 0;
  }

  .visual-modal {
    padding: 12px;
  }

  .visual-dialog {
    width: calc(100vw - 24px);
    max-height: calc(100vh - 24px);
    padding: 14px;
  }

  .visual-copy {
    padding-right: 44px;
  }

  .visual-copy h3 {
    font-size: 20px;
  }

  .source-page .flow,
  .source-page .row,
  .source-page .row-2,
  .source-page .row-3,
  .source-page .grid2,
  .source-page .grid3,
  .source-page .grid-2,
  .source-page .grid-3,
  .source-page .two-col,
  .source-page .three-col,
  .source-page .rules-grid,
  .source-page .risk-grid,
  .source-page .vork-grid,
  .source-page .faq-grid,
  .source-page .checklist-grid,
  .source-page .summary-grid,
  .source-page .check-grid,
  .source-page .steps-list,
  .source-page .flow-5 {
    grid-template-columns: 1fr;
  }

  .source-page .timeline {
    grid-template-columns: 1fr;
    gap: 10px;
    padding-top: 0;
  }

  .source-page .timeline::before {
    display: none;
  }

  .source-page .tl-item {
    grid-template-columns: 54px minmax(0, 1fr);
    grid-template-rows: auto 1fr;
    text-align: left;
    align-items: start;
  }

  .source-page .tl-day {
    grid-row: 1 / span 2;
    margin: 0;
  }

  .source-page .tl-label,
  .source-page .tl-text {
    grid-column: 2;
  }

  .source-page .tl-text {
    text-align: left;
  }

  .footer {
    display: grid;
  }
}

@media print {
  .practice-header,
  .hero,
  .topic-band,
  .breadcrumb,
  .more-info,
  .content-tabs,
  .visual-launcher,
  .visual-modal,
  .footer {
    display: none !important;
  }

  .workspace {
    display: block;
    max-width: none;
    padding: 0;
  }

  .detail {
    padding: 18mm;
  }

  .content-section {
    page-break-inside: avoid;
  }
}
