@import url("https://fonts.googleapis.com/css2?family=Comfortaa:wght@400;700&display=swap");

@font-face {
  font-family: "DCL Myanmar Fallback";
  src: url("/wp-content/themes/twentytwentyfive/assets/fonts/literata/Literata72pt-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "DCL Myanmar Fallback";
  src: url("/wp-content/themes/twentytwentyfive/assets/fonts/literata/Literata72pt-SemiBold.woff2") format("woff2");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

:root {
  --dcl-navy: #8b3a57;
  --dcl-slate: #b26c67;
  --dcl-midnight: #703149;
  --dcl-peach: #f5dbd6;
  --dcl-terra: #b26c67;
  --dcl-brand-green: #4f7d56;
  --dcl-brand-blush: #f5dbd6;
  --dcl-green: #0cd963;
  --dcl-green-hover: #049542;
  --dcl-light: #fef3f0;
  --dcl-white: #ffffff;
  --dcl-ink: #5a2a3d;
  --dcl-muted: #7b4d62;
  --font-heading: "Myanmar MN", "DCL Myanmar Fallback", "Times New Roman", Georgia, serif;
  --font-body: "Myanmar MN", "DCL Myanmar Fallback", "Times New Roman", Georgia, serif;
  --font-button: "Comfortaa", "Trebuchet MS", "Segoe UI", sans-serif;
  --dcl-radius: 24px;
  --dcl-shadow: 0 20px 48px rgba(90, 42, 61, 0.16);
  --dcl-content-max: 1180px;
  --dcl-content-gutter: clamp(20px, 4vw, 56px);
}

/* Remove header e footer do tema apenas na pagina da landing (shortcode). */
body.dcl-landing-page .wp-site-blocks > header.wp-block-template-part,
body.dcl-landing-page .wp-site-blocks > header,
body.dcl-landing-page .wp-site-blocks > footer.wp-block-template-part,
body.dcl-landing-page .wp-site-blocks > footer,
body.dcl-landing-page .wp-site-blocks > .wp-block-template-part,
body.dcl-landing-page .wp-site-blocks > .wp-block-template-part:first-child,
body.dcl-landing-page .wp-site-blocks > .wp-block-template-part:last-child {
  display: none !important;
}

/* Remove espacamentos herdados do template para a landing ocupar a largura correta. */
body.dcl-landing-page .wp-site-blocks,
body.dcl-landing-page .wp-site-blocks > main,
body.dcl-landing-page main.wp-block-group {
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

body.dcl-landing-page .wp-site-blocks > main .wp-block-post-content,
body.dcl-landing-page .wp-site-blocks > main .entry-content {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  margin-inline: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

body.dcl-landing-page .wp-site-blocks > main .alignwide,
body.dcl-landing-page .wp-site-blocks > main .alignfull {
  max-width: 100% !important;
  margin-inline: 0 !important;
}

body.dcl-landing-page .is-layout-constrained > .dcl-page,
body.dcl-landing-page .entry-content > .dcl-page,
body.dcl-landing-page .wp-block-post-content > .dcl-page {
  width: 100vw !important;
  max-width: none !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
}

body.dcl-landing-page main.wp-block-group > .wp-block-group.alignfull {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

/* Garante que o Hero seja o primeiro bloco visual da landing. */
body.dcl-landing-page .wp-block-post-title,
body.dcl-landing-page .entry-title {
  display: none !important;
}

html {
  scroll-behavior: smooth;
  overflow-x: hidden;
}

body.dcl-landing-page {
  overflow-x: hidden;
}

.dcl-page {
  width: 100vw;
  max-width: none;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  overflow-x: hidden;
  overflow-y: visible;
  background: var(--dcl-light);
  color: var(--dcl-ink);
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 17px;
  line-height: 1.65;
}

.dcl-container {
  width: min(var(--dcl-content-max), calc(100% - var(--dcl-content-gutter)));
  margin-inline: auto;
  min-width: 0;
}

.dcl-hero {
  position: relative;
  min-height: 96vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(14px, 2.2vw, 26px) 0;
  background: #4f2035;
  text-align: left;
  color: var(--dcl-white);
}

.dcl-hero-overlay {
  display: none;
}

.dcl-hero-shell {
  position: relative;
  z-index: 1;
  width: min(1240px, calc(100% - 40px));
  max-width: none;
  min-height: clamp(560px, 84vh, 860px);
  margin-inline: auto;
  padding: 0;
  border-radius: clamp(24px, 3.2vw, 38px);
  overflow: hidden;
  isolation: isolate;
  background: #fff;
  box-shadow: 0 34px 70px rgba(68, 22, 39, 0.32);
}

.dcl-hero-shell::before {
  content: none;
}

.dcl-hero-shell > * {
  position: relative;
  z-index: 1;
}

.dcl-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(340px, 0.92fr);
  gap: 0;
  align-items: stretch;
  min-height: clamp(560px, 84vh, 860px);
}

.dcl-hero-content {
  min-width: 0;
  padding: clamp(38px, 6.2vw, 84px) clamp(24px, 5vw, 72px);
  background: linear-gradient(145deg, #2f1422 0%, #4d1d31 56%, #6e2c45 100%);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.dcl-hero-photo-wrap {
  margin: 0;
  border-radius: 0;
  overflow: hidden;
  border: 0;
  background: #f0e1dc;
  box-shadow: none;
  position: relative;
  height: 100%;
}

.dcl-hero-photo-wrap::after {
  content: none;
}

.dcl-hero-photo {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 100%;
  aspect-ratio: auto;
  object-fit: cover;
  object-position: center top;
}

.dcl-logo {
  width: min(390px, 92%);
  max-width: 100%;
  height: auto;
  margin: 0 0 20px;
  filter: drop-shadow(0 10px 20px rgba(0, 0, 0, 0.25));
}

.dcl-hero-meta {
  margin: 0 0 14px;
  font-size: 13px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: rgba(255, 225, 208, 0.96);
}

.dcl-hero-title {
  margin: 0 0 16px;
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(40px, 5.4vw, 68px);
  line-height: 1.01;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  text-wrap: balance;
}

.dcl-hero-text {
  margin: 0 0 30px;
  max-width: 640px;
  font-size: clamp(18px, 1.9vw, 22px);
  line-height: 1.58;
  font-weight: 500;
  color: rgba(255, 243, 240, 0.94);
}

.dcl-hero .dcl-btn {
  min-height: 58px;
  padding: 16px 36px;
  font-size: 16px;
}

.dcl-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 54px;
  padding: 15px 30px;
  border-radius: 999px;
  border: 0;
  text-decoration: none;
  color: #fff;
  font-family: var(--font-button);
  font-weight: 700;
  font-size: 16px;
  line-height: 1.25;
  background-image: radial-gradient(circle at center, var(--dcl-green) 0%, var(--dcl-green-hover) 90%);
  box-shadow: 0 16px 32px rgba(12, 217, 99, 0.34);
  transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}

.dcl-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 20px 36px rgba(4, 149, 66, 0.38);
  filter: brightness(1.04);
}

.dcl-btn-icon {
  width: 18px;
  height: 18px;
  display: inline-flex;
}

.dcl-btn-icon svg {
  width: 100%;
  height: 100%;
  fill: currentColor;
}

.dcl-hero-audience {
  margin: 20px 0 0;
  max-width: 560px;
  font-size: 15px;
  line-height: 1.5;
  font-family: var(--font-button);
  color: rgba(255, 243, 240, 0.86);
}

.dcl-section {
  padding: 90px 0;
}

.dcl-section-light {
  background: var(--dcl-light);
}

.dcl-section-navy {
  background: linear-gradient(145deg, var(--dcl-navy), var(--dcl-slate));
  color: var(--dcl-white);
}

.dcl-section-slate {
  background: linear-gradient(140deg, var(--dcl-midnight), var(--dcl-slate));
  color: var(--dcl-white);
}

.dcl-section-cta {
  background: linear-gradient(135deg, var(--dcl-navy), var(--dcl-slate));
}

.dcl-section-areas {
  background: linear-gradient(145deg, #4d1d31 0%, #7a334d 60%, #8b3a57 100%);
  color: var(--dcl-white);
}

.dcl-section-dark-soft {
  background: linear-gradient(145deg, #632b41 0%, #8b3a57 56%, #a55a70 100%);
  color: var(--dcl-white);
}

.dcl-section-exams {
  background: linear-gradient(145deg, #5a253a 0%, #7a334d 58%, #9b4f66 100%);
  color: var(--dcl-white);
}

.dcl-section-cta-light {
  background: linear-gradient(180deg, #fff9f7 0%, var(--dcl-light) 100%);
}

.dcl-section-title {
  margin: 0 0 24px;
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(30px, 4.2vw, 50px);
  line-height: 1.06;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  text-wrap: balance;
}

.dcl-section-title-ink {
  color: var(--dcl-ink);
}

.dcl-panel {
  max-width: 860px;
  margin-inline: auto;
  background: var(--dcl-white);
  border-radius: var(--dcl-radius);
  padding: clamp(26px, 4.6vw, 48px);
  box-shadow: var(--dcl-shadow);
}

.dcl-panel-about {
  max-width: 1120px;
  padding: 0;
  overflow: hidden;
  border-radius: clamp(22px, 3vw, 34px);
  background: #fff;
  box-shadow: 0 26px 52px rgba(68, 22, 39, 0.2);
}

.dcl-about-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(280px, 0.92fr);
  gap: 0;
  align-items: stretch;
}

.dcl-about-content {
  min-width: 0;
  padding: clamp(30px, 4.8vw, 56px);
  background: linear-gradient(145deg, #2f1422 0%, #4d1d31 56%, #6e2c45 100%);
  color: var(--dcl-white);
}

.dcl-about-photo {
  margin: 0;
  border-radius: 0;
  overflow: hidden;
  border: 0;
  box-shadow: none;
  background: #f0e1dc;
  height: 100%;
}

.dcl-about-photo img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 520px;
  aspect-ratio: auto;
  object-fit: cover;
  object-position: center top;
}

.dcl-panel-about .dcl-about-content h2 {
  color: #ffffff;
  opacity: 1;
  font-weight: 600;
  line-height: 1.12;
  letter-spacing: 0.008em;
}

.dcl-panel-about .dcl-about-content p {
  color: #f8f1f4;
  opacity: 1;
  line-height: 1.65;
  font-weight: 500;
}

.dcl-panel-about .dcl-about-content .dcl-doctor-credentials {
  border-top-color: rgba(255, 255, 255, 0.34);
  color: #fff !important;
  opacity: 1;
  font-weight: 600;
}

.dcl-panel-about .dcl-about-content .dcl-credential-line {
  color: #ffffff;
  opacity: 1;
  font-weight: 600;
}

.dcl-credential-line {
  display: block;
}

.dcl-panel h2 {
  margin: 0 0 18px;
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(28px, 3.8vw, 44px);
  line-height: 1.08;
  text-transform: uppercase;
  color: var(--dcl-ink);
}

.dcl-panel p {
  margin: 0 0 14px;
  font-size: 18px;
  line-height: 1.65;
  font-weight: 500;
  color: var(--dcl-muted);
}

.dcl-doctor-credentials {
  margin-top: 24px;
  padding-top: 18px;
  border-top: 1px solid rgba(37, 49, 78, 0.13);
  color: var(--dcl-ink) !important;
  font-weight: 700;
  font-size: 16px;
  line-height: 1.55;
}

.dcl-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(260px, 1fr));
  gap: clamp(18px, 2vw, 26px);
  align-items: stretch;
}

.dcl-card {
  min-width: 0;
  border-radius: 20px;
  padding: clamp(20px, 2.2vw, 28px);
  background: rgba(255, 255, 255, 0.14);
  border: 1px solid rgba(255, 255, 255, 0.32);
  box-shadow: 0 14px 28px rgba(30, 10, 20, 0.18);
}

.dcl-card-media {
  margin: 0 0 14px;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.24);
  background: rgba(255, 255, 255, 0.1);
}

.dcl-card-image {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  object-position: center;
}

.dcl-card h3 {
  min-width: 0;
  margin: 0 0 10px;
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(22px, 1.9vw, 24px);
  line-height: 1.16;
  color: #fff6f3;
  overflow-wrap: break-word;
  word-break: normal;
  hyphens: auto;
}

.dcl-card p {
  min-width: 0;
  margin: 0;
  font-size: 16px;
  line-height: 1.62;
  font-weight: 500;
  overflow-wrap: break-word;
  word-break: normal;
  hyphens: auto;
  color: rgba(255, 255, 255, 0.97);
}

.dcl-card-grid-tight .dcl-card h3 {
  color: #fff8f5;
}

.dcl-card-soft {
  background: rgba(255, 255, 255, 0.17);
  border-color: rgba(255, 255, 255, 0.3);
}

.dcl-section-navy .dcl-card,
.dcl-section-slate .dcl-card {
  backdrop-filter: blur(2px);
}

.dcl-section-areas .dcl-section-title,
.dcl-section-exams .dcl-section-title {
  color: #fff;
}

.dcl-section-areas .dcl-card,
.dcl-section-exams .dcl-card,
.dcl-section-exams .dcl-card-soft {
  background: rgba(255, 255, 255, 0.14);
  border: 1px solid rgba(255, 255, 255, 0.32);
  box-shadow: 0 14px 28px rgba(30, 10, 20, 0.18);
}

.dcl-section-areas .dcl-card-media,
.dcl-section-exams .dcl-card-media {
  border-color: rgba(255, 255, 255, 0.24);
  background: rgba(255, 255, 255, 0.1);
}

.dcl-card-media-exam {
  margin-bottom: 16px;
}

.dcl-card-image-exam {
  aspect-ratio: 16 / 10;
  object-fit: cover;
  object-position: center top;
}

.dcl-section-areas .dcl-card h3,
.dcl-section-exams .dcl-card h3,
.dcl-section-exams .dcl-card-grid-tight .dcl-card h3 {
  color: #fff6f3;
}

.dcl-section-areas .dcl-card p,
.dcl-section-exams .dcl-card p {
  color: rgba(255, 255, 255, 0.97);
}

.dcl-section-dark-soft .dcl-section-title {
  color: #fff;
}

.dcl-section-action {
  margin-top: 22px;
  display: flex;
  justify-content: center;
}

.dcl-panel .dcl-section-action {
  justify-content: flex-start;
}

.dcl-btn-topic {
  min-height: 52px;
  padding: 14px 28px;
  font-size: 16px;
  letter-spacing: 0.01em;
}

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

.dcl-list-grid li {
  position: relative;
  background: #fff;
  border: 1px solid rgba(37, 49, 78, 0.12);
  border-radius: 16px;
  padding: 16px 16px 16px 44px;
  box-shadow: 0 10px 22px rgba(21, 34, 58, 0.08);
  color: var(--dcl-ink);
  font-size: 16px;
  line-height: 1.58;
  font-weight: 600;
}

.dcl-list-grid li::before {
  content: "";
  position: absolute;
  left: 18px;
  top: 22px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--dcl-terra);
  box-shadow: 0 0 0 5px rgba(205, 101, 60, 0.18);
}

.dcl-section-identify {
  background: linear-gradient(145deg, #4d1d31 0%, #7a334d 60%, #8b3a57 100%);
  color: var(--dcl-white);
}

.dcl-identify-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(280px, 0.85fr);
  gap: clamp(22px, 3vw, 34px);
  align-items: start;
}

.dcl-identify-content {
  min-width: 0;
}

.dcl-identify-intro {
  margin: 0 0 20px;
  max-width: 760px;
  font-size: 18px;
  line-height: 1.62;
  color: rgba(255, 243, 240, 0.92);
}

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

.dcl-identify-item {
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.28);
  border-radius: 16px;
  padding: 14px 16px;
  color: #fff;
  font-size: 16px;
  line-height: 1.56;
  font-weight: 600;
  box-shadow: 0 10px 20px rgba(36, 12, 24, 0.2);
}

.dcl-identify-photo {
  margin: 8px 0 0;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.28);
  box-shadow: 0 16px 30px rgba(36, 12, 24, 0.24);
  background: rgba(255, 255, 255, 0.08);
}

.dcl-identify-photo img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  object-position: center;
}

.dcl-section-formation {
  background: linear-gradient(180deg, #f7ebe7 0%, #fef3f0 100%);
}

.dcl-formation-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(300px, 0.92fr);
  border-radius: clamp(22px, 3vw, 34px);
  overflow: hidden;
  box-shadow: 0 26px 52px rgba(68, 22, 39, 0.2);
  background: #fff;
}

.dcl-formation-content {
  min-width: 0;
  padding: clamp(28px, 4.5vw, 54px);
  background: linear-gradient(145deg, #2f1422 0%, #4d1d31 56%, #6e2c45 100%);
  color: var(--dcl-white);
}

.dcl-formation-content .dcl-section-title {
  margin-bottom: 14px;
  color: #fff;
  font-size: clamp(30px, 4.1vw, 50px);
}

.dcl-formation-subtitle {
  margin: 0 0 20px;
  max-width: 64ch;
  color: rgba(255, 243, 240, 0.9);
  font-size: 17px;
  line-height: 1.62;
  font-weight: 500;
}

.dcl-formation-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 12px;
}

.dcl-formation-list li {
  position: relative;
  margin: 0;
  padding: 0 0 0 30px;
  color: rgba(255, 255, 255, 0.96);
  font-size: 16px;
  line-height: 1.58;
  font-weight: 500;
}

.dcl-formation-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  width: 14px;
  height: 14px;
  border-radius: 999px;
  background: rgba(178, 108, 103, 0.3);
  box-shadow: 0 0 0 2px rgba(245, 219, 214, 0.45) inset;
}

.dcl-formation-list li::after {
  content: "";
  position: absolute;
  left: 5px;
  top: 13px;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: #f5dbd6;
}

.dcl-formation-content .dcl-section-action {
  margin-top: 24px;
  justify-content: flex-start;
}

.dcl-formation-photo {
  margin: 0;
  background: #f0e1dc;
}

.dcl-formation-photo img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 560px;
  object-fit: cover;
  object-position: center top;
}

.dcl-section-photo-break {
  background: linear-gradient(165deg, rgba(139, 58, 87, 0.12), rgba(178, 108, 103, 0.2));
}

.dcl-feature-photo {
  margin: 0;
  border-radius: clamp(20px, 3vw, 34px);
  overflow: hidden;
  border: 1px solid rgba(139, 58, 87, 0.2);
  box-shadow: 0 24px 44px rgba(68, 22, 39, 0.2);
}

.dcl-feature-photo img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  object-position: center top;
}

.dcl-cta-box {
  text-align: center;
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: var(--dcl-radius);
  padding: clamp(28px, 5vw, 56px);
}

.dcl-section-cta-light .dcl-cta-box {
  background: linear-gradient(135deg, #5a253a, #8b3a57);
  border-color: rgba(255, 255, 255, 0.18);
  box-shadow: 0 22px 44px rgba(68, 22, 39, 0.26);
}

.dcl-cta-box h2 {
  margin: 0 0 14px;
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(30px, 4.4vw, 54px);
  line-height: 1.06;
  text-transform: uppercase;
  color: #fff;
}

.dcl-cta-box p {
  margin: 0 auto 24px;
  max-width: 760px;
  color: rgba(255, 255, 255, 0.88);
  font-size: 19px;
  line-height: 1.64;
  font-weight: 500;
}

.dcl-section-map {
  background: linear-gradient(145deg, #5a253a 0%, #7a334d 58%, #9b4f66 100%);
  padding-top: 72px;
  padding-bottom: 60px;
}

.dcl-map-shell {
  max-width: 1120px;
  margin-inline: auto;
}

.dcl-map-header {
  text-align: center;
  max-width: 760px;
  margin: 0 auto 16px;
}

.dcl-map-label {
  display: inline-block;
  margin-bottom: 10px;
  font-size: 13px;
  font-family: var(--font-button);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: #f5dbd6;
  font-weight: 700;
}

.dcl-map-header .dcl-section-title {
  margin-bottom: 14px;
}

.dcl-map-header p {
  margin: 0 auto;
  max-width: 62ch;
  color: var(--dcl-muted);
  font-size: 17px;
  line-height: 1.65;
}

.dcl-map-wrapper {
  border-radius: clamp(16px, 2vw, 24px);
  overflow: hidden;
  border: 1px solid rgba(50, 19, 39, 0.16);
  box-shadow: 0 22px 44px rgba(68, 22, 39, 0.2);
  background: #ece5e2;
}

.dcl-map-wrapper iframe {
  display: block;
  width: 100%;
  height: 420px;
  border: 0;
}

.dcl-footer {
  background: #19233a;
  color: #f6edf1;
  text-align: center;
  padding: 52px 0 38px;
}

.dcl-footer-logo {
  width: clamp(160px, 24vw, 240px);
  margin: 0 auto 20px;
}

.dcl-footer-logo img {
  display: block;
  width: 100%;
  height: auto;
}

.dcl-footer-meta {
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 10px 24px;
}

.dcl-footer-meta p {
  margin: 0;
  font-size: 16px;
  line-height: 1.6;
  color: #f6edf1;
  overflow-wrap: anywhere;
}

.dcl-footer-meta strong {
  color: #ffffff;
  font-weight: 700;
}

.dcl-footer-instagram {
  color: var(--dcl-peach);
  text-decoration: none;
  font-weight: 700;
}

.dcl-float-whatsapp {
  position: fixed;
  right: 16px;
  bottom: 16px;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  color: #fff;
  background: linear-gradient(165deg, var(--dcl-green), var(--dcl-green-hover));
  box-shadow: 0 20px 38px rgba(12, 217, 99, 0.35);
  text-decoration: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.dcl-float-whatsapp:hover {
  transform: translateY(-1px);
  box-shadow: 0 24px 40px rgba(4, 149, 66, 0.4);
}

.dcl-float-whatsapp svg {
  width: 29px;
  height: 29px;
  fill: currentColor;
}

@media (max-width: 980px) {
  .dcl-about-layout,
  .dcl-identify-layout,
  .dcl-formation-shell {
    grid-template-columns: 1fr;
  }

  .dcl-hero-grid {
    grid-template-columns: 1fr;
  }

  .dcl-hero-photo-wrap {
    order: -1;
    height: auto;
  }

  .dcl-hero-photo {
    height: auto;
    min-height: 0;
    aspect-ratio: 4 / 5;
  }

  .dcl-about-photo,
  .dcl-identify-photo,
  .dcl-formation-photo {
    max-width: 560px;
    width: 100%;
    margin-inline: auto;
  }

  .dcl-panel-about .dcl-about-photo {
    max-width: none;
    margin-inline: 0;
  }

  .dcl-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dcl-section-exams .dcl-card-grid-tight {
    grid-template-columns: none;
    grid-auto-flow: column;
    grid-auto-columns: minmax(250px, 1fr);
    overflow-x: auto;
    overflow-y: visible;
    overscroll-behavior-x: contain;
    scroll-snap-type: x proximity;
    scrollbar-width: thin;
    padding-bottom: 4px;
  }

  .dcl-section-exams .dcl-card-grid-tight .dcl-card {
    scroll-snap-align: start;
    height: auto;
    min-height: 0;
    max-height: none;
    overflow-y: visible;
  }

  .dcl-section-areas .dcl-card-grid {
    grid-template-columns: none;
    grid-auto-flow: column;
    grid-auto-columns: minmax(250px, 1fr);
    overflow-x: auto;
    overflow-y: visible;
    overscroll-behavior-x: contain;
    scroll-snap-type: x proximity;
    scrollbar-width: thin;
    padding-bottom: 4px;
  }

  .dcl-section-areas .dcl-card-grid .dcl-card {
    scroll-snap-align: start;
    height: auto;
    min-height: 0;
    max-height: none;
    overflow-y: visible;
  }

  .dcl-about-photo img,
  .dcl-identify-photo img,
  .dcl-formation-photo img {
    height: auto;
    min-height: 0;
    aspect-ratio: 4 / 5;
    object-fit: cover;
    object-position: center top;
  }

  .dcl-list-grid {
    grid-template-columns: 1fr;
  }

  .dcl-map-wrapper iframe {
    height: 360px;
  }
}

@media (max-width: 760px) {
  .dcl-page {
    font-size: 16px;
    line-height: 1.62;
  }

  .dcl-hero {
    min-height: auto;
    padding: 10px 0 20px;
    text-align: center;
  }

  .dcl-hero-shell {
    width: min(1240px, calc(100% - 20px));
    min-height: auto;
    padding: 0;
    border-radius: 24px;
  }

  .dcl-hero-grid {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .dcl-hero-photo-wrap {
    order: -1;
    width: 100%;
    margin-inline: 0;
  }

  .dcl-hero-photo {
    aspect-ratio: 4 / 4.45;
    object-position: center top;
  }

  .dcl-hero-shell::before {
    content: none;
  }

  .dcl-hero-content {
    padding: 24px 18px 28px;
  }

  .dcl-logo {
    width: min(320px, 84vw);
    margin: 0 auto 16px;
  }

  .dcl-hero-title {
    margin: 0 0 14px;
    font-size: clamp(30px, 9vw, 44px);
  }

  .dcl-hero-text {
    margin: 0 auto 24px;
    max-width: 34ch;
    font-size: 17px;
    line-height: 1.62;
  }

  .dcl-hero-audience {
    margin-top: 14px;
    max-width: 34ch;
    font-size: 14px;
    line-height: 1.5;
  }

  .dcl-section {
    padding: 54px 0;
  }

  .dcl-card-grid {
    grid-template-columns: 1fr;
  }

  .dcl-section-areas .dcl-card-grid {
    grid-template-columns: none;
    grid-auto-flow: column;
    grid-auto-columns: minmax(220px, 74vw);
    gap: 12px;
    overflow-x: auto;
    overflow-y: visible;
    overscroll-behavior-x: contain;
    scroll-snap-type: x mandatory;
    margin: 0 -2px;
    padding: 2px 2px 8px;
  }

  .dcl-section-areas .dcl-card-grid .dcl-card {
    height: auto;
    min-height: 0;
    max-height: none;
    overflow-y: visible;
    padding: 16px;
    scroll-snap-align: start;
  }

  .dcl-section-exams .dcl-card-grid-tight {
    grid-template-columns: none;
    grid-auto-flow: column;
    grid-auto-columns: minmax(220px, 74vw);
    gap: 12px;
    overflow-x: auto;
    overflow-y: visible;
    overscroll-behavior-x: contain;
    scroll-snap-type: x mandatory;
    margin: 0 -2px;
    padding: 2px 2px 8px;
  }

  .dcl-section-exams .dcl-card-grid-tight .dcl-card {
    height: auto;
    min-height: 0;
    max-height: none;
    overflow-y: visible;
    padding: 16px;
    scroll-snap-align: start;
  }

  .dcl-section-exams .dcl-card h3 {
    font-size: clamp(19px, 5.4vw, 22px);
    line-height: 1.2;
  }

  .dcl-section-exams .dcl-card p {
    font-size: 15px;
    line-height: 1.55;
  }

  .dcl-section-exams .dcl-card-image-exam {
    aspect-ratio: 16 / 11;
    object-position: center;
  }

  .dcl-section-areas .dcl-card h3 {
    font-size: clamp(19px, 5.4vw, 22px);
    line-height: 1.2;
  }

  .dcl-section-areas .dcl-card p {
    font-size: 15px;
    line-height: 1.55;
  }

  .dcl-about-photo img,
  .dcl-identify-photo img,
  .dcl-formation-photo img {
    aspect-ratio: 4 / 5;
    min-height: 0;
    object-position: center top;
  }

  .dcl-card-image {
    aspect-ratio: 16 / 10;
    min-height: 0;
  }

  .dcl-formation-content .dcl-section-action {
    justify-content: center;
  }

  .dcl-formation-photo img {
    min-height: 0;
    aspect-ratio: 4 / 5;
  }

  .dcl-identify-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  .dcl-panel p,
  .dcl-card p,
  .dcl-list-grid li,
  .dcl-identify-item,
  .dcl-formation-list li {
    font-size: 16px;
    line-height: 1.6;
  }

  .dcl-identify-intro,
  .dcl-formation-subtitle {
    font-size: 16px;
  }

  .dcl-feature-photo img {
    aspect-ratio: 4 / 5;
  }

  .dcl-panel .dcl-section-action {
    justify-content: center;
  }

  .dcl-btn-topic {
    width: 100%;
    max-width: 420px;
  }

  .dcl-hero .dcl-btn {
    width: auto;
    max-width: 340px;
    min-height: 52px;
    padding: 14px 24px;
    font-size: 15px;
    align-self: center;
  }

  .dcl-section-map {
    padding-top: 56px;
    padding-bottom: 48px;
  }

  .dcl-map-header p {
    font-size: 16px;
  }

  .dcl-map-wrapper iframe {
    height: 300px;
  }

  .dcl-footer-logo {
    width: clamp(130px, 48vw, 180px);
    margin-bottom: 16px;
  }

  .dcl-footer-meta {
    flex-direction: column;
    gap: 8px;
  }

  .dcl-footer-meta p {
    font-size: 15px;
  }
}

@media (max-width: 430px) {
  .dcl-hero-shell {
    width: min(1240px, calc(100% - 14px));
  }

  .dcl-hero-title {
    font-size: clamp(28px, 9.5vw, 38px);
  }

  .dcl-hero-text {
    font-size: 16px;
    line-height: 1.58;
  }

  .dcl-hero .dcl-btn {
    max-width: 300px;
    padding: 13px 20px;
    font-size: 14px;
  }

  .dcl-section-areas .dcl-card-grid {
    grid-auto-columns: minmax(210px, 86vw);
  }

  .dcl-identify-grid {
    grid-template-columns: 1fr;
  }

  .dcl-section-exams .dcl-card-grid-tight {
    grid-auto-columns: minmax(210px, 86vw);
  }

  .dcl-map-wrapper iframe {
    height: 280px;
  }

  .dcl-footer {
    padding: 44px 0 34px;
  }

  .dcl-footer-meta p {
    font-size: 14px;
  }
}

@media (min-width: 431px) and (max-width: 760px) {
  .dcl-section-areas .dcl-card-grid {
    grid-auto-columns: minmax(230px, 68vw);
  }
}

@media (prefers-reduced-motion: reduce) {
  .dcl-btn,
  .dcl-float-whatsapp {
    transition: none;
  }
}
