/* ==========================================================================
   DIVINE NANNIES — main.css
   Theme: Refined editorial luxury childcare brand
   ========================================================================== */

/* -------------------------
   CSS Custom Properties
   ------------------------- */
:root {
    /* Colors — from Figma */
    --color-bg:           #F2F4F8;      /* light blue-grey page background */
    --color-bg-white:     #FFFFFF;
    --color-navy:         #1A2B4A;      /* primary dark navy — headings, nav */
    --color-navy-deep:    #0E1B30;      /* darkest navy — footer logo */
    --color-blue-accent:  #3A6BC8;      /* hero line2 accent blue */
    --color-blue-cta:     #2B5FC4;      /* CTA button background */
    --color-blue-cta-hov: #1D4AA8;
    --color-text-body:    #4A556A;      /* body copy */
    --color-text-muted:   #8A96A8;      /* muted labels */
    --color-border:       #DDE3EE;
    --color-badge-bg:     #DDEAF8;
    --color-badge-text:   #2B5FC4;

    /* Typography */
    --font-display: 'Plus Jakarta Sans', sans-serif;
    --font-body:    'Plus Jakarta Sans', sans-serif;

    /* Spacing */
    --container-max:  1377px;
    --container-pad:  clamp(24px, 5vw, 80px);
    --header-height:  72px;
    --header-topbar-height: 40px;
    --header-total-height: calc(var(--header-height) + var(--header-topbar-height));

    /* Radius */
    --radius-sm:  6px;
    --radius-md:  14px;
    --radius-lg:  24px;
    --radius-pill: 999px;

    /* Shadow */
    --shadow-sm:   0 10px 24px rgba(26, 43, 74, .06);
    --shadow-md:   0 18px 44px rgba(26, 43, 74, .10);
    --shadow-lg:   0 28px 72px rgba(26, 43, 74, .14);
    --shadow-soft: 0 22px 54px rgba(33, 61, 111, 0.08);

    /* Transition */
    --transition: 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

/* -------------------------
   Reset & Base
   ------------------------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
    font-size: 16px;
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
}

body {
    font-family: var(--font-body);
    background:
        radial-gradient(circle at top left, rgba(221, 234, 248, 0.9), transparent 28%),
        radial-gradient(circle at top right, rgba(201, 219, 245, 0.55), transparent 22%),
        linear-gradient(180deg, #f7f9fc 0%, var(--color-bg) 26%, #eef3fb 100%);
    color: var(--color-text-body);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}

body.nav-open { overflow: hidden; }

img, svg { display: block; max-width: 100%; height: auto; }
a { text-decoration: none; color: inherit; }
ul { list-style: none; }
button { cursor: pointer; border: none; background: none; font: inherit; }

/* -------------------------
   Container Helper
   ------------------------- */
.dn-container {
    width: 100%;
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--container-pad);
}

#main-content {
    position: relative;
}

#main-content::before {
    content: "";
    position: absolute;
    inset: 0 0 auto;
    height: 520px;
    pointer-events: none;
    background:
        radial-gradient(circle at 18% 20%, rgba(255, 255, 255, 0.72), transparent 0 24%),
        radial-gradient(circle at 82% 6%, rgba(221, 234, 248, 0.72), transparent 0 18%);
    z-index: -1;
}

/* =========================================================
   HEADER
   ========================================================= */
.dn-header {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 1000;
    height: var(--header-total-height);
    background: rgba(255, 255, 255, 0.94);
    border-bottom: 1px solid transparent;
    transition: border-color var(--transition), box-shadow var(--transition), background var(--transition);
}

.dn-header.is-scrolled {
    border-color: var(--color-border);
    box-shadow: var(--shadow-sm);
    background: rgba(255,255,255,0.97);
    backdrop-filter: blur(12px);
}

.dn-header__topbar {
    height: var(--header-topbar-height);
    background: linear-gradient(90deg, rgba(26, 43, 74, 0.98), rgba(43, 95, 196, 0.94));
    color: rgba(255, 255, 255, 0.92);
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.dn-header__topbar-inner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    height: 100%;
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--container-pad);
}

.dn-header__topbar-note {
    font-size: 0.76rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.76);
}

.dn-header__topbar-contact {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 14px;
}

.dn-header__topbar-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-size: 0.88rem;
    line-height: 1;
    min-width: 0;
    transition: opacity var(--transition);
}

.dn-header__topbar-link:hover {
    opacity: 0.78;
}

.dn-header__topbar-value {
    font-weight: 500;
    letter-spacing: 0.01em;
    overflow-wrap: anywhere;
}

.dn-header__topbar-label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 46px;
    padding: 6px 10px;
    border-radius: var(--radius-pill);
    background: rgba(255, 255, 255, 0.12);
    color: rgba(255, 255, 255, 0.88);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.dn-header__topbar-divider {
    width: 1px;
    height: 16px;
    background: rgba(255, 255, 255, 0.2);
}

.dn-header__inner {
    display: flex;
    align-items: center;
    height: var(--header-height);
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--container-pad);
    gap: 32px;
    background: var(--color-bg-white);
}

/* Logo */
.dn-header__logo {
    display: flex;
    align-items: center;
    flex-shrink: 0;
    transition: opacity var(--transition);
}
.dn-header__logo:hover { opacity: 0.8; }

.dn-header__logo-text {
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--color-navy);
    letter-spacing: -0.01em;
    white-space: nowrap;
}

.dn-header__logo-img {
    height: 50px;
    width: auto;
}

/* Desktop Nav */
.dn-header__nav { margin-left: auto; }

.dn-header__menu {
    display: flex;
    align-items: center;
    gap: 8px;
}

.dn-header__menu li a {
    font-size: 0.9rem;
    font-weight: 400;
    color: var(--color-navy);
    padding: 8px 14px;
    border-radius: var(--radius-pill);
    transition: background var(--transition), color var(--transition);
    white-space: nowrap;
}

.dn-header__menu li a:hover,
.dn-header__menu li.current-menu-item > a {
    background: var(--color-badge-bg);
    color: var(--color-blue-cta);
}

/* Dropdowns */
.dn-header__menu li {
    position: relative;
}

.dn-header__menu .sub-menu {
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    min-width: 210px;
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-md);
    padding: 10px 0;
    opacity: 0;
    pointer-events: none;
    transform: translateY(6px);
    transition: opacity var(--transition), transform var(--transition), visibility var(--transition);
    visibility: hidden;
    z-index: 1001;
}

.dn-header__menu .sub-menu li a {
    border-radius: 0;
    padding: 10px 16px;
    display: block;
    color: var(--color-navy);
    background: transparent;
}

.dn-header__menu .sub-menu li a:hover {
    background: var(--color-badge-bg);
    color: var(--color-blue-cta);
}

.dn-header__menu li:hover > .sub-menu,
.dn-header__menu li:focus-within > .sub-menu {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
    visibility: visible;
}

.dn-header__menu .menu-item-has-children > a::after {
    content: '▾';
    font-size: 1rem;
    margin-left: 6px;
}

/* CTA Button */
.dn-header__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    padding: 10px 22px;
    background: var(--color-blue-cta);
    color: #fff;
    font-size: 0.875rem;
    font-weight: 500;
    border-radius: var(--radius-pill);
    transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
    white-space: nowrap;
}

.dn-header__cta:hover {
    background: var(--color-blue-cta-hov);
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(43, 95, 196, .35);
}

/* Hamburger */
.dn-header__hamburger {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 36px;
    height: 36px;
    padding: 6px;
    margin-left: auto;
    flex-shrink: 0;
}

.dn-header__hamburger span {
    display: block;
    height: 2px;
    background: var(--color-navy);
    border-radius: 2px;
    transition: transform var(--transition), opacity var(--transition);
    transform-origin: center;
}

.dn-header__hamburger.is-active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.dn-header__hamburger.is-active span:nth-child(2) { opacity: 0; }
.dn-header__hamburger.is-active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile Nav Drawer */
.dn-header__mobile-nav {
    display: none;
    position: fixed;
    top: var(--header-total-height);
    left: 0; right: 0;
    background: var(--color-bg-white);
    border-bottom: 1px solid var(--color-border);
    padding: 24px var(--container-pad) 32px;
    transform: translateY(-8px);
    opacity: 0;
    pointer-events: none;
    transition: transform var(--transition), opacity var(--transition);
    z-index: 999;
}

.dn-header__mobile-nav.is-open {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
}

.dn-header__mobile-menu {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-bottom: 20px;
}

.dn-header__mobile-menu li a {
    display: block;
    font-size: 1rem;
    font-weight: 400;
    color: var(--color-navy);
    padding: 12px 16px;
    border-radius: var(--radius-sm);
    transition: background var(--transition);
}

.dn-header__mobile-menu li a:hover {
    background: var(--color-badge-bg);
    color: var(--color-blue-cta);
}

.dn-header__cta--mobile {
    display: inline-flex;
    width: 100%;
    justify-content: center;
    margin-top: 8px;
}

/* Offset page content for fixed header */
#main-content { padding-top: var(--header-total-height); }

/* =========================================================
   SHARED BUTTON STYLES
   ========================================================= */
.dn-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 13px 26px;
    border-radius: var(--radius-pill);
    font-size: 0.9rem;
    font-weight: 500;
    line-height: 1;
    transition: background var(--transition), color var(--transition),
                border-color var(--transition), transform var(--transition),
                box-shadow var(--transition);
    white-space: nowrap;
    cursor: pointer;
}

.dn-btn--primary {
    background: var(--color-navy);
    color: #fff;
    border: 2px solid var(--color-navy);
}

.dn-btn--primary:hover {
    background: var(--color-navy-deep);
    border-color: var(--color-navy-deep);
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(26, 43, 74, .25);
}

.dn-btn--secondary {
    background: transparent;
    color: var(--color-navy);
    border: 2px solid var(--color-border);
}

.dn-btn--secondary:hover {
    background: var(--color-badge-bg);
    border-color: var(--color-badge-bg);
    transform: translateY(-2px);
}

/* =========================================================
   HERO SECTION
   ========================================================= */
.dn-hero {
    background: var(--color-bg);
    min-height: calc(100vh - var(--header-height));
    display: flex;
    align-items: center;
    overflow: hidden;
    position: relative;
}

.dn-hero__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    align-items: center;
    width: 100%;
    max-width: var(--container-max);
    margin-inline: auto;
    padding: 60px var(--container-pad);
}

/* Hero Left Content */
.dn-hero__content {
    display: flex;
    flex-direction: column;
    gap: 28px;
    animation: dn-fade-up 0.7s ease both;
}

.dn-hero__badge {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 6px 16px;
    border-radius: var(--radius-pill);
    background: var(--color-badge-bg);
    color: var(--color-badge-text);
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    border: 1px solid rgba(43, 95, 196, 0.2);
}

.dn-hero__heading {
    font-family: var(--font-display);
    font-size: clamp(2.4rem, 5vw, 3.75rem);
    font-weight: 800;
    line-height: 1.08;
    letter-spacing: -0.02em;
}

.dn-hero__heading-line1 {
    color: var(--color-navy);
    display: block;
}

.dn-hero__heading-line2 {
    color: var(--color-blue-accent);
    display: block;
}

.dn-hero__description {
    font-size: 0.95rem;
    line-height: 1.7;
    color: var(--color-text-body);
    max-width: 42ch;
}

.dn-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    align-items: center;
}

/* Hero Right Media */
.dn-hero__media {
    display: flex;
    justify-content: flex-end;
    animation: dn-fade-up 0.7s 0.15s ease both;
}

.dn-hero__image-wrap {
    position: relative;
    width: 100%;
    max-width: 480px;
}

.dn-hero__image {
    width: 100%;
    height: 35pc;
    border-radius: var(--radius-lg);
    object-fit: cover;
    aspect-ratio: 4/5;
    display: block;
    box-shadow: var(--shadow-lg);
}

.dn-hero__image-placeholder {
    width: 100%;
    border-radius: var(--radius-lg);
    overflow: hidden;
    aspect-ratio: 4/5;
    background: var(--color-border);
}

/* Trust Badge overlay */
.dn-hero__trust-badge {
    position: absolute;
    bottom: 28px;
    left: -24px;
    background: var(--color-bg-white);
    border-radius: var(--radius-md);
    padding: 16px 22px;
    box-shadow: var(--shadow-md);
    max-width: 260px;
    animation: dn-fade-up 0.7s 0.3s ease both;
}

.dn-hero__trust-label {
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-text-muted);
    margin-bottom: 6px;
}

.dn-hero__trust-text {
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-navy);
    line-height: 1.3;
}

/* =========================================================
   FOOTER
   ========================================================= */
.dn-footer {
    background: var(--color-bg);
    border-top: 1px solid var(--color-border);
    padding-top: 72px;
}

.dn-footer__inner {
    display: grid;
    grid-template-columns: 1.6fr 1fr 1fr 1fr;
    gap: 40px;
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--container-pad);
    padding-bottom: 56px;
}

/* Footer Brand */
.dn-footer__brand {}

.dn-footer__logo {
    display: inline-block;
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--color-navy-deep);
    letter-spacing: -0.01em;
    margin-bottom: 14px;
    transition: opacity var(--transition);
}
.dn-footer__logo:hover { opacity: 0.75; }

.dn-footer__tagline {
    font-size: 0.865rem;
    color: var(--color-text-body);
    line-height: 1.65;
    max-width: 28ch;
}

/* Footer Columns */
.dn-footer__col {}

.dn-footer__col-heading {
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-text-muted);
    margin-bottom: 20px;
}

.dn-footer__col-links {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.dn-footer__col-links li a {
    font-size: 0.9rem;
    color: var(--color-navy);
    transition: color var(--transition), transform var(--transition);
    display: inline-block;
}

.dn-footer__col-links li a:hover {
    color: var(--color-blue-accent);
    transform: translateX(3px);
}

/* Footer Bottom Bar */
.dn-footer__bottom {
    border-top: 1px solid var(--color-border);
    padding-block: 22px;
}

.dn-footer__bottom-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--container-pad);
}

.dn-footer__copyright {
    font-size: 0.72rem;
    color: var(--color-text-muted);
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.dn-footer__legal {
    display: flex;
    gap: 28px;
}

.dn-footer__legal a {
    font-size: 0.72rem;
    color: var(--color-text-muted);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    transition: color var(--transition);
}

.dn-footer__legal a:hover { color: var(--color-navy); }

/* =========================================================
   STATS STRIP — SECTION 2
   ========================================================= */
.dn-stats {
    background: var(--color-bg);
    padding: 0 0 20px;
}

.dn-stats__inner {
    display: flex;
    gap: 20px;
    justify-content: center;
    align-items: stretch;
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--container-pad);
    padding-block: 20px 40px;
}

/* Stat Card */
.dn-stats__card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    flex: 1;
    min-width: 0;
    background: var(--color-bg-white);
    border-radius: var(--radius-lg);
    padding: 32px 28px;
    text-align: center;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-border);
    cursor: default;

    /* Hover transition */
    transition:
        transform var(--transition),
        box-shadow var(--transition),
        background var(--transition),
        border-color var(--transition);
}

.dn-stats__card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-md);
    border-color: rgba(58, 107, 200, 0.2);
}

/* Featured / highlighted card — navy */
.dn-stats__card--featured {
    background: var(--color-navy);
    border-color: var(--color-navy);
    box-shadow: var(--shadow-md);
}

.dn-stats__card--featured:hover {
    background: var(--color-navy-deep);
    border-color: var(--color-navy-deep);
    transform: translateY(-6px);
    box-shadow: var(--shadow-lg);
}

/* Icon wrapper */
.dn-stats__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: var(--color-badge-bg);
    flex-shrink: 0;
    transition: background var(--transition), transform var(--transition);
    overflow: hidden;
    color: var(--color-blue-accent);
}

.dn-stats__icon img {
    width: 28px;
    height: 28px;
    object-fit: contain;
    display: block;
    transition: transform var(--transition);
}

/* Fallback placeholder dot when no image uploaded */
.dn-stats__icon-placeholder {
    display: block;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--color-blue-accent);
    opacity: 0.4;
}

.dn-stats__icon svg {
    width: 28px;
    height: 28px;
}

/* Featured icon overrides */
.dn-stats__card--featured .dn-stats__icon {
    background: rgba(255, 255, 255, 0.15);
    color: #fff;
}

/* Hover: lift icon slightly */
.dn-stats__card:hover .dn-stats__icon {
    transform: scale(1.08);
}

.dn-stats__card:not(.dn-stats__card--featured):hover .dn-stats__icon {
    background: var(--color-badge-bg);
}

/* Stat number */
.dn-stats__number {
    font-family: var(--font-display);
    font-size: clamp(2rem, 4vw, 2.75rem);
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.02em;
    color: var(--color-navy);
    transition: color var(--transition);
}

.dn-stats__card--featured .dn-stats__number {
    color: #fff;
}

/* Stat label */
.dn-stats__label {
    font-size: 0.82rem;
    font-weight: 400;
    color: var(--color-text-muted);
    letter-spacing: 0.01em;
    transition: color var(--transition);
}

.dn-stats__card--featured .dn-stats__label {
    color: rgba(255, 255, 255, 0.65);
}

/* =========================================================
   SERVICE SUITES — SECTION 3
   ========================================================= */
.dn-services {
    background: #e9effb;
    padding-block: 60px 80px;
}

.dn-services__inner {
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--container-pad);
    display: flex;
    flex-direction: column;
    gap: 28px;
}

.dn-services__inner--stack {
    align-items: stretch;
    gap: 24px;
}

.dn-services__header {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.dn-services__header--left {
    text-align: left;
}

.dn-services__heading {
    font-family: var(--font-display);
    font-size: clamp(1.6rem, 3vw, 2rem);
    font-weight: 800;
    color: var(--color-navy);
    letter-spacing: -0.01em;
}

.dn-services__subheading {
    font-size: 0.95rem;
    color: var(--color-text-muted);
    max-width: 52ch;
}

/* Services page intro */
.dn-services__intro {
    display: flex;
    flex-direction: column;
    gap: 10px;
    background: #eef3fb;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 20px 22px;
    box-shadow: var(--shadow-sm);
}
.dn-services__intro-heading {
    font-family: var(--font-display);
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--color-navy);
}

.dn-services__eyebrow {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    margin-bottom: 14px;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(221, 234, 248, 0.92);
    color: var(--color-blue-cta);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.dn-services__intro-body {
    font-size: 0.95rem;
    color: var(--color-text-body);
    line-height: 1.6;
}


.dn-services__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
}

.dn-services__grid--detailed {
    align-items: stretch;
}

.dn-service-card {
    position: relative;
    background: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: 24px;
    padding: 24px 24px 22px;
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    gap: 12px;
    transition: transform var(--transition), box-shadow var(--transition), background var(--transition), border-color var(--transition);
    overflow: hidden;
}

.dn-service-card::after {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 72px;
    background: linear-gradient(180deg, rgba(221, 234, 248, 0.38), rgba(221, 234, 248, 0));
    pointer-events: none;
}

.dn-service-card__index {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    margin-left: auto;
    border-radius: 14px;
    background: rgba(221, 234, 248, 0.72);
    color: var(--color-blue-cta);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
}

.dn-service-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-md);
    border-color: rgba(58, 107, 200, 0.2);
}

.dn-service-card--featured {
    background: var(--color-navy);
    border-color: var(--color-navy);
    box-shadow: var(--shadow-md);
}

.dn-service-card--featured .dn-service-card__index {
    background: rgba(255, 255, 255, 0.14);
    color: rgba(255, 255, 255, 0.9);
}

.dn-service-card__icon {
    width: 46px;
    height: 46px;
    border-radius: 12px;
    background: var(--color-badge-bg);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--color-blue-accent);
    overflow: hidden;
    flex-shrink: 0;
    transition: background var(--transition), color var(--transition);
}

.dn-service-card__icon img {
    width: 32px;
    height: 32px;
    object-fit: contain;
}

.dn-service-card__media-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 12px;
}

.dn-service-card__icon svg {
    width: 30px;
    height: 30px;
}

.dn-service-card--featured .dn-service-card__icon {
    background: rgba(255, 255, 255, 0.14);
    color: #fff;
}

.dn-services__icon-placeholder {
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: var(--color-blue-accent);
    opacity: 0.3;
}

.dn-service-card__title {
    font-family: var(--font-display);
    font-size: 1.12rem;
    font-weight: 800;
    color: var(--color-navy);
    letter-spacing: -0.01em;
    overflow-wrap: anywhere;
    line-height: 1.3;
}

.dn-service-card--featured .dn-service-card__title {
    color: #fff;
}

.dn-service-card__desc {
    font-size: 0.92rem;
    line-height: 1.7;
    color: var(--color-text-muted);
}

.dn-service-card__meta {
    font-size: 0.95rem;
    font-weight: 700;
    line-height: 1.6;
    color: var(--color-text-body);
    margin-top: -2px;
}

.dn-service-card__list {
    display: grid;
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.dn-service-card__list li {
    position: relative;
    padding-left: 18px;
    font-size: 0.88rem;
    line-height: 1.7;
    color: var(--color-text-body);
}

.dn-service-card__list li::before {
    content: '';
    position: absolute;
    top: 0.62em;
    left: 0;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--color-blue-accent);
    opacity: 0.9;
}

.dn-service-card__rate {
    margin-top: auto;
    font-size: 0.9rem;
    font-weight: 700;
    line-height: 1.6;
    color: var(--color-navy);
}

.dn-service-card--featured .dn-service-card__desc {
    color: rgba(255, 255, 255, 0.78);
}

.dn-service-card--featured .dn-service-card__meta,
.dn-service-card--featured .dn-service-card__list li,
.dn-service-card--featured .dn-service-card__rate {
    color: rgba(255, 255, 255, 0.88);
}

.dn-service-card--featured .dn-service-card__list li::before {
    background: #ffffff;
    opacity: 0.95;
}

.dn-service-card__cta {
    margin-top: auto;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.83rem;
    font-weight: 700;
    color: var(--color-navy);
    letter-spacing: 0.01em;
    transition: color var(--transition), transform var(--transition);
    padding-top: 8px;
}

.dn-service-card__cta span { font-size: 0.9rem; }

.dn-service-card__cta:hover {
    color: var(--color-blue-accent);
    transform: translateX(3px);
}

.dn-service-card--featured .dn-service-card__cta {
    color: #fff;
}

.dn-service-card--featured .dn-service-card__cta:hover {
    color: #e4edff;
}

.dn-home-note__card--services {
    position: relative;
    overflow: hidden;
}

.dn-home-note__card--services::before {
    content: "";
    position: absolute;
    top: -38px;
    right: -24px;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(58, 107, 200, 0.12), rgba(58, 107, 200, 0));
    pointer-events: none;
}

/* =========================================================
   THE DIVINE STANDARD — SECTION 4
   ========================================================= */
.dn-standard {
    background: #eef3fb;
    padding-block: 70px 80px;
}

.dn-standard__inner {
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--container-pad);
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: 40px;
    align-items: center;
}

.dn-standard__content {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.dn-standard__heading {
    font-family: var(--font-display);
    font-size: clamp(1.8rem, 3vw, 2.2rem);
    font-weight: 800;
    color: var(--color-navy);
    letter-spacing: -0.01em;
}

.dn-standard__list {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.dn-standard__item {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 14px;
    align-items: flex-start;
}

.dn-standard__icon {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: #dfe8f8;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--color-blue-accent);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
}

.dn-standard__icon img {
    width: 28px;
    height: 28px;
    object-fit: contain;
}

.dn-standard__icon svg {
    width: 26px;
    height: 26px;
}

.dn-standard__icon-placeholder {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--color-blue-accent);
    opacity: 0.3;
}

.dn-standard__title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-navy);
    margin-bottom: 4px;
}

.dn-standard__desc {
    font-size: 0.9rem;
    color: var(--color-text-muted);
    line-height: 1.6;
}

.dn-standard__media {
    display: flex;
    justify-content: center;
}

.dn-standard__img {
    width: min(480px, 100%);
    border-radius: 22px;
    object-fit: cover;
    box-shadow: var(--shadow-lg);
}

.dn-standard__img-placeholder {
    width: min(480px, 100%);
    aspect-ratio: 1;
    border-radius: 22px;
    overflow: hidden;
    background: var(--color-border);
}

/* =========================================================
   PRICING / INVESTMENT — SECTION 5
   ========================================================= */
.dn-pricing {
    background: #e9effb;
    padding-block: 64px 80px;
}

.dn-pricing__inner {
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--container-pad);
    display: flex;
    flex-direction: column;
    gap: 28px;
}

.dn-pricing__header {
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.dn-pricing__heading {
    font-family: var(--font-display);
    font-size: clamp(1.8rem, 3vw, 2.25rem);
    font-weight: 800;
    color: var(--color-navy);
}

.dn-pricing__subheading {
    font-size: 0.95rem;
    color: var(--color-text-muted);
}

.dn-pricing__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}

.dn-price-card {
    position: relative;
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: 18px;
    padding: 22px 22px 20px;
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    gap: 14px;
    min-height: 100%;
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.dn-price-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
    border-color: rgba(58, 107, 200, 0.24);
}

.dn-price-card--featured {
    background: var(--color-navy);
    color: #fff;
    border-color: var(--color-navy);
    box-shadow: var(--shadow-md);
}

.dn-price-card__badge {
    align-self: center;
    background: #f037a5;
    color: #fff;
    padding: 6px 12px;
    border-radius: var(--radius-pill);
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    box-shadow: 0 6px 18px rgba(240, 55, 165, 0.35);
}

.dn-price-card__title {
    font-family: var(--font-display);
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--color-navy);
}

.dn-price-card--featured .dn-price-card__title {
    color: #fff;
}

.dn-price-card__price {
    display: flex;
    align-items: baseline;
    gap: 6px;
}

.dn-price-card__amount {
    font-family: var(--font-display);
    font-size: 2.4rem;
    font-weight: 800;
    color: var(--color-navy);
}

.dn-price-card__suffix {
    font-size: 0.95rem;
    color: var(--color-text-muted);
}

.dn-price-card--featured .dn-price-card__amount { color: #fff; }
.dn-price-card--featured .dn-price-card__suffix { color: rgba(255,255,255,0.8); }

.dn-price-card__features {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 0;
    margin: 4px 0 0;
}

.dn-price-card__features li {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 10px;
    align-items: center;
    font-size: 0.9rem;
    color: var(--color-text-body);
}

.dn-price-card--featured .dn-price-card__features li { color: rgba(255,255,255,0.9); }

.dn-price-card__check {
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: #dfe8f8;
    color: var(--color-blue-accent);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.9rem;
    box-shadow: var(--shadow-sm);
}

.dn-price-card--featured .dn-price-card__check {
    background: rgba(255,255,255,0.15);
    color: #fff;
}

.dn-price-card__cta {
    margin-top: auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 18px;
    border-radius: 999px;
    border: 2px solid var(--color-border);
    color: var(--color-navy);
    font-weight: 700;
    transition: background var(--transition), color var(--transition), border-color var(--transition), transform var(--transition);
}

.dn-price-card__cta:hover {
    background: var(--color-badge-bg);
    border-color: var(--color-badge-bg);
    transform: translateY(-2px);
}

.dn-price-card--featured .dn-price-card__cta {
    background: #fff;
    color: var(--color-navy);
    border-color: #fff;
    box-shadow: var(--shadow-md);
}

.dn-price-card--featured .dn-price-card__cta:hover {
    background: #e9effb;
    border-color: #e9effb;
}

/* =========================================================
   PACKAGES PAGE
   ========================================================= */
.dn-packages {
    background: #e9effb;
    padding-block: 64px 80px;
}

.dn-packages__inner {
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--container-pad);
    display: flex;
    flex-direction: column;
    gap: 30px;
}

.dn-packages__header {
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.dn-packages__heading {
    font-family: var(--font-display);
    font-size: clamp(1.8rem, 3vw, 2.25rem);
    font-weight: 800;
    color: var(--color-navy);
}

.dn-packages__subheading {
    font-size: 0.98rem;
    color: var(--color-text-muted);
}

.dn-packages__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}

.dn-package-card {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: 22px;
    padding: 24px 22px 22px;
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    gap: 12px;
    min-height: 100%;
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition), background var(--transition);
}

.dn-package-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
    border-color: rgba(58, 107, 200, 0.24);
}

.dn-package-card--featured {
    background: var(--color-navy);
    border-color: var(--color-navy);
    box-shadow: var(--shadow-md);
}

.dn-package-card__icon {
    width: 56px;
    height: 56px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 16px;
    background: #d7e6fb;
    color: #3f6f9f;
    margin-bottom: 4px;
}

.dn-package-card__icon img,
.dn-package-card__icon svg {
    width: 28px;
    height: 28px;
}

.dn-package-card__hours {
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-blue-accent);
}

.dn-package-card__title {
    font-family: var(--font-display);
    font-size: 1.45rem;
    font-weight: 800;
    line-height: 1.2;
    color: var(--color-navy);
}

.dn-package-card__rate {
    font-size: 1.1rem;
    font-weight: 700;
    line-height: 1.5;
    color: var(--color-text-body);
}

.dn-package-card__note {
    font-size: 0.92rem;
    line-height: 1.6;
    color: var(--color-text-muted);
}

.dn-package-card__cta {
    margin-top: auto;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.88rem;
    font-weight: 700;
    color: var(--color-navy);
    transition: color var(--transition), transform var(--transition);
}

.dn-package-card__cta:hover {
    color: var(--color-blue-accent);
    transform: translateX(3px);
}

.dn-package-card--featured .dn-package-card__icon {
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
}

.dn-package-card--featured .dn-package-card__hours,
.dn-package-card--featured .dn-package-card__title,
.dn-package-card--featured .dn-package-card__rate,
.dn-package-card--featured .dn-package-card__cta {
    color: #fff;
}

.dn-package-card--featured .dn-package-card__note {
    color: rgba(255, 255, 255, 0.82);
}

.dn-packages__notes {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 18px;
}

.dn-packages__note-card {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: 20px;
    padding: 24px;
    box-shadow: var(--shadow-sm);
}

.dn-packages__note-card h3 {
    margin: 0 0 10px;
    font-family: var(--font-display);
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--color-navy);
}

.dn-packages__note-card p {
    margin: 0;
    font-size: 0.98rem;
    line-height: 1.75;
    color: var(--color-text-body);
}

/* =========================================================
   EDITORIAL JOURNAL — SECTION 6
   ========================================================= */
.dn-journal {
    background: #eef3fb;
    padding-block: 60px 70px;
}

.dn-journal__inner {
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--container-pad);
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.dn-journal__top {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: center;
}

.dn-journal__heading {
    font-family: var(--font-display);
    font-size: 1.6rem;
    font-weight: 800;
    color: var(--color-navy);
}

.dn-journal__eyebrow {
    display: inline-flex;
    align-items: center;
    margin-bottom: 14px;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(221, 234, 248, 0.92);
    color: var(--color-blue-cta);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.dn-journal__subheading {
    font-size: 0.95rem;
    color: var(--color-text-muted);
    max-width: 38ch;
    line-height: 1.7;
}

.dn-journal__link {
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--color-blue-accent);
    transition: color var(--transition), transform var(--transition);
}

.dn-journal__link:hover { color: var(--color-navy); transform: translateX(3px); }

.dn-journal__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
}

.dn-journal__card {
    position: relative;
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: 24px;
    box-shadow: var(--shadow-sm);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    min-height: 100%;
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.dn-journal__card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-md);
    border-color: rgba(58, 107, 200, 0.18);
}

.dn-journal__card::after {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 88px;
    background: linear-gradient(180deg, rgba(221, 234, 248, 0.34), rgba(221, 234, 248, 0));
    pointer-events: none;
}

.dn-blog-topics {
    padding: 28px 0 12px;
}

.dn-blog-topics__inner {
    width: min(1180px, calc(100% - 48px));
    margin: 0 auto;
}

.dn-blog-topics__header {
    margin-bottom: 22px;
}

.dn-blog-topics__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
}

.dn-blog-topics__card {
    min-height: 170px;
    padding: 26px;
    border-radius: 30px;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(43, 76, 126, 0.1);
    box-shadow: var(--shadow-soft);
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.dn-blog-topics__card:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-md);
    border-color: rgba(58, 107, 200, 0.16);
}

.dn-blog-topics__index {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 46px;
    height: 46px;
    margin-bottom: 18px;
    border-radius: 16px;
    background: rgba(221, 234, 248, 0.92);
    color: var(--color-blue-cta);
    font-size: 0.92rem;
    font-weight: 800;
    letter-spacing: 0.08em;
}

.dn-blog-topics__title {
    margin: 0;
    color: var(--color-navy);
    font-family: var(--font-display);
    font-size: clamp(1.25rem, 2vw, 1.6rem);
    font-weight: 800;
    line-height: 1.15;
}

.dn-journal__media img,
.dn-journal__img-placeholder {
    width: 100%;
    height: 200px;
    object-fit: cover;
    display: block;
}

.dn-journal__img-placeholder {
    background: linear-gradient(135deg, #d8e2f5, #e8edf9);
}

.dn-journal__body {
    padding: 20px 20px 24px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.dn-journal__tag {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 7px 11px;
    border-radius: 999px;
    background: rgba(221, 234, 248, 0.9);
    font-size: 0.7rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-blue-cta);
    font-weight: 700;
}

.dn-journal__title {
    font-family: var(--font-display);
    font-size: 1.18rem;
    font-weight: 800;
    color: var(--color-navy);
    line-height: 1.3;
}

.dn-journal__excerpt {
    font-size: 0.94rem;
    color: var(--color-text-body);
    line-height: 1.7;
}

.dn-journal__top--blog {
    align-items: end;
    margin-bottom: 4px;
}

.dn-pagination {
    margin-top: 30px;
}

.dn-pagination ul {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: center;
    list-style: none;
    margin: 0;
    padding: 0;
}

.dn-pagination a,
.dn-pagination span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    height: 44px;
    padding: 0 14px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(43, 76, 126, 0.1);
    color: var(--color-navy);
    font-weight: 700;
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition), background var(--transition);
}

.dn-pagination a:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-sm);
    border-color: rgba(58, 107, 200, 0.18);
}

.dn-pagination .current {
    background: var(--color-navy);
    border-color: var(--color-navy);
    color: #fff;
}

/* =========================================================
   CTA BANNER — SECTION 7
   ========================================================= */
.dn-cta {
    background: #eef3fb;
    padding-block: 50px 70px;
}

.dn-cta__inner {
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--container-pad);
    background: var(--color-navy);
    color: #fff;
    border-radius: 18px;
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    align-items: stretch;
    overflow: hidden;
    box-shadow: var(--shadow-md);
}

.dn-cta__content {
    padding: 28px 32px 28px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.dn-cta__heading {
    font-family: var(--font-display);
    font-size: clamp(1.6rem, 3vw, 2rem);
    font-weight: 800;
}

.dn-cta__subheading {
    font-size: 0.95rem;
    color: rgba(255,255,255,0.85);
    line-height: 1.6;
}

.dn-cta__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    padding: 12px 22px;
    border-radius: 999px;
    background: #fff;
    color: var(--color-navy);
    font-weight: 700;
    transition: transform var(--transition), box-shadow var(--transition), background var(--transition);
    border: 2px solid transparent;
}

.dn-cta__button:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
    background: #e9effb;
}

.dn-cta__media {
    position: relative;
    min-height: 100%;
}

.dn-cta__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.dn-cta__img-placeholder {
    width: 100%;
    height: 100%;
    min-height: 260px;
    background: linear-gradient(135deg, rgba(255,255,255,0.2), rgba(255,255,255,0.05));
}

/* =========================================================
   LEGAL / GENERIC TEXT SECTIONS
   ========================================================= */
.dn-legal {
    background: var(--color-bg);
    padding: 50px var(--container-pad);
}
.dn-legal__inner {
    max-width: var(--container-max);
    margin-inline: auto;
    display: flex;
    flex-direction: column;
    gap: 18px;
    font-size: 0.95rem;
    color: var(--color-text-body);
}
.dn-legal__inner h2 {
    font-family: var(--font-display);
    font-size: 1.4rem;
    font-weight: 800;
    color: var(--color-navy);
    margin-top: 4px;
}
.dn-legal__inner ul {
    list-style: disc;
    margin-left: 20px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.dn-legal__two-col {
    display: grid;
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap: 24px;
}

@media (max-width: 768px) {
    .dn-legal__two-col { grid-template-columns: 1fr; }
}

/* =========================================================
   SLEEP TRAINING PAGE
   ========================================================= */
.dn-st-hero {
    position: relative;
    background:
        radial-gradient(circle at 14% 18%, rgba(221, 234, 248, 0.9), transparent 0 24%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.55), rgba(238, 243, 251, 0.75));
    padding: 82px var(--container-pad) 68px;
    overflow: hidden;
}

.dn-st-hero::after {
    content: "";
    position: absolute;
    top: 24px;
    right: clamp(24px, 8vw, 120px);
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(58, 107, 200, 0.12), rgba(58, 107, 200, 0));
    pointer-events: none;
}
.dn-st-hero__inner {
    max-width: var(--container-max);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    gap: 52px;
    align-items: center;
}
.dn-st-hero__badge {
    display: inline-flex;
    align-items: center;
    padding: 6px 14px;
    border-radius: var(--radius-pill);
    background: var(--color-badge-bg);
    color: var(--color-blue-accent);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-size: 0.72rem;
}
.dn-st-hero__heading {
    font-family: var(--font-display);
    font-size: clamp(2.2rem, 4.4vw, 3.15rem);
    font-weight: 800;
    color: var(--color-navy);
    line-height: 1.05;
    letter-spacing: -0.04em;
    margin: 16px 0 12px;
}
.dn-st-hero__subheading {
    font-size: 1.04rem;
    color: var(--color-text-body);
    line-height: 1.8;
    margin-bottom: 20px;
    max-width: 58ch;
    padding-left: 20px;
    list-style: circle;
}
.dn-st-hero__actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}
.dn-st-hero__media {
    display: flex;
    justify-content: center;
}
.dn-st-hero__img {
    width: 100%;
    max-width: 520px;
    border-radius: 30px;
    object-fit: cover;
    box-shadow: var(--shadow-lg);
}
.dn-st-hero__placeholder {
    width: 100%;
    max-width: 520px;
    aspect-ratio: 4/5;
    border-radius: 30px;
    background:
        radial-gradient(circle at 30% 28%, rgba(143, 177, 229, 0.34), transparent 0 14%),
        linear-gradient(180deg, #dfe6f3, #eef3fb);
}

.dn-st-highlights {
    background: #eef3fb;
    padding: 40px var(--container-pad) 50px;
}
.dn-st-highlights__inner {
    max-width: var(--container-max);
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}
.dn-st-highlights__card {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: 16px;
    padding: 18px 18px 20px;
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.dn-st-highlights__icon {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    background: var(--color-badge-bg);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    color: var(--color-blue-accent);
}
.dn-st-highlights__icon img { width: 32px; height: 32px; object-fit: contain; }
.dn-st-highlights__card h3 {
    font-family: var(--font-display);
    font-size: 1.05rem;
    color: var(--color-navy);
}
.dn-st-highlights__card p {
    font-size: 0.92rem;
    color: var(--color-text-body);
    line-height: 1.6;
}

.dn-st-outcomes {
    background: var(--color-bg-white);
    padding: 50px var(--container-pad);
}
.dn-st-outcomes__inner {
    max-width: 900px;
    margin: 0 auto;
}
.dn-st-outcomes__inner h2 {
    font-family: var(--font-display);
    font-size: 1.6rem;
    font-weight: 800;
    color: var(--color-navy);
    margin-bottom: 18px;
}
.dn-st-outcomes__list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.dn-st-outcomes__list li {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 10px;
    align-items: center;
    font-size: 0.96rem;
    color: var(--color-text-body);
}
.dn-st-outcomes__dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: var(--color-blue-accent);
    opacity: 0.7;
}

.dn-st-feature {
    background: #eef3fb;
    padding: 60px var(--container-pad);
}
.dn-st-feature__inner {
    max-width: var(--container-max);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
    align-items: center;
}
.dn-st-feature__content h2 {
    font-family: var(--font-display);
    font-size: 1.6rem;
    font-weight: 800;
    color: var(--color-navy);
    margin-bottom: 12px;
}
.dn-st-feature__content p {
    font-size: 0.95rem;
    color: var(--color-text-body);
    line-height: 1.7;
}
.dn-st-feature__img {
    width: 100%;
    border-radius: var(--radius-lg);
    object-fit: cover;
    box-shadow: var(--shadow-md);
}
.dn-st-feature__placeholder {
    width: 100%;
    aspect-ratio: 4/3;
    border-radius: var(--radius-lg);
    background: #dfe6f3;
}

.dn-st-cta {
    background: var(--color-bg);
    padding: 60px var(--container-pad) 80px;
}
.dn-st-cta__inner {
    max-width: var(--container-max);
    margin: 0 auto;
    background: var(--color-navy);
    color: #fff;
    border-radius: 18px;
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    overflow: hidden;
    box-shadow: var(--shadow-md);
}
.dn-st-cta__content {
    padding: 28px 32px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.dn-st-cta__content h2 {
    font-family: var(--font-display);
    font-size: 1.7rem;
    font-weight: 800;
}
.dn-st-cta__content p {
    color: rgba(255,255,255,0.82);
    line-height: 1.6;
}
.dn-st-cta__media {
    position: relative;
}
.dn-st-cta__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.dn-st-cta__img-placeholder {
    width: 100%;
    height: 100%;
    min-height: 240px;
    background: linear-gradient(135deg, rgba(255,255,255,0.2), rgba(255,255,255,0.05));
}

/* Responsive: Sleep Training */
@media (max-width: 1024px) {
    .dn-st-hero__inner { grid-template-columns: 1fr; }
    .dn-st-feature__inner { grid-template-columns: 1fr; }
    .dn-st-cta__inner { grid-template-columns: 1fr; }
    .dn-st-cta__media { order: -1; }
}
@media (max-width: 768px) {
    .dn-st-highlights__inner { grid-template-columns: repeat(2, 1fr); }
    .dn-st-feature { padding: 48px var(--container-pad); }
    .dn-st-hero { padding-block: 56px 50px; }
}
@media (max-width: 560px) {
    .dn-st-highlights__inner { grid-template-columns: 1fr; }
    .dn-st-hero__actions { flex-direction: column; align-items: flex-start; }
    .dn-st-cta { padding-block: 50px 60px; }
}

/* =========================================================
   ABOUT / ARCHITECTS — SECTION 8
   ========================================================= */
.dn-about {
    background: var(--color-bg);
    padding-block: 60px 80px;
}

.dn-about__inner {
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: 56px;
    align-items: center;
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--container-pad);
}

/* Text content */
.dn-about__content {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.dn-about__heading {
    font-family: var(--font-display);
    font-size: clamp(2rem, 3.5vw, 2.75rem);
    font-weight: 800;
    color: var(--color-navy);
    line-height: 1.12;
    letter-spacing: -0.02em;
}

.dn-about__para {
    font-size: 0.9rem;
    line-height: 1.75;
    color: var(--color-text-body);
    max-width: 48ch;
}

/* Media grid — two images side by side */
.dn-about__media {
    display: grid;
    grid-template-columns: 1.35fr 1fr;
    gap: 16px;
    align-items: end;
}

/* Image wrapper base */
.dn-about__img-wrap {
    border-radius: var(--radius-lg);
    overflow: hidden;
    position: relative;
    box-shadow: var(--shadow-md);

    /* Hover lift */
    transition: transform var(--transition), box-shadow var(--transition);
}

.dn-about__img-wrap:hover {
    transform: translateY(-6px) scale(1.015);
    box-shadow: var(--shadow-lg);
}

/* Image 1 — taller */
.dn-about__img-wrap--1 {
    aspect-ratio: 3/4;
}

/* Image 2 — shorter, offset down slightly for visual interest */
.dn-about__img-wrap--2 {
    aspect-ratio: 3/4;
    margin-top: 36px;
}

.dn-about__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.45s cubic-bezier(0.4, 0, 0.2, 1);
}

.dn-about__img-wrap:hover .dn-about__img {
    transform: scale(1.04);
}

.dn-about__img-placeholder {
    width: 100%;
    height: 100%;
    min-height: 300px;
}

.dn-about__img-placeholder svg {
    width: 100%;
    height: 100%;
}

/* =========================================================
   CONTACT
   ========================================================= */
.dn-contact {
    padding: 32px 0 80px;
}

.dn-contact__inner {
    width: min(1180px, calc(100% - 48px));
    margin: 0 auto;
    grid-template-columns: 0.9fr 1.1fr;
    gap: 28px;
    align-items: start;
}

.dn-contact__info,
.dn-contact__form-wrap {
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(43, 76, 126, 0.08);
    border-radius: 32px;
    box-shadow: var(--shadow-soft);
    backdrop-filter: blur(8px);
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.dn-contact__info {
    padding: 36px 32px;
}

.dn-contact__info h2 {
    margin: 0 0 16px;
    font-family: var(--font-display);
    font-size: clamp(1.9rem, 2.8vw, 2.6rem);
    line-height: 1.05;
    color: var(--color-navy);
}

.dn-contact__info p {
    margin: 0 0 22px;
    font-size: 1rem;
    line-height: 1.75;
    color: rgba(37, 57, 92, 0.82);
}

.dn-contact__info h3 {
    margin: 28px 0 12px;
    font-family: var(--font-display);
    font-size: 1.2rem;
    font-weight: 800;
    line-height: 1.2;
    color: var(--color-navy);
}

.dn-contact__list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 14px;
}

.dn-contact__list li {
    padding: 14px 16px;
    border-radius: 18px;
    background: rgba(232, 240, 255, 0.72);
    color: var(--color-navy);
    font-size: 0.98rem;
    line-height: 1.55;
}

.dn-contact__list strong {
    color: var(--color-navy-dark);
}

.dn-contact__map {
    margin-top: 14px;
    overflow: hidden;
    border-radius: 24px;
    border: 1px solid rgba(43, 76, 126, 0.1);
    box-shadow: 0 14px 36px rgba(33, 61, 111, 0.08);
}

.dn-contact__map iframe {
    display: block;
    width: 100%;
    min-height: 320px;
    border: 0;
}

.dn-contact__form-wrap {
    padding: 32px;
    margin-top: 23px;
}

.dn-contact__info:hover,
.dn-contact__form-wrap:hover,
.dn-careers__content:hover,
.dn-careers__media:hover,
.dn-careers-apply__content:hover,
.dn-careers-apply__form-wrap:hover,
.dn-about-page__content:hover,
.dn-about-page__media:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
    border-color: rgba(58, 107, 200, 0.14);
}

.dn-contact__notice {
    padding: 16px 18px;
    border-radius: 18px;
    background: rgba(232, 240, 255, 0.9);
    color: var(--color-navy);
    font-size: 0.98rem;
    line-height: 1.6;
}

.dn-contact__cf7 .wpcf7 {
    margin: 0;
}

.dn-contact__cf7 form {
    display: grid;
    gap: 16px;
}

.dn-contact__cf7 p {
    margin: 0;
    color: var(--color-navy);
    font-size: 0.94rem;
    font-weight: 600;
}

.dn-contact__cf7 label {
    display: grid;
    gap: 8px;
    color: var(--color-navy);
    font-size: 0.94rem;
    font-weight: 600;
}

.dn-contact__cf7 fieldset {
    margin: 0;
    padding: 20px 18px 18px;
    border: 1px solid rgba(43, 76, 126, 0.14);
    border-radius: 22px;
    background: #fff;
}

.dn-contact__cf7 legend {
    padding: 0 8px;
    color: var(--color-navy);
    font-size: 0.94rem;
    font-weight: 700;
}

.dn-contact__cf7 input[type="text"],
.dn-contact__cf7 input[type="email"],
.dn-contact__cf7 input[type="tel"],
.dn-contact__cf7 select,
.dn-contact__cf7 textarea {
    width: 100%;
    border: 1px solid rgba(43, 76, 126, 0.14);
    border-radius: 18px;
    background: #fff;
    padding: 15px 18px;
    color: var(--color-navy);
    font: inherit;
    line-height: 1.5;
    transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}

.dn-contact__cf7 textarea {
    min-height: 150px;
    resize: vertical;
}

.dn-contact__cf7 .wpcf7-checkbox,
.dn-contact__cf7 .wpcf7-radio {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-top: 6px;
}

.dn-contact__cf7 .wpcf7-list-item {
    margin: 0;
}

.dn-contact__cf7 .wpcf7-list-item label {
    display: flex;
    align-items: center;
    gap: 10px;
    min-height: 56px;
    padding: 14px 16px;
    border: 1px solid rgba(43, 76, 126, 0.14);
    border-radius: 18px;
    background: rgba(244, 247, 252, 0.9);
    cursor: pointer;
    transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition), background var(--transition);
}

.dn-contact__cf7 .wpcf7-list-item label:hover {
    border-color: rgba(43, 76, 126, 0.28);
    box-shadow: 0 10px 24px rgba(33, 61, 111, 0.08);
    transform: translateY(-1px);
}

.dn-contact__cf7 .wpcf7-list-item input[type="checkbox"],
.dn-contact__cf7 .wpcf7-list-item input[type="radio"] {
    width: 18px;
    height: 18px;
    margin: 0;
    accent-color: var(--color-blue-cta);
    flex: 0 0 auto;
}

.dn-contact__cf7 .wpcf7-list-item-label {
    color: var(--color-navy);
    font-size: 0.96rem;
    font-weight: 600;
    line-height: 1.4;
}

.dn-contact__conditional-hidden {
    display: none !important;
}

.dn-contact__cf7 input[type="file"] {
    width: 100%;
    padding: 14px 16px;
    border: 1px dashed rgba(43, 76, 126, 0.22);
    border-radius: 18px;
    background: rgba(244, 247, 252, 0.9);
    color: var(--color-navy);
    font-size: 0.95rem;
    line-height: 1.4;
    cursor: pointer;
}

.dn-contact__cf7 input[type="file"]::file-selector-button {
    margin-right: 14px;
    border: 0;
    border-radius: 999px;
    background: var(--color-navy);
    color: #fff;
    padding: 10px 16px;
    font-family: inherit;
    font-size: 0.9rem;
    font-weight: 700;
    cursor: pointer;
}

.dn-contact__cf7 input:focus,
.dn-contact__cf7 select:focus,
.dn-contact__cf7 textarea:focus {
    outline: none;
    border-color: rgba(43, 76, 126, 0.35);
    box-shadow: 0 0 0 4px rgba(143, 177, 229, 0.22);
    transform: translateY(-1px);
}

.dn-contact__cf7 .wpcf7-submit {
    min-width: 190px;
    border: 0;
    border-radius: 999px;
    background: var(--color-navy);
    color: #fff;
    padding: 14px 24px;
    font: inherit;
    font-weight: 700;
    cursor: pointer;
    transition: transform var(--transition), box-shadow var(--transition), background var(--transition);
    box-shadow: 0 16px 32px rgba(33, 61, 111, 0.18);
}

.dn-contact__cf7 .wpcf7-submit:hover {
    transform: translateY(-2px);
}

.dn-contact__cf7 .wpcf7-spinner {
    margin: 0 0 0 12px;
}

.dn-contact__cf7 .wpcf7-not-valid-tip,
.dn-contact__cf7 .wpcf7-response-output {
    margin: 8px 0 0;
    font-size: 0.92rem;
    border-radius: 14px;
}

.dn-contact__cf7 .wpcf7-response-output {
    padding: 12px 14px;
}

/* =========================================================
   CAREERS
   ========================================================= */
.dn-careers,
.dn-careers-apply {
    padding: 28px 0 72px;
}

.dn-careers-intro__card {
    position: relative;
    overflow: hidden;
}

.dn-careers-intro__card::after {
    content: "";
    position: absolute;
    top: -48px;
    right: -18px;
    width: 170px;
    height: 170px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(58, 107, 200, 0.12), rgba(58, 107, 200, 0));
    pointer-events: none;
}

.dn-careers-intro__eyebrow,
.dn-careers-earnings__eyebrow {
    display: inline-flex;
    align-items: center;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(221, 234, 248, 0.9);
    color: var(--color-blue-cta);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.dn-careers-earnings {
    padding: 0 0 72px;
}

.dn-careers-earnings__inner {
    width: min(1180px, calc(100% - 48px));
    margin: 0 auto;
}

.dn-careers-earnings__header {
    margin-bottom: 24px;
}

.dn-careers-earnings__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.dn-careers-earnings__card {
    position: relative;
    min-height: 100%;
    padding: 26px 24px 24px;
    background:
        linear-gradient(180deg, rgba(221, 234, 248, 0.5), rgba(255, 255, 255, 0) 40%),
        rgba(255, 255, 255, 0.98);
    border: 1px solid rgba(43, 76, 126, 0.08);
    border-radius: 28px;
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.dn-careers-earnings__card:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-md);
    border-color: rgba(58, 107, 200, 0.16);
}

.dn-careers-earnings__index {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    height: 44px;
    margin-bottom: 18px;
    padding: 0 12px;
    border-radius: 14px;
    background: var(--color-navy);
    color: #fff;
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    box-shadow: 0 14px 24px rgba(26, 43, 74, 0.18);
}

.dn-careers-earnings__text {
    margin: 0;
    color: var(--color-navy);
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.7;
}

.dn-careers__inner,
.dn-careers-apply__inner {
    width: min(1180px, calc(100% - 48px));
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 0.92fr);
    gap: 28px;
    align-items: stretch;
}

.dn-careers__content,
.dn-careers__media,
.dn-careers-apply__content,
.dn-careers-apply__form-wrap {
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(43, 76, 126, 0.08);
    border-radius: 32px;
    box-shadow: var(--shadow-soft);
    backdrop-filter: blur(8px);
}

.dn-careers__content,
.dn-careers-apply__content {
    padding: 38px 36px;
}

.dn-careers__eyebrow,
.dn-careers-apply__eyebrow {
    display: inline-flex;
    align-items: center;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(221, 234, 248, 0.88);
    color: var(--color-blue-cta);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.11em;
    text-transform: uppercase;
}

.dn-careers__heading,
.dn-careers-apply__heading {
    margin: 20px 0 16px;
    font-family: var(--font-display);
    font-size: clamp(2rem, 3.3vw, 3.4rem);
    line-height: 0.98;
    letter-spacing: -0.03em;
    color: var(--color-navy);
}

.dn-careers__body,
.dn-careers-apply__body {
    margin: 0 0 24px;
    font-size: 1rem;
    line-height: 1.8;
    color: rgba(37, 57, 92, 0.82);
    max-width: 62ch;
}

.dn-careers-apply__img {
    width: 100%;
    min-height: 280px;
    border-radius: 28px;
    object-fit: cover;
    box-shadow: var(--shadow-md);
}

.dn-careers__steps {
    display: grid;
    gap: 14px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.dn-careers__step {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 16px;
    align-items: start;
    padding: 16px 18px;
    border-radius: 20px;
    background: rgba(232, 240, 255, 0.68);
}

.dn-careers__step-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--color-navy);
    color: #fff;
    font-size: 0.84rem;
    font-weight: 700;
    letter-spacing: 0.08em;
}

.dn-careers__step-text {
    color: var(--color-navy);
    font-size: 0.98rem;
    line-height: 1.65;
}

.dn-careers__media {
    overflow: hidden;
    min-height: 100%;
}

.dn-careers__img,
.dn-careers__placeholder {
    width: 100%;
    height: 100%;
    min-height: 560px;
    object-fit: cover;
}

.dn-careers__placeholder {
    background:
        radial-gradient(circle at 24% 24%, rgba(143, 177, 229, 0.34), transparent 0 13%),
        linear-gradient(180deg, rgba(221, 234, 248, 0.92), rgba(245, 247, 252, 1));
}

.dn-careers-apply {
    padding-top: 0;
}

.dn-careers-apply__skills-card {
    margin-top: 26px;
    padding: 24px;
    border-radius: 24px;
    background: linear-gradient(180deg, rgba(232, 240, 255, 0.8), rgba(244, 247, 252, 0.95));
}

.dn-careers-apply__skills-card h3 {
    margin: 0 0 10px;
    font-family: var(--font-display);
    font-size: 1.5rem;
    line-height: 1.1;
    color: var(--color-navy);
}

.dn-careers-apply__skills-card p {
    margin: 0 0 16px;
    color: rgba(37, 57, 92, 0.82);
    line-height: 1.75;
}

.dn-careers-apply__skills-list {
    display: grid;
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.dn-careers-apply__skills-list li {
    position: relative;
    padding-left: 24px;
    color: var(--color-navy);
    line-height: 1.6;
}

.dn-careers-apply__skills-list li::before {
    content: '';
    position: absolute;
    top: 0.68em;
    left: 0;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--color-blue-cta);
    box-shadow: 0 0 0 5px rgba(143, 177, 229, 0.24);
}

.dn-careers-apply__form-wrap {
    padding: 32px;
}

/* =========================================================
   404
   ========================================================= */
.dn-404 {
    padding: 42px 0 86px;
}

.dn-404__inner {
    width: min(1180px, calc(100% - 48px));
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
    gap: 30px;
    align-items: stretch;
}

.dn-404__content,
.dn-404__panel {
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(43, 76, 126, 0.08);
    border-radius: 34px;
    box-shadow: 0 18px 48px rgba(33, 61, 111, 0.08);
}

.dn-404__content {
    padding: 44px 42px;
}

.dn-404__badge {
    display: inline-flex;
    align-items: center;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(221, 234, 248, 0.9);
    color: var(--color-blue-cta);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.dn-404__code {
    margin: 22px 0 8px;
    font-family: var(--font-display);
    font-size: clamp(4.5rem, 10vw, 7rem);
    line-height: 0.9;
    letter-spacing: -0.05em;
    color: var(--color-navy);
}

.dn-404__heading {
    margin: 0;
    max-width: 11ch;
    font-family: var(--font-display);
    font-size: clamp(2rem, 4vw, 3.6rem);
    line-height: 0.96;
    letter-spacing: -0.04em;
    color: var(--color-navy);
}

.dn-404__body {
    margin: 20px 0 0;
    max-width: 58ch;
    font-size: 1rem;
    line-height: 1.8;
    color: rgba(37, 57, 92, 0.82);
}

.dn-404__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 28px;
}

.dn-404__panel {
    display: grid;
    gap: 14px;
    padding: 20px;
    background:
        radial-gradient(circle at top right, rgba(143, 177, 229, 0.14), transparent 32%),
        rgba(255, 255, 255, 0.94);
}

.dn-404__card {
    padding: 22px 22px 24px;
    border-radius: 24px;
    background: rgba(232, 240, 255, 0.72);
    color: var(--color-navy);
}

.dn-404__card--large {
    background: var(--color-navy);
    color: #fff;
}

.dn-404__card-label {
    display: block;
    margin-bottom: 10px;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: inherit;
    opacity: 0.7;
}

.dn-404__card strong {
    display: block;
    font-family: var(--font-display);
    font-size: 1.45rem;
    line-height: 1.12;
    letter-spacing: -0.02em;
}

.dn-404__card a {
    display: inline-flex;
    align-items: center;
    margin-top: 18px;
    font-size: 0.94rem;
    font-weight: 700;
    color: inherit;
}

.dn-404__card a::after {
    content: '→';
    margin-left: 8px;
}

.dn-404__links {
    width: min(1180px, calc(100% - 48px));
    margin: 22px auto 0;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.dn-404__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 18px;
    border-radius: 999px;
    border: 1px solid rgba(43, 76, 126, 0.12);
    background: rgba(255, 255, 255, 0.78);
    color: var(--color-navy);
    font-size: 0.92rem;
    font-weight: 600;
    transition: transform var(--transition), background var(--transition), box-shadow var(--transition);
}

.dn-404__link:hover {
    background: rgba(221, 234, 248, 0.82);
    transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(33, 61, 111, 0.08);
}

/* =========================================================
   HOMEPAGE CLIENT CONTENT
   ========================================================= */
.dn-home-copy,
.dn-home-trust,
.dn-home-statistics,
.dn-testimonials,
.dn-home-note {
    padding: 0 0 72px;
}

.dn-home-copy__inner,
.dn-home-trust__inner,
.dn-home-statistics__inner,
.dn-testimonials__inner,
.dn-home-note__inner {
    width: min(1180px, calc(100% - 48px));
    margin: 0 auto;
}

.dn-home-copy__card,
.dn-home-statistics__inner,
.dn-home-note__card {
    padding: 36px 38px;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(43, 76, 126, 0.08);
    border-radius: 32px;
    box-shadow: var(--shadow-soft);
    backdrop-filter: blur(8px);
}

.dn-home-copy__eyebrow {
    display: inline-flex;
    align-items: center;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(221, 234, 248, 0.9);
    color: var(--color-blue-cta);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.dn-home-copy__heading {
    margin: 18px 0 14px;
    font-family: var(--font-display);
    font-size: clamp(1.9rem, 3vw, 2.8rem);
    font-weight: 800;
    line-height: 1.05;
    letter-spacing: -0.03em;
    color: var(--color-navy);
}

.dn-home-copy__body,
.dn-home-statistics__body,
.dn-testimonials__subheading {
    font-size: 1rem;
    line-height: 1.8;
    color: rgba(37, 57, 92, 0.82);
}

.dn-home-trust__inner {
    display: grid;
    gap: 24px;
}

.dn-home-trust__list {
    display: grid;
    gap: 14px;
}

.dn-home-trust__item {
    position: relative;
    padding: 18px 18px 18px 54px;
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(43, 76, 126, 0.08);
    border-radius: 24px;
    box-shadow: 0 16px 36px rgba(33, 61, 111, 0.06);
    color: var(--color-navy);
    line-height: 1.75;
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.dn-home-trust__item:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
    border-color: rgba(58, 107, 200, 0.14);
}

.dn-home-trust__item::before {
    content: '';
    position: absolute;
    top: 21px;
    left: 22px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--color-blue-cta);
    box-shadow: 0 0 0 6px rgba(143, 177, 229, 0.18);
}

.dn-home-statistics__body p + p {
    margin-top: 18px;
}

.dn-testimonials__header {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 24px;
}

.dn-testimonials__eyebrow {
    display: inline-flex;
    align-items: center;
    margin-bottom: 14px;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(221, 234, 248, 0.92);
    color: var(--color-blue-cta);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.dn-testimonials__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.dn-testimonials__slider {
    display: grid;
    gap: 22px;
}

.dn-testimonials__viewport {
    overflow: hidden;
}

.dn-testimonials__track {
    display: flex;
    transition: transform 0.45s cubic-bezier(0.4, 0, 0.2, 1);
    will-change: transform;
}

.dn-testimonials__slide {
    flex: 0 0 100%;
    min-width: 100%;
}

.dn-testimonials__slide .dn-testimonials__card {
    height: 100%;
}

@media (min-width: 768px) {
    .dn-testimonials__slide {
        flex-basis: 50%;
        min-width: 50%;
        padding-right: 18px;
    }
}

@media (min-width: 1025px) {
    .dn-testimonials__slide {
        flex-basis: 33.3333%;
        min-width: 33.3333%;
        padding-right: 18px;
    }
}

.dn-testimonials__empty {
    padding: 24px 26px;
    background: rgba(255, 255, 255, 0.94);
    border: 1px dashed rgba(43, 76, 126, 0.18);
    border-radius: 24px;
    color: var(--color-text-body);
    line-height: 1.75;
}

.dn-testimonials__card {
    height: 100%;
    padding: 28px 24px;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(43, 76, 126, 0.08);
    border-radius: 28px;
    box-shadow: var(--shadow-soft);
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.dn-testimonials__card:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-md);
    border-color: rgba(58, 107, 200, 0.16);
}

.dn-testimonials__card-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}

.dn-testimonials__badge {
    display: inline-flex;
    align-items: center;
    padding: 7px 12px;
    border-radius: 999px;
    background: rgba(221, 234, 248, 0.9);
    color: var(--color-blue-cta);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.dn-testimonials__stars {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: #f5b545;
    font-size: 0.95rem;
}

.dn-testimonials__quote {
    margin: 18px 0 18px;
    color: var(--color-navy);
    font-size: 1rem;
    line-height: 1.8;
    min-height: 120px;
}

.dn-testimonials__reviewer {
    display: flex;
    align-items: center;
    gap: 14px;
}

.dn-testimonials__avatar {
    width: 54px;
    height: 54px;
    border-radius: 18px;
    object-fit: cover;
    flex-shrink: 0;
    box-shadow: var(--shadow-sm);
}

.dn-testimonials__avatar--placeholder {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--color-navy), var(--color-blue-cta));
    color: #fff;
    font-size: 1rem;
    font-weight: 800;
}

.dn-testimonials__name {
    margin: 0;
    font-size: 0.92rem;
    font-weight: 700;
    color: var(--color-navy);
}

.dn-testimonials__meta {
    margin: 4px 0 0;
    font-size: 0.9rem;
    color: var(--color-text-muted);
}

.dn-testimonials__controls {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
}

.dn-testimonials__arrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 46px;
    height: 46px;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(43, 76, 126, 0.12);
    color: var(--color-navy);
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.dn-testimonials__arrow:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
    border-color: rgba(58, 107, 200, 0.18);
}

.dn-testimonials__dots {
    display: flex;
    align-items: center;
    gap: 8px;
}

.dn-testimonials__dot {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: rgba(43, 76, 126, 0.2);
    transition: width var(--transition), background var(--transition), transform var(--transition);
}

.dn-testimonials__dot.is-active {
    width: 28px;
    background: var(--color-blue-cta);
}

/* =========================================================
   ABOUT PAGE
   ========================================================= */
.dn-about-page {
    padding: 0 0 72px;
}

.dn-about-page__inner {
    width: min(1180px, calc(100% - 48px));
    margin: 0 auto;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.9fr);
    gap: 28px;
    align-items: stretch;
}

.dn-about-page__content,
.dn-about-page__media {
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(43, 76, 126, 0.08);
    border-radius: 32px;
    box-shadow: var(--shadow-soft);
    backdrop-filter: blur(8px);
}

.dn-about-page__content {
    padding: 38px 36px;
}

.dn-about-page__eyebrow {
    display: inline-flex;
    align-items: center;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(221, 234, 248, 0.9);
    color: var(--color-blue-cta);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.dn-about-page__heading {
    margin: 18px 0 14px;
    font-family: var(--font-display);
    font-size: clamp(1.9rem, 3vw, 2.8rem);
    font-weight: 800;
    line-height: 1.05;
    letter-spacing: -0.03em;
    color: var(--color-navy);
}

.dn-about-page__body {
    font-size: 1rem;
    line-height: 1.8;
    color: rgba(37, 57, 92, 0.82);
}

.dn-about-page__body p + p {
    margin-top: 16px;
}

.dn-about-page__media {
    overflow: hidden;
}

.dn-about-page__img,
.dn-about-page__placeholder {
    width: 100%;
    height: 100%;
    min-height: 520px;
    object-fit: cover;
}

.dn-about-page__placeholder {
    background:
        radial-gradient(circle at 24% 24%, rgba(143, 177, 229, 0.34), transparent 0 13%),
        linear-gradient(180deg, rgba(221, 234, 248, 0.92), rgba(245, 247, 252, 1));
}

.dn-about-page__content {
    position: relative;
    overflow: hidden;
}

.dn-about-page__content::after {
    content: "";
    position: absolute;
    top: -44px;
    right: -20px;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(58, 107, 200, 0.12), rgba(58, 107, 200, 0));
    pointer-events: none;
}

.dn-about-page__media {
    position: relative;
}

.dn-about-page__media::after {
    content: "";
    position: absolute;
    inset: auto 22px 22px auto;
    width: 112px;
    height: 112px;
    border-radius: 28px;
    background: linear-gradient(135deg, rgba(26, 43, 74, 0.1), rgba(58, 107, 200, 0.16));
    pointer-events: none;
}

.dn-about-reality {
    padding: 0 0 72px;
}

.dn-about-reality__inner {
    width: min(1180px, calc(100% - 48px));
    margin: 0 auto;
    padding: 38px 40px 42px;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(43, 76, 126, 0.08);
    border-radius: 32px;
    box-shadow: var(--shadow-soft);
    backdrop-filter: blur(8px);
}

.dn-about-reality__header {
    margin-bottom: 26px;
}

.dn-about-reality__eyebrow {
    display: inline-flex;
    align-items: center;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(221, 234, 248, 0.9);
    color: var(--color-blue-cta);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.dn-about-reality__heading {
    margin: 18px 0 0;
    font-family: var(--font-display);
    font-size: clamp(1.95rem, 3vw, 2.9rem);
    font-weight: 800;
    line-height: 1.05;
    letter-spacing: -0.04em;
    color: var(--color-navy);
}

.dn-about-reality__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
}

.dn-about-reality__card {
    position: relative;
    min-height: 100%;
    padding: 26px 24px 24px;
    background:
        linear-gradient(180deg, rgba(221, 234, 248, 0.5), rgba(255, 255, 255, 0) 40%),
        rgba(255, 255, 255, 0.98);
    border: 1px solid rgba(43, 76, 126, 0.08);
    border-radius: 28px;
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.dn-about-reality__card:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-md);
    border-color: rgba(58, 107, 200, 0.16);
}

.dn-about-reality__index {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    height: 44px;
    margin-bottom: 18px;
    padding: 0 12px;
    border-radius: 14px;
    background: var(--color-navy);
    color: #fff;
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    box-shadow: 0 14px 24px rgba(26, 43, 74, 0.18);
}

.dn-about-reality__card-heading {
    margin: 0 0 12px;
    font-family: var(--font-display);
    font-size: 1.28rem;
    font-weight: 800;
    line-height: 1.2;
    color: var(--color-navy);
}

.dn-about-reality__card-body {
    margin: 0;
    color: rgba(37, 57, 92, 0.82);
    font-size: 0.98rem;
    line-height: 1.75;
}

/* =========================================================
   TRAINING
   ========================================================= */
.dn-training__eyebrow {
    display: inline-flex;
    align-items: center;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(221, 234, 248, 0.9);
    color: var(--color-blue-cta);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.dn-training-intro__card,
.dn-training-note__card {
    position: relative;
    overflow: hidden;
}

.dn-training-intro__card::after,
.dn-training-note__card::after {
    content: "";
    position: absolute;
    top: -44px;
    right: -22px;
    width: 170px;
    height: 170px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(58, 107, 200, 0.12), rgba(58, 107, 200, 0));
    pointer-events: none;
}

.dn-training-points {
    padding: 0 0 72px;
}

.dn-training-points__inner {
    width: min(1180px, calc(100% - 48px));
    margin: 0 auto;
}

.dn-training-points__header {
    margin-bottom: 24px;
}

.dn-training-points__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.dn-training-points__card {
    position: relative;
    min-height: 100%;
    padding: 26px 24px 24px;
    background:
        linear-gradient(180deg, rgba(221, 234, 248, 0.5), rgba(255, 255, 255, 0) 40%),
        rgba(255, 255, 255, 0.98);
    border: 1px solid rgba(43, 76, 126, 0.08);
    border-radius: 28px;
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.dn-training-points__card:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-md);
    border-color: rgba(58, 107, 200, 0.16);
}

.dn-training-points__index {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    height: 44px;
    margin-bottom: 18px;
    padding: 0 12px;
    border-radius: 14px;
    background: var(--color-navy);
    color: #fff;
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    box-shadow: 0 14px 24px rgba(26, 43, 74, 0.18);
}

.dn-training-points__text {
    margin: 0;
    color: var(--color-navy);
    font-size: 0.98rem;
    line-height: 1.75;
}

/* =========================================================
   OUR NANNIES
   ========================================================= */
.dn-our-nannies-section {
    padding: 0 0 72px;
}

.dn-our-nannies-section__inner {
    width: min(1180px, calc(100% - 48px));
    margin: 0 auto;
}

.dn-our-nannies-section__inner--card {
    padding: 38px 40px 42px;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(43, 76, 126, 0.08);
    border-radius: 32px;
    box-shadow: var(--shadow-soft);
}

.dn-our-nannies-section__header {
    margin-bottom: 24px;
}

.dn-our-nannies-section__eyebrow {
    display: inline-flex;
    align-items: center;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(221, 234, 248, 0.9);
    color: var(--color-blue-cta);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.dn-our-nannies-section__heading {
    margin: 18px 0 0;
    font-family: var(--font-display);
    font-size: clamp(1.95rem, 3vw, 2.9rem);
    font-weight: 800;
    line-height: 1.05;
    letter-spacing: -0.04em;
    color: var(--color-navy);
}

.dn-our-nannies-section__intro {
    margin: 16px 0 0;
    max-width: 62ch;
    font-size: 1rem;
    line-height: 1.8;
    color: rgba(37, 57, 92, 0.82);
}

.dn-our-nannies-grid {
    display: grid;
    gap: 20px;
}

.dn-our-nannies-grid--skills {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.dn-our-nannies-grid--checks,
.dn-our-nannies-grid--duties {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.dn-our-nannies-bullets {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px 42px;
    margin: 0;
    padding-left: 22px;
    color: var(--color-text-body);
    font-size: 1.02rem;
    line-height: 1.8;
    list-style: circle;
}

.dn-our-nannies-bullets__item {
    padding-left: 2px;
}

.dn-our-nannies-card {
    position: relative;
    min-height: 100%;
    padding: 24px;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(43, 76, 126, 0.08);
    border-radius: 28px;
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.dn-our-nannies-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-md);
    border-color: rgba(58, 107, 200, 0.16);
}

.dn-our-nannies-card--skill {
    padding-top: 76px;
    background:
        linear-gradient(180deg, rgba(221, 234, 248, 0.55), rgba(255, 255, 255, 0) 34%),
        rgba(255, 255, 255, 0.98);
}

.dn-our-nannies-card__badge {
    position: absolute;
    top: 22px;
    left: 22px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    height: 44px;
    padding: 0 12px;
    border-radius: 14px;
    background: var(--color-navy);
    color: #fff;
    font-size: 0.84rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    box-shadow: 0 14px 24px rgba(26, 43, 74, 0.18);
}

.dn-our-nannies-card__text {
    margin: 0;
    color: var(--color-navy);
    font-size: 0.98rem;
    line-height: 1.75;
}

.dn-our-nannies-card--check,
.dn-our-nannies-card--duty {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 14px;
    align-items: start;
}

.dn-our-nannies-card__check,
.dn-our-nannies-card__icon {
    width: 24px;
    height: 24px;
    margin-top: 3px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--color-blue-cta), #80a8ee);
    box-shadow: 0 0 0 7px rgba(143, 177, 229, 0.16);
    flex-shrink: 0;
}

.dn-our-nannies-card__check::before {
    content: "";
    display: block;
    width: 8px;
    height: 4px;
    margin: 8px 0 0 7px;
    border-left: 2px solid #fff;
    border-bottom: 2px solid #fff;
    transform: rotate(-45deg);
}

.dn-our-nannies-card__icon {
    border-radius: 12px;
}

.dn-our-nannies-card__icon::before,
.dn-our-nannies-card__icon::after {
    content: "";
    position: absolute;
}

.dn-our-nannies-card--duty .dn-our-nannies-card__icon {
    position: relative;
}

.dn-our-nannies-card--duty .dn-our-nannies-card__icon::before {
    inset: 6px 7px 6px 9px;
    border-left: 2px solid #fff;
    border-bottom: 2px solid #fff;
    transform: rotate(-45deg);
}

.dn-our-nannies-card--duty .dn-our-nannies-card__icon::after {
    width: 8px;
    height: 2px;
    right: 4px;
    top: 6px;
    background: rgba(255, 255, 255, 0.85);
    border-radius: 999px;
}

/* =========================================================
   ANIMATIONS
   ========================================================= */
@keyframes dn-fade-up {
    from { opacity: 0; transform: translateY(24px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* =========================================================
   RESPONSIVE
   ========================================================= */

/* Tablet ≤ 1024px */
@media (max-width: 1024px) {
    :root {
        --container-pad: clamp(22px, 4.6vw, 44px);
    }

    .dn-hero__inner {
        grid-template-columns: 1fr;
        max-width: 600px;
        padding-block: 48px;
    }
    .dn-hero__media { justify-content: center; }
    .dn-hero__trust-badge { left: auto; right: 0; bottom: 20px; }
    .dn-footer__inner {
        grid-template-columns: 1fr 1fr;
        gap: 40px 32px;
    }
    .dn-footer__brand {
        grid-column: 1 / -1;
    }
    .dn-our-nannies-grid--skills,
    .dn-our-nannies-grid--checks,
    .dn-our-nannies-grid--duties {
        grid-template-columns: 1fr 1fr;
    }
    .dn-our-nannies-bullets {
        grid-template-columns: 1fr;
    }
}

/* Mobile ≤ 768px */
@media (max-width: 768px) {
    :root {
        --header-height: 64px;
        --header-topbar-height: 36px;
    }

    .dn-header__nav { display: none; }
    .dn-header__cta { display: none; }
    .dn-header__hamburger { display: flex; }
    .dn-header__mobile-nav { display: block; }
    .dn-header__topbar-inner {
        justify-content: center;
        flex-direction: column;
        gap: 14px;
        padding-top: 6px;
        padding-bottom: 6px;
    }
    .dn-header__topbar-note {
        font-size: 0.67rem;
        letter-spacing: 0.1em;
        text-align: center;
    }
    .dn-header__topbar-contact {
        gap: 10px;
        flex-wrap: wrap;
        justify-content: center;
    }
    .dn-header__topbar-link {
        font-size: 0.78rem;
        gap: 8px;
    }
    .dn-header__topbar-label {
        min-width: 40px;
        padding: 5px 8px;
        font-size: 0.65rem;
    }

    #main-content::before {
        height: 380px;
    }

    .dn-hero__heading { font-size: 2.25rem; }
    .dn-hero__trust-badge {
        position: static;
        margin-top: 16px;
        max-width: 100%;
        box-shadow: var(--shadow-sm);
    }

    .dn-footer__inner {
        grid-template-columns: 1fr 1fr;
        gap: 32px 24px;
    }
    .dn-footer__brand { grid-column: 1 / -1; }

    .dn-footer__bottom-inner {
        flex-direction: column;
        text-align: center;
        gap: 12px;
    }
}

/* Small Mobile ≤ 480px */
@media (max-width: 480px) {
    .dn-header__topbar {
        height: auto;
        min-height: var(--header-topbar-height);
    }
    :root {
        --header-topbar-height: 60px;
    }
    .dn-header__topbar-contact {
        flex-direction: column;
        gap: 6px;
    }
    .dn-header__topbar-divider {
        display: none;
    }
    .dn-hero__actions { flex-direction: column; align-items: flex-start; }
    .dn-btn { width: 100%; justify-content: center; }

    .dn-footer__inner { grid-template-columns: 1fr; }
    .dn-footer__brand { grid-column: auto; }

    .dn-footer__legal { flex-direction: column; gap: 10px; align-items: center; }
}

/* ─── Service Suites responsive ──────────────────────────── */
@media (max-width: 1024px) {
    .dn-services__grid { grid-template-columns: repeat(2, 1fr); }
    .dn-about-reality__grid { grid-template-columns: repeat(2, 1fr); }
    .dn-careers-earnings__grid { grid-template-columns: repeat(2, 1fr); }
    .dn-training-points__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
    .dn-services { padding-block: 48px 60px; }
    .dn-services__grid { grid-template-columns: 1fr; }
    .dn-service-card {
        padding: 20px;
        border-radius: 22px;
    }
    .dn-blog-topics__inner { width: min(100% - 24px, 1180px); }
    .dn-blog-topics__grid { grid-template-columns: 1fr; }
    .dn-services__grid,
    .dn-journal__grid,
    .dn-blog-topics__grid,
    .dn-testimonials__grid { gap: 16px; }
    .dn-home-copy__card,
    .dn-home-statistics__inner,
    .dn-home-note__card,
    .dn-contact__info,
    .dn-contact__form-wrap,
    .dn-careers__content,
    .dn-careers__media,
    .dn-careers-apply__content,
    .dn-careers-apply__form-wrap,
    .dn-about-page__content,
    .dn-about-page__media { border-radius: 24px; }
    .dn-our-nannies-section {
        padding-bottom: 56px;
    }
    .dn-our-nannies-section__inner,
    .dn-our-nannies-section__inner--card {
        width: min(100% - 24px, 1180px);
    }
    .dn-our-nannies-section__inner--card {
        padding: 28px 22px 30px;
        border-radius: 24px;
    }
    .dn-our-nannies-grid--skills,
    .dn-our-nannies-grid--checks,
    .dn-our-nannies-grid--duties {
        grid-template-columns: 1fr;
        gap: 16px;
    }
    .dn-our-nannies-bullets {
        grid-template-columns: 1fr;
        gap: 10px;
    }
    .dn-our-nannies-card {
        padding: 20px;
        border-radius: 22px;
    }
    .dn-our-nannies-card--skill {
        padding-top: 72px;
    }
    .dn-about-reality {
        padding-bottom: 56px;
    }
    .dn-about-reality__inner {
        width: min(100% - 24px, 1180px);
        padding: 28px 22px 30px;
        border-radius: 24px;
    }
    .dn-about-reality__grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }
    .dn-about-reality__card {
        padding: 22px 20px;
        border-radius: 22px;
    }
    .dn-careers-earnings {
        padding-bottom: 56px;
    }
    .dn-careers-earnings__inner {
        width: min(100% - 24px, 1180px);
    }
    .dn-careers-earnings__grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }
    .dn-careers-earnings__card {
        padding: 22px 20px;
        border-radius: 22px;
    }
    .dn-careers-apply__img {
        min-height: 220px;
        border-radius: 22px;
    }
    .dn-training-points {
        padding-bottom: 56px;
    }
    .dn-training-points__inner {
        width: min(100% - 24px, 1180px);
    }
    .dn-training-points__grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }
    .dn-training-points__card {
        padding: 22px 20px;
        border-radius: 22px;
    }
}

/* ─── Divine Standard responsive ─────────────────────────── */
@media (max-width: 960px) {
    .dn-standard__inner {
        grid-template-columns: 1fr;
        gap: 32px;
    }
    .dn-standard__media { order: -1; }
    .dn-standard__img,
    .dn-standard__img-placeholder { width: 100%; }
}

@media (max-width: 640px) {
    .dn-standard { padding-block: 50px 60px; }
    .dn-standard__heading { font-size: 1.65rem; }
    .dn-standard__icon {
        width: 44px;
        height: 44px;
    }
}

/* ─── Pricing responsive ─────────────────────────────────── */
@media (max-width: 1024px) {
    .dn-pricing__grid { grid-template-columns: repeat(2, 1fr); }
    .dn-packages__grid { grid-template-columns: repeat(2, 1fr); }
    .dn-packages__notes { grid-template-columns: 1fr; }
}

@media (max-width: 720px) {
    .dn-pricing { padding-block: 52px 64px; }
    .dn-pricing__grid { grid-template-columns: 1fr; }
    .dn-price-card { padding: 20px; }
    .dn-packages { padding-block: 52px 64px; }
    .dn-packages__grid { grid-template-columns: 1fr; }
    .dn-package-card,
    .dn-packages__note-card { padding: 20px; }
}

/* ─── Journal responsive ─────────────────────────────────── */
@media (max-width: 960px) {
    .dn-journal__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 720px) {
    .dn-journal__grid { grid-template-columns: 1fr; }
    .dn-journal { padding-block: 48px 60px; }
    .dn-journal__top { flex-direction: column; align-items: flex-start; }
    .dn-journal__subheading { max-width: none; }
    .dn-testimonials__quote { min-height: 0; }
    .dn-testimonials__controls { justify-content: space-between; }
}

/* ─── CTA responsive ─────────────────────────────────────── */
@media (max-width: 960px) {
    .dn-cta__inner {
        grid-template-columns: 1fr;
    }
    .dn-cta__media { order: -1; }
}

@media (max-width: 600px) {
    .dn-cta { padding-block: 42px 56px; }
    .dn-cta__content { padding: 24px; }
}

/* ─── Stats Strip responsive ─────────────────────────────── */
@media (max-width: 768px) {
    .dn-stats__inner {
        flex-wrap: wrap;
        gap: 14px;
    }
    .dn-stats__card {
        flex: 1 1 calc(50% - 7px);
        min-width: 140px;
        padding: 24px 16px;
    }
}

@media (max-width: 400px) {
    .dn-stats__card { flex: 1 1 100%; }
}

/* ─── About Section responsive ───────────────────────────── */
@media (max-width: 1024px) {
    .dn-about__inner {
        grid-template-columns: 1fr;
        gap: 40px;
        max-width: 680px;
    }
    .dn-about__media {
        grid-template-columns: 1.35fr 1fr;
    }
    .dn-about__img-wrap--2 { margin-top: 28px; }
}

@media (max-width: 600px) {
    .dn-about__media {
        grid-template-columns: 1fr 1fr;
        gap: 12px;
    }
    .dn-about__img-wrap--2 { margin-top: 20px; }
    .dn-about__heading { font-size: 1.85rem; }
}

@media (max-width: 960px) {
    .dn-contact__inner {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .dn-contact {
        padding: 24px 0 56px;
    }

    .dn-contact__inner {
        width: min(100% - 24px, 1180px);
        gap: 18px;
    }

    .dn-contact__info,
    .dn-contact__form-wrap {
        padding: 24px 20px;
        border-radius: 24px;
    }

    .dn-contact__cf7 .wpcf7-submit {
        width: 100%;
    }

    .dn-contact__cf7 .wpcf7-checkbox,
    .dn-contact__cf7 .wpcf7-radio {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 960px) {
    .dn-careers__inner,
    .dn-careers-apply__inner {
        grid-template-columns: 1fr;
    }

    .dn-careers__media {
        order: -1;
    }

    .dn-careers__img,
    .dn-careers__placeholder {
        min-height: 420px;
    }
}

@media (max-width: 640px) {
    .dn-careers,
    .dn-careers-apply {
        padding: 22px 0 56px;
    }

    .dn-careers__inner,
    .dn-careers-apply__inner {
        width: min(100% - 24px, 1180px);
        gap: 18px;
    }

    .dn-careers__content,
    .dn-careers__media,
    .dn-careers-apply__content,
    .dn-careers-apply__form-wrap {
        border-radius: 24px;
    }

    .dn-careers__content,
    .dn-careers-apply__content,
    .dn-careers-apply__form-wrap {
        padding: 24px 20px;
    }

    .dn-careers__img,
    .dn-careers__placeholder {
        min-height: 320px;
    }

    .dn-careers__step {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 960px) {
    .dn-404__inner {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 960px) {
    .dn-about-page__inner {
        grid-template-columns: 1fr;
    }

    .dn-about-page__media {
        order: -1;
    }

    .dn-about-page__img,
    .dn-about-page__placeholder {
        min-height: 400px;
    }
}

@media (max-width: 640px) {
    .dn-404 {
        padding: 26px 0 56px;
    }

    .dn-404__inner,
    .dn-404__links {
        width: min(100% - 24px, 1180px);
    }

    .dn-404__content,
    .dn-404__panel {
        border-radius: 24px;
    }

    .dn-404__content {
        padding: 28px 22px;
    }

    .dn-404__heading {
        max-width: none;
    }

    .dn-404__actions {
        flex-direction: column;
        align-items: stretch;
    }

    .dn-404__actions .dn-btn {
        width: 100%;
    }

    .dn-404__links {
        flex-direction: column;
    }

    .dn-404__link {
        width: 100%;
    }
}

@media (max-width: 640px) {
    .dn-about-page {
        padding-bottom: 56px;
    }

    .dn-about-page__inner {
        width: min(100% - 24px, 1180px);
        gap: 18px;
    }

    .dn-about-page__content,
    .dn-about-page__media {
        border-radius: 24px;
    }

    .dn-about-page__content {
        padding: 26px 22px;
    }

    .dn-about-page__img,
    .dn-about-page__placeholder {
        min-height: 320px;
    }
}

@media (max-width: 960px) {
    .dn-testimonials__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .dn-home-copy,
    .dn-home-trust,
    .dn-home-statistics,
    .dn-testimonials,
    .dn-home-note {
        padding-bottom: 56px;
    }

    .dn-home-copy__inner,
    .dn-home-trust__inner,
    .dn-home-statistics__inner,
    .dn-testimonials__inner,
    .dn-home-note__inner {
        width: min(100% - 24px, 1180px);
    }

    .dn-home-copy__card,
    .dn-home-statistics__inner,
    .dn-home-note__card {
        padding: 26px 22px;
        border-radius: 24px;
    }

    .dn-home-trust__item {
        padding: 16px 16px 16px 46px;
        border-radius: 20px;
    }

    .dn-home-trust__item::before {
        left: 18px;
        top: 20px;
        width: 12px;
        height: 12px;
    }

    .dn-testimonials__header {
        flex-direction: column;
        align-items: flex-start;
    }

    .dn-testimonials__grid {
        grid-template-columns: 1fr;
    }

    .dn-testimonials__card {
        padding: 24px 20px;
        border-radius: 24px;
    }
}


/* Design By Anshuman */
.dn-footer__stripe {
    width: 100%;
    background: #2d3e50; /* match your theme dark color */
    text-align: center;
    padding: 14px 10px;
}

.dn-footer__stripe p {
    color: #ffffff;
    font-size: 14px;
    margin: 0;
    letter-spacing: 0.5px;
}
