@layer base, layout, components, utilities;

@layer base {
  :root {
    --fd-color-bg: #f5f3ef;
    --fd-color-bg-alt: #edeae4;
    --fd-color-surface: #faf9f7;
    --fd-color-surface-raised: #ffffff;
    --fd-color-text: #1e1c18;
    --fd-color-text-secondary: #4a4640;
    --fd-color-text-muted: #7a7570;
    --fd-color-primary: #2c4a3e;
    --fd-color-primary-dark: #1e3329;
    --fd-color-primary-light: #3d6456;
    --fd-color-accent: #b07d3a;
    --fd-color-accent-light: #c9943f;
    --fd-color-accent-subtle: #f0e4cf;
    --fd-color-border: #d8d3cb;
    --fd-color-border-light: #e8e4de;

    --fd-shadow-xs: 0 1px 2px rgba(30,28,24,0.06);
    --fd-shadow-sm: 0 2px 6px rgba(30,28,24,0.08), 0 1px 2px rgba(30,28,24,0.04);
    --fd-shadow-md: 0 4px 16px rgba(30,28,24,0.10), 0 2px 4px rgba(30,28,24,0.06);
    --fd-shadow-lg: 0 8px 32px rgba(30,28,24,0.12), 0 4px 8px rgba(30,28,24,0.06), 0 1px 2px rgba(30,28,24,0.04);
    --fd-shadow-xl: 0 16px 48px rgba(30,28,24,0.14), 0 8px 16px rgba(30,28,24,0.08), 0 2px 4px rgba(30,28,24,0.04);
    --fd-shadow-glass: 0 8px 32px rgba(30,28,24,0.16), 0 2px 8px rgba(30,28,24,0.08);

    --fd-radius-xs: 4px;
    --fd-radius-sm: 8px;
    --fd-radius-md: 12px;
    --fd-radius-lg: 20px;
    --fd-radius-xl: 28px;
    --fd-radius-full: 9999px;

    --fd-space-xs: 0.5rem;
    --fd-space-sm: 1rem;
    --fd-space-md: 1.5rem;
    --fd-space-lg: 2.5rem;
    --fd-space-xl: 4rem;
    --fd-space-2xl: 6rem;
    --fd-space-3xl: 9rem;

    --fd-font-heading: 'Familjen Grotesk', sans-serif;
    --fd-font-body: 'DM Sans', sans-serif;

    --fd-nav-height: 80px;
    --fd-transition: 0.28s cubic-bezier(0.4, 0, 0.2, 1);
    --fd-transition-slow: 0.45s cubic-bezier(0.4, 0, 0.2, 1);
  }

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

  html {
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
  }

  body {
    font-family: var(--fd-font-body);
    background-color: var(--fd-color-bg);
    color: var(--fd-color-text);
    line-height: 1.65;
    font-size: 1rem;
    min-block-size: 100vh;
    display: flex;
    flex-direction: column;
    overflow-x: hidden;
  }

  img {
    max-inline-size: 100%;
    block-size: auto;
    display: block;
  }

  a {
    color: inherit;
    text-decoration: none;
    transition: color var(--fd-transition);
  }

  ul, ol {
    list-style: none;
  }

  address {
    font-style: normal;
  }

  button {
    cursor: pointer;
    border: none;
    background: none;
    font-family: inherit;
  }
}

#pace .pace-progress {
  background: var(--fd-color-accent) !important;
  height: 3px !important;
}

@layer layout {
  .fd-container {
    inline-size: min(100%, 1200px);
    margin-inline: auto;
    padding-inline: clamp(1.25rem, 5vw, 2.5rem);
  }

  main {
    flex: 1;
  }
}

@layer components {

  .fd-nav {
    position: fixed;
    inset-block-start: 0;
    inset-inline: 0;
    z-index: 900;
    background-color: var(--fd-color-surface);
    border-block-end: 1px solid var(--fd-color-border-light);
    box-shadow: var(--fd-shadow-sm);
    transition: transform var(--fd-transition-slow), opacity var(--fd-transition-slow);
  }

  .fd-nav.fd-nav--hidden {
    transform: translateY(-100%);
    opacity: 0;
    pointer-events: none;
  }

  .fd-nav-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    block-size: var(--fd-nav-height);
    inline-size: min(100%, 1200px);
    margin-inline: auto;
    padding-inline: clamp(1.25rem, 5vw, 2.5rem);
  }

  .fd-nav-logo {
    flex-shrink: 0;
  }

  .fd-logo-img {
    block-size: 40px;
    inline-size: auto;
    transition: opacity var(--fd-transition);
  }

  .fd-logo-img:hover {
    opacity: 0.8;
  }

  .fd-nav-links {
    display: flex;
    align-items: center;
    gap: var(--fd-space-xs);
  }

  .fd-nav-link {
    font-family: var(--fd-font-heading);
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--fd-color-text-secondary);
    padding: 0.4rem 0.75rem;
    border-radius: var(--fd-radius-sm);
    transition: color var(--fd-transition), background-color var(--fd-transition);
    position: relative;
  }

  .fd-nav-link::after {
    content: '';
    position: absolute;
    inset-block-end: 0;
    inset-inline-start: 0.75rem;
    inset-inline-end: 0.75rem;
    block-size: 2px;
    background-color: var(--fd-color-accent);
    transform: scaleX(0);
    transition: transform var(--fd-transition);
    border-radius: var(--fd-radius-full);
  }

  .fd-nav-link:hover {
    color: var(--fd-color-primary);
    background-color: var(--fd-color-bg-alt);
  }

  .fd-nav-link:hover::after,
  .fd-nav-link.fd-active::after {
    transform: scaleX(1);
  }

  .fd-nav-link.fd-active {
    color: var(--fd-color-primary);
  }

  .fd-nav-cta {
    background-color: var(--fd-color-primary);
    color: var(--fd-color-surface) !important;
    padding: 0.5rem 1.25rem;
    border-radius: var(--fd-radius-full);
    font-weight: 600;
    transition: background-color var(--fd-transition), transform var(--fd-transition), box-shadow var(--fd-transition);
  }

  .fd-nav-cta::after {
    display: none;
  }

  .fd-nav-cta:hover {
    background-color: var(--fd-color-primary-light) !important;
    transform: translateY(-1px);
    box-shadow: var(--fd-shadow-md);
  }

  .fd-hamburger {
    display: none;
    flex-direction: column;
    gap: 5px;
    padding: 8px;
    border-radius: var(--fd-radius-sm);
    transition: background-color var(--fd-transition);
  }

  .fd-hamburger:hover {
    background-color: var(--fd-color-bg-alt);
  }

  .fd-hamburger span {
    display: block;
    inline-size: 22px;
    block-size: 2px;
    background-color: var(--fd-color-text);
    border-radius: var(--fd-radius-full);
    transition: transform var(--fd-transition), opacity var(--fd-transition);
  }

  .fd-nav-pill {
    position: fixed;
    inset-block-start: 1.25rem;
    inset-inline-end: 1.25rem;
    z-index: 901;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--fd-transition-slow), transform var(--fd-transition-slow);
    transform: translateY(-8px);
  }

  .fd-nav-pill.fd-pill--visible {
    opacity: 1;
    pointer-events: all;
    transform: translateY(0);
  }

  .fd-pill-btn {
    background-color: var(--fd-color-primary);
    color: var(--fd-color-surface);
    inline-size: 48px;
    block-size: 48px;
    border-radius: var(--fd-radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    box-shadow: var(--fd-shadow-lg);
    transition: background-color var(--fd-transition), transform var(--fd-transition), box-shadow var(--fd-transition);
  }

  .fd-pill-btn:hover {
    background-color: var(--fd-color-primary-light);
    transform: scale(1.08);
    box-shadow: var(--fd-shadow-xl);
  }

  .fd-mobile-overlay {
    position: fixed;
    inset: 0;
    background-color: rgba(30, 28, 24, 0.5);
    z-index: 950;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--fd-transition-slow);
    backdrop-filter: blur(2px);
  }

  .fd-mobile-overlay.fd-overlay--active {
    opacity: 1;
    pointer-events: all;
  }

  .fd-mobile-menu {
    position: fixed;
    inset-block: 0;
    inset-inline-start: 0;
    inline-size: 80%;
    max-inline-size: 340px;
    background-color: var(--fd-color-surface);
    z-index: 960;
    transform: translateX(-100%);
    transition: transform var(--fd-transition-slow);
    display: flex;
    flex-direction: column;
    padding: var(--fd-space-xl) var(--fd-space-lg) var(--fd-space-lg);
    box-shadow: var(--fd-shadow-xl);
  }

  .fd-mobile-menu.fd-menu--open {
    transform: translateX(0);
  }

  .fd-mobile-close {
    align-self: flex-end;
    inline-size: 40px;
    block-size: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--fd-radius-sm);
    color: var(--fd-color-text-secondary);
    font-size: 1.25rem;
    transition: background-color var(--fd-transition), color var(--fd-transition);
    margin-block-end: var(--fd-space-lg);
  }

  .fd-mobile-close:hover {
    background-color: var(--fd-color-bg-alt);
    color: var(--fd-color-text);
  }

  .fd-mobile-nav {
    display: flex;
    flex-direction: column;
    gap: var(--fd-space-xs);
    flex: 1;
  }

  .fd-mobile-link {
    font-family: var(--fd-font-heading);
    font-size: 1.2rem;
    font-weight: 600;
    color: var(--fd-color-text);
    padding: 0.75rem var(--fd-space-sm);
    border-radius: var(--fd-radius-md);
    transition: background-color var(--fd-transition), color var(--fd-transition), transform var(--fd-transition);
    opacity: 0;
    transform: translateX(-16px);
  }

  .fd-mobile-menu.fd-menu--open .fd-mobile-link {
    opacity: 1;
    transform: translateX(0);
    transition: opacity var(--fd-transition-slow) calc(var(--i) * 0.06s + 0.1s),
                transform var(--fd-transition-slow) calc(var(--i) * 0.06s + 0.1s),
                background-color var(--fd-transition),
                color var(--fd-transition);
  }

  .fd-mobile-link:hover {
    background-color: var(--fd-color-bg-alt);
    color: var(--fd-color-primary);
  }

  .fd-mobile-footer {
    padding-block-start: var(--fd-space-lg);
    border-block-start: 1px solid var(--fd-color-border-light);
    color: var(--fd-color-text-muted);
    font-size: 0.875rem;
    line-height: 1.8;
  }

  .fd-mobile-footer a {
    color: var(--fd-color-primary);
    font-weight: 500;
    transition: color var(--fd-transition);
  }

  .fd-mobile-footer a:hover {
    color: var(--fd-color-accent);
  }

  .fd-hero {
    position: relative;
    min-block-size: 100svh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background-color: var(--fd-color-primary-dark);
    padding-block: calc(var(--fd-nav-height) + 2rem) 4rem;
  }

  .fd-hero-bg {
    position: absolute;
    inset: 0;
    overflow: hidden;
  }

  .fd-blob {
    position: absolute;
    border-radius: var(--fd-radius-full);
    filter: blur(80px);
    opacity: 0.35;
  }

  .fd-blob-1 {
    inline-size: 600px;
    block-size: 600px;
    background: radial-gradient(circle, #3d6456 0%, transparent 70%);
    inset-block-start: -150px;
    inset-inline-end: -100px;
    animation: fd-blob-move-1 18s ease-in-out infinite;
  }

  .fd-blob-2 {
    inline-size: 500px;
    block-size: 500px;
    background: radial-gradient(circle, #b07d3a 0%, transparent 70%);
    inset-block-end: -100px;
    inset-inline-start: -80px;
    animation: fd-blob-move-2 22s ease-in-out infinite;
  }

  .fd-blob-3 {
    inline-size: 400px;
    block-size: 400px;
    background: radial-gradient(circle, #2c4a3e 0%, transparent 70%);
    inset-block-start: 40%;
    inset-inline-start: 30%;
    animation: fd-blob-move-3 26s ease-in-out infinite;
  }

  @keyframes fd-blob-move-1 {
    0%, 100% { transform: translate(0, 0) scale(1); }
    33% { transform: translate(-60px, 80px) scale(1.1); }
    66% { transform: translate(40px, -40px) scale(0.95); }
  }

  @keyframes fd-blob-move-2 {
    0%, 100% { transform: translate(0, 0) scale(1); }
    40% { transform: translate(80px, -60px) scale(1.05); }
    70% { transform: translate(-30px, 50px) scale(1.1); }
  }

  @keyframes fd-blob-move-3 {
    0%, 100% { transform: translate(0, 0) scale(1); }
    50% { transform: translate(-80px, 60px) scale(1.15); }
  }

  .fd-hero-content {
    position: relative;
    z-index: 2;
    inline-size: min(100%, 760px);
    padding-inline: clamp(1.25rem, 5vw, 2.5rem);
    text-align: center;
  }

  .fd-glass-card {
    background: rgba(250, 249, 247, 0.08);
    backdrop-filter: blur(24px) saturate(180%);
    -webkit-backdrop-filter: blur(24px) saturate(180%);
    border: 1px solid rgba(250, 249, 247, 0.15);
    border-radius: var(--fd-radius-xl);
    padding: clamp(2rem, 6vw, 4rem);
    box-shadow: var(--fd-shadow-glass);
  }

  .fd-eyebrow {
    display: inline-block;
    font-family: var(--fd-font-heading);
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--fd-color-accent-light);
    margin-block-end: 1.25rem;
  }

  .fd-hero-title {
    font-family: var(--fd-font-heading);
    font-size: clamp(2.2rem, 6vw, 4rem);
    font-weight: 700;
    color: var(--fd-color-surface);
    line-height: 1.15;
    letter-spacing: -0.02em;
    margin-block-end: 1.25rem;
  }

  .fd-hero-desc {
    font-size: clamp(1rem, 2vw, 1.125rem);
    color: rgba(250, 249, 247, 0.75);
    line-height: 1.7;
    margin-block-end: 2rem;
    max-inline-size: 580px;
    margin-inline: auto;
  }

  .fd-hero-actions {
    display: flex;
    gap: var(--fd-space-sm);
    justify-content: center;
    flex-wrap: wrap;
  }

  .fd-hero-scroll {
    position: absolute;
    inset-block-end: 2rem;
    inset-inline-start: 50%;
    transform: translateX(-50%);
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    color: rgba(250, 249, 247, 0.5);
    font-size: 0.75rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    animation: fd-scroll-bounce 2.5s ease-in-out infinite;
  }

  @keyframes fd-scroll-bounce {
    0%, 100% { transform: translateX(-50%) translateY(0); }
    50% { transform: translateX(-50%) translateY(6px); }
  }

  .fd-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--fd-font-heading);
    font-weight: 600;
    font-size: 0.95rem;
    padding: 0.75rem 1.75rem;
    border-radius: var(--fd-radius-full);
    transition: background-color var(--fd-transition), color var(--fd-transition), transform var(--fd-transition), box-shadow var(--fd-transition), border-color var(--fd-transition);
    min-block-size: 48px;
    cursor: pointer;
    border: 2px solid transparent;
    text-align: center;
    white-space: nowrap;
  }

  .fd-btn-primary {
    background-color: var(--fd-color-accent);
    color: var(--fd-color-surface);
    border-color: var(--fd-color-accent);
  }

  .fd-btn-primary:hover {
    background-color: var(--fd-color-accent-light);
    border-color: var(--fd-color-accent-light);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(176, 125, 58, 0.35), 0 2px 6px rgba(176, 125, 58, 0.2);
  }

  .fd-btn-ghost {
    background-color: rgba(250, 249, 247, 0.12);
    color: var(--fd-color-surface);
    border-color: rgba(250, 249, 247, 0.3);
  }

  .fd-btn-ghost:hover {
    background-color: rgba(250, 249, 247, 0.2);
    border-color: rgba(250, 249, 247, 0.5);
    transform: translateY(-2px);
  }

  .fd-btn-outline {
    background-color: transparent;
    color: var(--fd-color-primary);
    border-color: var(--fd-color-primary);
  }

  .fd-btn-outline:hover {
    background-color: var(--fd-color-primary);
    color: var(--fd-color-surface);
    transform: translateY(-2px);
    box-shadow: var(--fd-shadow-md);
  }

  .fd-btn-full {
    inline-size: 100%;
    justify-content: center;
  }

  .fd-label {
    display: inline-block;
    font-family: var(--fd-font-heading);
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--fd-color-accent);
    margin-block-end: 0.75rem;
  }

  .fd-section-title {
    font-family: var(--fd-font-heading);
    font-size: clamp(1.75rem, 4vw, 2.75rem);
    font-weight: 700;
    color: var(--fd-color-text);
    line-height: 1.2;
    letter-spacing: -0.02em;
    margin-block-end: 1rem;
  }

  .fd-section-sub {
    font-size: 1.05rem;
    color: var(--fd-color-text-secondary);
    max-inline-size: 560px;
    margin-inline: auto;
    line-height: 1.7;
  }

  .fd-section-header {
    text-align: center;
    margin-block-end: var(--fd-space-xl);
  }

  .fd-link-arrow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--fd-font-heading);
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--fd-color-primary);
    transition: gap var(--fd-transition), color var(--fd-transition);
    margin-block-start: var(--fd-space-sm);
  }

  .fd-link-arrow:hover {
    color: var(--fd-color-accent);
    gap: 0.75rem;
  }

  .fd-img-rounded {
    border-radius: var(--fd-radius-lg);
    object-fit: cover;
    inline-size: 100%;
    aspect-ratio: 4/3;
    box-shadow: var(--fd-shadow-lg);
  }

  .fd-intro {
    padding-block: var(--fd-space-3xl);
    background-color: var(--fd-color-surface);
  }

  .fd-intro-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(2rem, 6vw, 5rem);
    align-items: center;
  }

  .fd-intro-text {
    max-inline-size: 520px;
  }

  .fd-intro-text p {
    color: var(--fd-color-text-secondary);
    line-height: 1.75;
    margin-block-end: 1rem;
  }

  .fd-intro-image {
    position: relative;
  }

  .fd-intro-badge {
    position: absolute;
    inset-block-end: -1.5rem;
    inset-inline-start: -1.5rem;
    background-color: var(--fd-color-surface-raised);
    border: 1px solid var(--fd-color-border-light);
    border-radius: var(--fd-radius-md);
    padding: 0.75rem 1.25rem;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    box-shadow: var(--fd-shadow-md);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--fd-color-text-secondary);
  }

  .fd-intro-badge i {
    color: var(--fd-color-accent);
    font-size: 1.1rem;
  }

  .fd-benefits {
    padding-block: var(--fd-space-3xl);
    background-color: var(--fd-color-bg);
  }

  .fd-benefits-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: var(--fd-space-md);
  }

  .fd-benefit-card {
    background-color: var(--fd-color-surface);
    border: 1px solid var(--fd-color-border-light);
    border-radius: var(--fd-radius-lg);
    padding: var(--fd-space-lg);
    transition: transform var(--fd-transition), box-shadow var(--fd-transition), border-color var(--fd-transition);
    box-shadow: var(--fd-shadow-sm);
  }

  .fd-benefit-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--fd-shadow-lg);
    border-color: var(--fd-color-border);
  }

  .fd-benefit-icon {
    inline-size: 44px;
    block-size: 44px;
    background-color: var(--fd-color-accent-subtle);
    border-radius: var(--fd-radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-block-end: var(--fd-space-sm);
    transition: background-color var(--fd-transition);
  }

  .fd-benefit-card:hover .fd-benefit-icon {
    background-color: var(--fd-color-accent);
  }

  .fd-benefit-icon i {
    color: var(--fd-color-accent);
    font-size: 1rem;
    transition: color var(--fd-transition);
  }

  .fd-benefit-card:hover .fd-benefit-icon i {
    color: var(--fd-color-surface);
  }

  .fd-benefit-card h3 {
    font-family: var(--fd-font-heading);
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--fd-color-text);
    margin-block-end: 0.5rem;
  }

  .fd-benefit-card p {
    font-size: 0.9rem;
    color: var(--fd-color-text-secondary);
    line-height: 1.65;
  }

  .fd-courses {
    padding-block: var(--fd-space-3xl);
    background-color: var(--fd-color-bg-alt);
  }

  .fd-courses-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: var(--fd-space-md);
  }

  .fd-course-card {
    background-color: var(--fd-color-surface-raised);
    border-radius: var(--fd-radius-lg);
    overflow: hidden;
    box-shadow: var(--fd-shadow-md);
    transition: transform var(--fd-transition), box-shadow var(--fd-transition);
    border: 1px solid var(--fd-color-border-light);
  }

  .fd-course-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--fd-shadow-xl);
  }

  .fd-course-img {
    overflow: hidden;
    aspect-ratio: 16/9;
  }

  .fd-course-img img {
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
    transition: transform var(--fd-transition-slow);
  }

  .fd-course-card:hover .fd-course-img img {
    transform: scale(1.04);
  }

  .fd-course-body {
    padding: var(--fd-space-md) var(--fd-space-lg);
  }

  .fd-course-tag {
    display: inline-block;
    font-family: var(--fd-font-heading);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--fd-color-accent);
    background-color: var(--fd-color-accent-subtle);
    padding: 0.25rem 0.75rem;
    border-radius: var(--fd-radius-full);
    margin-block-end: 0.75rem;
  }

  .fd-tag-alt {
    background-color: color-mix(in srgb, var(--fd-color-primary) 12%, transparent);
    color: var(--fd-color-primary);
  }

  .fd-course-body h3 {
    font-family: var(--fd-font-heading);
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--fd-color-text);
    margin-block-end: 0.6rem;
  }

  .fd-course-body p {
    font-size: 0.9rem;
    color: var(--fd-color-text-secondary);
    line-height: 1.65;
    margin-block-end: 0.5rem;
  }

  .fd-approach {
    padding-block: var(--fd-space-3xl);
    background-color: var(--fd-color-surface);
  }

  .fd-approach-inner {
    display: grid;
    grid-template-columns: 5fr 7fr;
    gap: clamp(2rem, 6vw, 5rem);
    align-items: start;
  }

  .fd-approach-image img {
    border-radius: var(--fd-radius-xl);
    object-fit: cover;
    inline-size: 100%;
    aspect-ratio: 3/4;
    box-shadow: var(--fd-shadow-xl);
  }

  .fd-approach-steps {
    display: flex;
    flex-direction: column;
    gap: var(--fd-space-md);
    margin-block-start: var(--fd-space-lg);
  }

  .fd-step {
    display: flex;
    gap: var(--fd-space-sm);
    align-items: flex-start;
    padding: var(--fd-space-sm) var(--fd-space-md);
    border-radius: var(--fd-radius-md);
    border: 1px solid var(--fd-color-border-light);
    background-color: var(--fd-color-bg);
    transition: border-color var(--fd-transition), box-shadow var(--fd-transition), transform var(--fd-transition);
  }

  .fd-step:hover {
    border-color: var(--fd-color-accent);
    box-shadow: var(--fd-shadow-sm);
    transform: translateX(4px);
  }

  .fd-step-num {
    font-family: var(--fd-font-heading);
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--fd-color-accent);
    letter-spacing: 0.05em;
    flex-shrink: 0;
    padding-block-start: 0.2rem;
    min-inline-size: 28px;
  }

  .fd-step-text h4 {
    font-family: var(--fd-font-heading);
    font-size: 1rem;
    font-weight: 600;
    color: var(--fd-color-text);
    margin-block-end: 0.35rem;
  }

  .fd-step-text p {
    font-size: 0.875rem;
    color: var(--fd-color-text-secondary);
    line-height: 1.6;
  }

  .fd-areas {
    padding-block: var(--fd-space-3xl);
    background-color: var(--fd-color-bg-alt);
  }

  .fd-areas-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: var(--fd-space-md);
  }

  .fd-area-card {
    background-color: var(--fd-color-surface);
    border: 1px solid var(--fd-color-border-light);
    border-radius: var(--fd-radius-lg);
    padding: var(--fd-space-lg);
    transition: transform var(--fd-transition), box-shadow var(--fd-transition), border-color var(--fd-transition);
    box-shadow: var(--fd-shadow-sm);
  }

  .fd-area-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--fd-shadow-md);
    border-color: var(--fd-color-primary);
  }

  .fd-area-icon {
    font-size: 1.25rem;
    color: var(--fd-color-primary);
    margin-block-end: 0.75rem;
    transition: color var(--fd-transition);
  }

  .fd-area-card:hover .fd-area-icon {
    color: var(--fd-color-accent);
  }

  .fd-area-card h3 {
    font-family: var(--fd-font-heading);
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--fd-color-text);
    margin-block-end: 0.5rem;
  }

  .fd-area-card p {
    font-size: 0.875rem;
    color: var(--fd-color-text-secondary);
    line-height: 1.65;
  }

  .fd-certifications {
    padding-block: var(--fd-space-3xl);
    background-color: var(--fd-color-primary-dark);
  }

  .fd-certifications .fd-section-header .fd-label {
    color: var(--fd-color-accent-light);
  }

  .fd-certifications .fd-section-title {
    color: var(--fd-color-surface);
  }

  .fd-certs-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: var(--fd-space-md);
  }

  .fd-cert-card {
    background: rgba(250, 249, 247, 0.06);
    border: 1px solid rgba(250, 249, 247, 0.12);
    border-radius: var(--fd-radius-lg);
    padding: var(--fd-space-lg);
    transition: background-color var(--fd-transition), border-color var(--fd-transition), transform var(--fd-transition);
  }

  .fd-cert-card:hover {
    background: rgba(250, 249, 247, 0.1);
    border-color: rgba(250, 249, 247, 0.2);
    transform: translateY(-3px);
  }

  .fd-cert-icon {
    font-size: 1.5rem;
    color: var(--fd-color-accent-light);
    margin-block-end: var(--fd-space-sm);
    transition: transform var(--fd-transition);
  }

  .fd-cert-card:hover .fd-cert-icon {
    transform: scale(1.1);
  }

  .fd-cert-card h4 {
    font-family: var(--fd-font-heading);
    font-size: 1rem;
    font-weight: 600;
    color: var(--fd-color-surface);
    margin-block-end: 0.5rem;
  }

  .fd-cert-card p {
    font-size: 0.875rem;
    color: rgba(250, 249, 247, 0.65);
    line-height: 1.65;
  }

  .fd-cta-section {
    padding-block: var(--fd-space-3xl);
    background-color: var(--fd-color-bg);
  }

  .fd-cta-inner {
    background-color: var(--fd-color-surface-raised);
    border: 1px solid var(--fd-color-border-light);
    border-radius: var(--fd-radius-xl);
    padding: clamp(2rem, 5vw, 3.5rem);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--fd-space-xl);
    box-shadow: var(--fd-shadow-lg);
    position: relative;
    overflow: hidden;
  }

  .fd-cta-inner::before {
    content: '';
    position: absolute;
    inset-block-start: 0;
    inset-inline-start: 0;
    inline-size: 4px;
    block-size: 100%;
    background: linear-gradient(to bottom, var(--fd-color-accent), var(--fd-color-primary));
  }

  .fd-cta-text h2 {
    font-family: var(--fd-font-heading);
    font-size: clamp(1.4rem, 3vw, 2rem);
    font-weight: 700;
    color: var(--fd-color-text);
    margin-block-end: 0.5rem;
  }

  .fd-cta-text p {
    color: var(--fd-color-text-secondary);
    font-size: 1rem;
    max-inline-size: 480px;
    line-height: 1.65;
  }

  .fd-cta-actions {
    display: flex;
    gap: var(--fd-space-sm);
    flex-shrink: 0;
    flex-wrap: wrap;
  }

  .fd-footer {
    background-color: var(--fd-color-text);
    color: rgba(250, 249, 247, 0.7);
    padding-block-start: var(--fd-space-3xl);
    margin-block-start: auto;
  }

  .fd-footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: clamp(1.5rem, 4vw, 3rem);
    padding-block-end: var(--fd-space-xl);
    border-block-end: 1px solid rgba(250, 249, 247, 0.1);
  }

  .fd-footer-logo {
    block-size: 36px;
    inline-size: auto;
    margin-block-end: var(--fd-space-sm);
    opacity: 0.9;
    filter: brightness(0) invert(1);
  }

  .fd-footer-brand p {
    font-size: 0.875rem;
    line-height: 1.7;
    margin-block-end: 0.75rem;
    max-inline-size: 280px;
  }

  .fd-footer-brand address {
    font-size: 0.8rem;
    line-height: 1.8;
    color: rgba(250, 249, 247, 0.5);
  }

  .fd-footer-nav h4,
  .fd-footer-contact h4,
  .fd-footer-legal h4 {
    font-family: var(--fd-font-heading);
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: rgba(250, 249, 247, 0.9);
    margin-block-end: var(--fd-space-sm);
  }

  .fd-footer-nav ul,
  .fd-footer-contact ul,
  .fd-footer-legal ul {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
  }

  .fd-footer-nav a,
  .fd-footer-contact a,
  .fd-footer-legal a {
    font-size: 0.875rem;
    color: rgba(250, 249, 247, 0.6);
    transition: color var(--fd-transition);
    display: flex;
    align-items: center;
    gap: 0.5rem;
  }

  .fd-footer-nav a:hover,
  .fd-footer-contact a:hover,
  .fd-footer-legal a:hover {
    color: rgba(250, 249, 247, 0.95);
  }

  .fd-footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-block: var(--fd-space-md);
    font-size: 0.8rem;
    color: rgba(250, 249, 247, 0.4);
    flex-wrap: wrap;
    gap: 0.5rem;
  }

  .fd-page-hero {
    padding-block-start: calc(var(--fd-nav-height) + 3rem);
    padding-block-end: var(--fd-space-xl);
    background-color: var(--fd-color-primary);
    text-align: center;
    position: relative;
    overflow: hidden;
  }

  .fd-page-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 70% 50%, rgba(176, 125, 58, 0.15) 0%, transparent 60%);
  }

  .fd-page-hero-content {
    position: relative;
    z-index: 1;
    max-inline-size: 700px;
    margin-inline: auto;
    padding-inline: clamp(1.25rem, 5vw, 2.5rem);
  }

  .fd-page-hero h1 {
    font-family: var(--fd-font-heading);
    font-size: clamp(2rem, 5vw, 3.25rem);
    font-weight: 700;
    color: var(--fd-color-surface);
    letter-spacing: -0.02em;
    margin-block-end: 0.75rem;
  }

  .fd-page-hero p {
    font-size: 1.05rem;
    color: rgba(250, 249, 247, 0.7);
    line-height: 1.65;
  }

  .fd-lecturers {
    padding-block: var(--fd-space-3xl);
    background-color: var(--fd-color-surface);
  }

  .fd-lecturers-intro {
    max-inline-size: 680px;
    margin-inline: auto;
    text-align: center;
    margin-block-end: var(--fd-space-3xl);
  }

  .fd-lecturers-intro p {
    font-size: 1.1rem;
    color: var(--fd-color-text-secondary);
    line-height: 1.75;
  }

  .fd-lecturer-profile {
    display: grid;
    grid-template-columns: 2fr 3fr;
    gap: clamp(2rem, 5vw, 4rem);
    align-items: start;
    margin-block-end: var(--fd-space-3xl);
    padding-block-end: var(--fd-space-3xl);
    border-block-end: 1px solid var(--fd-color-border-light);
  }

  .fd-lecturer-profile:last-child {
    border-block-end: none;
    margin-block-end: 0;
    padding-block-end: 0;
  }

  .fd-lecturer-profile--reverse {
    grid-template-columns: 3fr 2fr;
  }

  .fd-lecturer-profile--reverse .fd-lecturer-img {
    order: 2;
  }

  .fd-lecturer-profile--reverse .fd-lecturer-info {
    order: 1;
  }

  .fd-lecturer-img img {
    inline-size: 100%;
    aspect-ratio: 3/4;
    object-fit: cover;
    border-radius: var(--fd-radius-xl);
    box-shadow: var(--fd-shadow-xl);
  }

  .fd-lecturer-info h2 {
    font-family: var(--fd-font-heading);
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 700;
    color: var(--fd-color-text);
    letter-spacing: -0.02em;
    margin-block-end: 0.25rem;
  }

  .fd-lecturer-role {
    font-size: 0.95rem;
    color: var(--fd-color-text-muted);
    margin-block-end: 1.25rem;
    font-weight: 500;
  }

  .fd-lecturer-info p {
    color: var(--fd-color-text-secondary);
    line-height: 1.75;
    margin-block-end: 0.85rem;
    font-size: 0.975rem;
  }

  .fd-lecturer-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-block-start: var(--fd-space-sm);
  }

  .fd-lecturer-tags span {
    font-family: var(--fd-font-heading);
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--fd-color-primary);
    background-color: color-mix(in srgb, var(--fd-color-primary) 10%, transparent);
    padding: 0.3rem 0.75rem;
    border-radius: var(--fd-radius-full);
    border: 1px solid color-mix(in srgb, var(--fd-color-primary) 20%, transparent);
    transition: background-color var(--fd-transition), color var(--fd-transition);
  }

  .fd-lecturer-tags span:hover {
    background-color: var(--fd-color-primary);
    color: var(--fd-color-surface);
  }

  .fd-approach-values {
    padding-block: var(--fd-space-3xl);
    background-color: var(--fd-color-bg);
  }

  .fd-values-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--fd-space-lg);
  }

  .fd-value-item {
    padding: var(--fd-space-md);
    border-radius: var(--fd-radius-lg);
    border: 1px solid var(--fd-color-border-light);
    background-color: var(--fd-color-surface);
    transition: transform var(--fd-transition), box-shadow var(--fd-transition);
  }

  .fd-value-item:hover {
    transform: translateY(-3px);
    box-shadow: var(--fd-shadow-md);
  }

  .fd-value-item i {
    font-size: 1.25rem;
    color: var(--fd-color-accent);
    margin-block-end: 0.75rem;
    display: block;
  }

  .fd-value-item h4 {
    font-family: var(--fd-font-heading);
    font-size: 1rem;
    font-weight: 600;
    color: var(--fd-color-text);
    margin-block-end: 0.4rem;
  }

  .fd-value-item p {
    font-size: 0.875rem;
    color: var(--fd-color-text-secondary);
    line-height: 1.65;
  }

  .fd-programs {
    padding-block: var(--fd-space-3xl);
    background-color: var(--fd-color-surface);
  }

  .fd-programs-intro {
    max-inline-size: 700px;
    margin-inline: auto;
    text-align: center;
    margin-block-end: var(--fd-space-3xl);
  }

  .fd-programs-intro p {
    font-size: 1.05rem;
    color: var(--fd-color-text-secondary);
    line-height: 1.75;
  }

  .fd-program-detail {
    background-color: var(--fd-color-surface-raised);
    border: 1px solid var(--fd-color-border-light);
    border-radius: var(--fd-radius-xl);
    overflow: hidden;
    margin-block-end: var(--fd-space-xl);
    box-shadow: var(--fd-shadow-md);
    transition: box-shadow var(--fd-transition);
  }

  .fd-program-detail:hover {
    box-shadow: var(--fd-shadow-xl);
  }

  .fd-program-header {
    padding: var(--fd-space-xl) var(--fd-space-xl) var(--fd-space-md);
    border-block-end: 1px solid var(--fd-color-border-light);
    background-color: var(--fd-color-bg);
  }

  .fd-program-meta {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-block-end: 0.75rem;
  }

  .fd-program-header h2 {
    font-family: var(--fd-font-heading);
    font-size: clamp(1.5rem, 3vw, 2rem);
    font-weight: 700;
    color: var(--fd-color-text);
    margin-block-end: 0.5rem;
  }

  .fd-program-sub {
    color: var(--fd-color-text-muted);
    font-size: 1rem;
  }

  .fd-program-body {
    display: grid;
    grid-template-columns: 3fr 2fr;
    gap: var(--fd-space-xl);
    padding: var(--fd-space-xl);
    align-items: start;
  }

  .fd-program-content p {
    color: var(--fd-color-text-secondary);
    line-height: 1.75;
    margin-block-end: 1rem;
    font-size: 0.975rem;
  }

  .fd-program-content h4 {
    font-family: var(--fd-font-heading);
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--fd-color-text);
    margin-block-end: 0.5rem;
    margin-block-start: 0.5rem;
  }

  .fd-program-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
  }

  .fd-program-list li {
    font-size: 0.875rem;
    color: var(--fd-color-text-secondary);
    padding-inline-start: 1.25rem;
    position: relative;
    line-height: 1.5;
  }

  .fd-program-list li::before {
    content: '';
    position: absolute;
    inset-inline-start: 0;
    inset-block-start: 0.55em;
    inline-size: 6px;
    block-size: 6px;
    background-color: var(--fd-color-accent);
    border-radius: var(--fd-radius-full);
  }

  .fd-program-image img {
    inline-size: 100%;
    aspect-ratio: 4/3;
    object-fit: cover;
    border-radius: var(--fd-radius-lg);
    box-shadow: var(--fd-shadow-md);
  }

  .fd-formats {
    padding-block: var(--fd-space-3xl);
    background-color: var(--fd-color-bg-alt);
  }

  .fd-formats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: var(--fd-space-md);
  }

  .fd-format-card {
    background-color: var(--fd-color-surface);
    border: 1px solid var(--fd-color-border-light);
    border-radius: var(--fd-radius-lg);
    padding: var(--fd-space-lg);
    transition: transform var(--fd-transition), box-shadow var(--fd-transition), border-color var(--fd-transition);
    box-shadow: var(--fd-shadow-sm);
  }

  .fd-format-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--fd-shadow-lg);
    border-color: var(--fd-color-primary);
  }

  .fd-format-icon {
    inline-size: 48px;
    block-size: 48px;
    background-color: color-mix(in srgb, var(--fd-color-primary) 10%, transparent);
    border-radius: var(--fd-radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-block-end: var(--fd-space-sm);
    transition: background-color var(--fd-transition);
  }

  .fd-format-card:hover .fd-format-icon {
    background-color: var(--fd-color-primary);
  }

  .fd-format-icon i {
    color: var(--fd-color-primary);
    font-size: 1.1rem;
    transition: color var(--fd-transition);
  }

  .fd-format-card:hover .fd-format-icon i {
    color: var(--fd-color-surface);
  }

  .fd-format-card h3 {
    font-family: var(--fd-font-heading);
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--fd-color-text);
    margin-block-end: 0.5rem;
  }

  .fd-format-card p {
    font-size: 0.875rem;
    color: var(--fd-color-text-secondary);
    line-height: 1.65;
  }

  .fd-faq-section {
    padding-block: var(--fd-space-3xl);
    background-color: var(--fd-color-surface);
  }

  .fd-faq-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(2rem, 5vw, 4rem);
    align-items: start;
  }

  .fd-faq-group {
    margin-block-end: var(--fd-space-xl);
  }

  .fd-faq-group-title {
    font-family: var(--fd-font-heading);
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--fd-color-accent);
    margin-block-end: var(--fd-space-sm);
    padding-block-end: 0.5rem;
    border-block-end: 2px solid var(--fd-color-accent-subtle);
  }

  .fd-faq-item {
    border-block-end: 1px solid var(--fd-color-border-light);
  }

  .fd-faq-q {
    inline-size: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 1rem 0;
    font-family: var(--fd-font-heading);
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--fd-color-text);
    text-align: start;
    transition: color var(--fd-transition);
    cursor: pointer;
    background: none;
    border: none;
  }

  .fd-faq-q:hover {
    color: var(--fd-color-primary);
  }

  .fd-faq-q i {
    flex-shrink: 0;
    font-size: 0.8rem;
    color: var(--fd-color-accent);
    transition: transform var(--fd-transition);
  }

  .fd-faq-q[aria-expanded="true"] i {
    transform: rotate(45deg);
  }

  .fd-faq-a {
    max-block-size: 0;
    overflow: hidden;
    transition: max-block-size var(--fd-transition-slow);
  }

  .fd-faq-a.fd-faq--open {
    max-block-size: 400px;
  }

  .fd-faq-a p {
    padding-block-end: 1rem;
    font-size: 0.9rem;
    color: var(--fd-color-text-secondary);
    line-height: 1.7;
  }

  .fd-contact-section {
    padding-block: var(--fd-space-3xl);
    background-color: var(--fd-color-surface);
  }

  .fd-contact-grid {
    display: grid;
    grid-template-columns: 5fr 7fr;
    gap: clamp(2rem, 6vw, 5rem);
    align-items: start;
  }

  .fd-contact-info h2,
  .fd-contact-form-wrap h2 {
    font-family: var(--fd-font-heading);
    font-size: clamp(1.5rem, 3vw, 2rem);
    font-weight: 700;
    color: var(--fd-color-text);
    margin-block-end: 0.5rem;
  }

  .fd-contact-form-wrap > p {
    font-size: 0.9rem;
    color: var(--fd-color-text-muted);
    margin-block-end: var(--fd-space-lg);
  }

  .fd-contact-details {
    display: flex;
    flex-direction: column;
    gap: var(--fd-space-md);
    margin-block: var(--fd-space-lg);
  }

  .fd-contact-item {
    display: flex;
    gap: var(--fd-space-sm);
    align-items: flex-start;
  }

  .fd-contact-icon {
    inline-size: 44px;
    block-size: 44px;
    background-color: color-mix(in srgb, var(--fd-color-primary) 10%, transparent);
    border-radius: var(--fd-radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--fd-color-primary);
    transition: background-color var(--fd-transition), color var(--fd-transition);
  }

  .fd-contact-item:hover .fd-contact-icon {
    background-color: var(--fd-color-primary);
    color: var(--fd-color-surface);
  }

  .fd-contact-item h4 {
    font-family: var(--fd-font-heading);
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--fd-color-text-muted);
    margin-block-end: 0.25rem;
  }

  .fd-contact-item p,
  .fd-contact-item a {
    font-size: 0.95rem;
    color: var(--fd-color-text-secondary);
    line-height: 1.65;
    transition: color var(--fd-transition);
  }

  .fd-contact-item a:hover {
    color: var(--fd-color-primary);
  }

  .fd-contact-map {
    border-radius: var(--fd-radius-lg);
    overflow: hidden;
    box-shadow: var(--fd-shadow-md);
    border: 1px solid var(--fd-color-border-light);
  }

  .fd-accordion-form {
    display: flex;
    flex-direction: column;
    gap: 0;
  }

  .fd-acc-section {
    border: 1px solid var(--fd-color-border-light);
    border-radius: var(--fd-radius-lg);
    overflow: hidden;
    margin-block-end: 0.75rem;
    transition: border-color var(--fd-transition), box-shadow var(--fd-transition);
    background-color: var(--fd-color-surface-raised);
  }

  .fd-acc-section.fd-acc-open {
    border-color: var(--fd-color-primary);
    box-shadow: var(--fd-shadow-sm);
  }

  .fd-acc-header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem 1.25rem;
    cursor: default;
    background-color: var(--fd-color-bg);
    border-block-end: 1px solid transparent;
    transition: border-color var(--fd-transition);
  }

  .fd-acc-section.fd-acc-open .fd-acc-header {
    border-block-end-color: var(--fd-color-border-light);
  }

  .fd-acc-num {
    font-family: var(--fd-font-heading);
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--fd-color-accent);
    letter-spacing: 0.05em;
    min-inline-size: 24px;
  }

  .fd-acc-title {
    font-family: var(--fd-font-heading);
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--fd-color-text);
    flex: 1;
  }

  .fd-acc-icon {
    color: var(--fd-color-text-muted);
    font-size: 0.8rem;
    transition: transform var(--fd-transition), color var(--fd-transition);
  }

  .fd-acc-section.fd-acc-open .fd-acc-icon {
    transform: rotate(180deg);
    color: var(--fd-color-primary);
  }

  .fd-acc-body {
    max-block-size: 0;
    overflow: hidden;
    transition: max-block-size var(--fd-transition-slow);
  }

  .fd-acc-section.fd-acc-open .fd-acc-body {
    max-block-size: 600px;
  }

  .fd-acc-body > * {
    padding: 1.25rem;
  }

  .fd-field {
    margin-block-end: 1rem;
  }

  .fd-field:last-child {
    margin-block-end: 0;
  }

  .fd-field label {
    display: block;
    font-family: var(--fd-font-heading);
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--fd-color-text-secondary);
    margin-block-end: 0.4rem;
  }

  .fd-required {
    color: var(--fd-color-accent);
  }

  .fd-field input,
  .fd-field textarea,
  .fd-field select {
    inline-size: 100%;
    padding: 0.75rem 1rem;
    border: 1.5px solid var(--fd-color-border);
    border-radius: var(--fd-radius-md);
    font-family: var(--fd-font-body);
    font-size: 0.95rem;
    color: var(--fd-color-text);
    background-color: var(--fd-color-surface-raised);
    transition: border-color var(--fd-transition), box-shadow var(--fd-transition);
    min-block-size: 48px;
    outline: none;
  }

  .fd-field input:focus,
  .fd-field textarea:focus {
    border-color: var(--fd-color-primary);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--fd-color-primary) 15%, transparent);
  }

  .fd-field textarea {
    resize: vertical;
    min-block-size: 120px;
  }

  .fd-field-checkbox {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    margin-block-end: 1.25rem;
  }

  .fd-checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    cursor: pointer;
    font-size: 0.875rem;
    color: var(--fd-color-text-secondary);
    line-height: 1.5;
  }

  .fd-checkbox-label input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    inline-size: 0;
    block-size: 0;
  }

  .fd-checkbox-custom {
    flex-shrink: 0;
    inline-size: 20px;
    block-size: 20px;
    border: 2px solid var(--fd-color-border);
    border-radius: var(--fd-radius-xs);
    background-color: var(--fd-color-surface-raised);
    transition: border-color var(--fd-transition), background-color var(--fd-transition);
    margin-block-start: 2px;
    position: relative;
  }

  .fd-checkbox-label input[type="checkbox"]:checked + .fd-checkbox-custom {
    background-color: var(--fd-color-primary);
    border-color: var(--fd-color-primary);
  }

  .fd-checkbox-label input[type="checkbox"]:checked + .fd-checkbox-custom::after {
    content: '';
    position: absolute;
    inset-inline-start: 5px;
    inset-block-start: 2px;
    inline-size: 6px;
    block-size: 10px;
    border: 2px solid white;
    border-block-start: none;
    border-inline-start: none;
    transform: rotate(45deg);
  }

  .fd-checkbox-label a {
    color: var(--fd-color-primary);
    text-decoration: underline;
    transition: color var(--fd-transition);
  }

  .fd-checkbox-label a:hover {
    color: var(--fd-color-accent);
  }

  .fd-team-contact {
    padding-block: var(--fd-space-3xl);
    background-color: var(--fd-color-bg-alt);
  }

  .fd-team-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: var(--fd-space-lg);
  }

  .fd-team-card {
    background-color: var(--fd-color-surface-raised);
    border: 1px solid var(--fd-color-border-light);
    border-radius: var(--fd-radius-xl);
    overflow: hidden;
    box-shadow: var(--fd-shadow-md);
    transition: transform var(--fd-transition), box-shadow var(--fd-transition);
  }

  .fd-team-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--fd-shadow-xl);
  }

  .fd-team-img {
    aspect-ratio: 16/9;
    overflow: hidden;
  }

  .fd-team-img img {
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
    transition: transform var(--fd-transition-slow);
  }

  .fd-team-card:hover .fd-team-img img {
    transform: scale(1.04);
  }

  .fd-team-info {
    padding: var(--fd-space-md) var(--fd-space-lg);
  }

  .fd-team-info h3 {
    font-family: var(--fd-font-heading);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--fd-color-text);
    margin-block-end: 0.25rem;
  }

  .fd-team-role {
    font-size: 0.85rem;
    color: var(--fd-color-accent);
    font-weight: 500;
    margin-block-end: 0.75rem;
  }

  .fd-team-info p {
    font-size: 0.9rem;
    color: var(--fd-color-text-secondary);
    line-height: 1.65;
  }

  .fd-thanks-section {
    min-block-size: calc(100svh - var(--fd-nav-height) - 200px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding-block: var(--fd-space-3xl);
    padding-block-start: calc(var(--fd-nav-height) + var(--fd-space-3xl));
    background-color: var(--fd-color-bg);
  }

  .fd-thanks-inner {
    text-align: center;
    max-inline-size: 560px;
    padding-inline: clamp(1.25rem, 5vw, 2.5rem);
  }

  .fd-envelope-wrap {
    margin-block-end: var(--fd-space-xl);
    display: flex;
    justify-content: center;
  }

  .fd-envelope {
    position: relative;
    inline-size: 120px;
    block-size: 90px;
  }

  .fd-envelope-body {
    position: relative;
    inline-size: 100%;
    block-size: 100%;
    background-color: var(--fd-color-surface-raised);
    border: 2px solid var(--fd-color-border);
    border-radius: var(--fd-radius-sm);
    overflow: visible;
    box-shadow: var(--fd-shadow-md);
  }

  .fd-envelope-flap {
    position: absolute;
    inset-block-start: -2px;
    inset-inline: -2px;
    block-size: 55px;
    background-color: var(--fd-color-accent-subtle);
    border: 2px solid var(--fd-color-border);
    border-radius: var(--fd-radius-sm) var(--fd-radius-sm) 0 0;
    clip-path: polygon(0 0, 100% 0, 50% 65%);
    transform-origin: top center;
    animation: fd-flap-open 0.6s ease-out 0.8s forwards;
  }

  @keyframes fd-flap-open {
    0% { transform: rotateX(0deg); }
    100% { transform: rotateX(-160deg); }
  }

  .fd-envelope-letter {
    position: absolute;
    inset-inline: 12px;
    block-size: 70px;
    background-color: var(--fd-color-surface);
    border: 1px solid var(--fd-color-border-light);
    border-radius: var(--fd-radius-xs);
    padding: 8px;
    inset-block-end: 8px;
    transform: translateY(0);
    animation: fd-letter-rise 0.5s ease-out 1.4s forwards;
    box-shadow: var(--fd-shadow-sm);
  }

  @keyframes fd-letter-rise {
    0% { transform: translateY(0); }
    100% { transform: translateY(-50px); }
  }

  .fd-letter-lines {
    display: flex;
    flex-direction: column;
    gap: 5px;
    padding: 4px;
  }

  .fd-letter-lines span {
    display: block;
    block-size: 3px;
    background-color: var(--fd-color-border);
    border-radius: var(--fd-radius-full);
  }

  .fd-letter-lines span:first-child { inline-size: 80%; }
  .fd-letter-lines span:nth-child(2) { inline-size: 100%; }
  .fd-letter-lines span:last-child { inline-size: 60%; }

  .fd-thanks-text {
    opacity: 0;
    transform: translateY(16px);
    animation: fd-thanks-appear 0.5s ease-out 2s forwards;
  }

  @keyframes fd-thanks-appear {
    to { opacity: 1; transform: translateY(0); }
  }

  .fd-thanks-text h1 {
    font-family: var(--fd-font-heading);
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    font-weight: 700;
    color: var(--fd-color-text);
    margin-block-end: 0.75rem;
  }

  .fd-thanks-text p {
    color: var(--fd-color-text-secondary);
    line-height: 1.7;
    margin-block-end: var(--fd-space-lg);
  }

  .fd-thanks-text a {
    color: var(--fd-color-primary);
    text-decoration: underline;
    transition: color var(--fd-transition);
  }

  .fd-thanks-text a:hover {
    color: var(--fd-color-accent);
  }

  .fd-thanks-actions {
    display: flex;
    gap: var(--fd-space-sm);
    justify-content: center;
    flex-wrap: wrap;
  }

  .fd-legal-section {
    padding-block: var(--fd-space-3xl);
    background-color: var(--fd-color-surface);
  }

  .fd-legal-container {
    max-inline-size: 860px;
  }

  .fd-legal-intro {
    font-size: 1.05rem;
    color: var(--fd-color-text-secondary);
    line-height: 1.75;
    margin-block-end: var(--fd-space-xl);
    padding: var(--fd-space-md) var(--fd-space-lg);
    background-color: var(--fd-color-bg);
    border-radius: var(--fd-radius-md);
    border-inline-start: 4px solid var(--fd-color-accent);
  }

  .fd-legal-container h2 {
    font-family: var(--fd-font-heading);
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--fd-color-text);
    margin-block: var(--fd-space-xl) var(--fd-space-sm);
    padding-block-end: 0.5rem;
    border-block-end: 2px solid var(--fd-color-border-light);
  }

  .fd-legal-container h3 {
    font-family: var(--fd-font-heading);
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--fd-color-text);
    margin-block: var(--fd-space-md) var(--fd-space-xs);
  }

  .fd-legal-container p {
    font-size: 0.95rem;
    color: var(--fd-color-text-secondary);
    line-height: 1.75;
    margin-block-end: 0.85rem;
  }

  .fd-legal-container a {
    color: var(--fd-color-primary);
    text-decoration: underline;
    transition: color var(--fd-transition);
  }

  .fd-legal-container a:hover {
    color: var(--fd-color-accent);
  }

  .fd-legal-table {
    inline-size: 100%;
    border-collapse: collapse;
    margin-block: var(--fd-space-sm) var(--fd-space-md);
    font-size: 0.875rem;
  }

  .fd-legal-table th,
  .fd-legal-table td {
    padding: 0.65rem 1rem;
    text-align: start;
    border: 1px solid var(--fd-color-border-light);
    line-height: 1.5;
  }

  .fd-legal-table thead th {
    background-color: var(--fd-color-bg-alt);
    font-family: var(--fd-font-heading);
    font-weight: 600;
    color: var(--fd-color-text);
    font-size: 0.8rem;
    letter-spacing: 0.04em;
  }

  .fd-legal-table tbody th {
    background-color: var(--fd-color-bg);
    font-weight: 600;
    color: var(--fd-color-text);
    inline-size: 35%;
  }

  .fd-legal-table tbody td {
    color: var(--fd-color-text-secondary);
  }

  .fd-legal-table tbody tr:hover td,
  .fd-legal-table tbody tr:hover th {
    background-color: color-mix(in srgb, var(--fd-color-primary) 4%, transparent);
  }

  .fd-legal-list {
    list-style: disc;
    padding-inline-start: 1.5rem;
    margin-block: 0.5rem var(--fd-space-sm);
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
  }

  .fd-legal-list li {
    font-size: 0.9rem;
    color: var(--fd-color-text-secondary);
    line-height: 1.65;
  }

  .fd-legal-dl {
    margin-block: var(--fd-space-sm) var(--fd-space-md);
  }

  .fd-legal-dl dt {
    font-family: var(--fd-font-heading);
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--fd-color-text);
    margin-block-start: var(--fd-space-sm);
  }

  .fd-legal-dl dd {
    font-size: 0.9rem;
    color: var(--fd-color-text-secondary);
    line-height: 1.65;
    padding-inline-start: 1rem;
    border-inline-start: 2px solid var(--fd-color-border-light);
    margin-inline-start: 0;
    margin-block-start: 0.25rem;
  }

  .fd-legal-container code {
    font-family: 'Courier New', monospace;
    font-size: 0.85rem;
    background-color: var(--fd-color-bg-alt);
    padding: 0.1em 0.4em;
    border-radius: var(--fd-radius-xs);
    color: var(--fd-color-primary);
  }

  .fd-cookie-backdrop {
    position: fixed;
    inset: 0;
    background-color: rgba(30, 28, 24, 0.6);
    z-index: 9000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--fd-space-sm);
    backdrop-filter: blur(4px);
    opacity: 0;
    transition: opacity var(--fd-transition-slow);
  }

  .fd-cookie-backdrop.fd-cookie--visible {
    opacity: 1;
  }

  .fd-cookie-modal {
    background-color: var(--fd-color-surface-raised);
    border-radius: var(--fd-radius-xl);
    padding: clamp(1.5rem, 4vw, 2.5rem);
    max-inline-size: 560px;
    inline-size: 100%;
    max-height: 90%;
    overflow-y: auto;
    box-shadow: var(--fd-shadow-xl);
    border: 1px solid var(--fd-color-border-light);
    transform: translateY(20px) scale(0.97);
    transition: transform var(--fd-transition-slow);
  }

  .fd-cookie-backdrop.fd-cookie--visible .fd-cookie-modal {
    transform: translateY(0) scale(1);
  }

  .fd-cookie-modal h3 {
    font-family: var(--fd-font-heading);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--fd-color-text);
    margin-block-end: 0.5rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
  }

  .fd-cookie-modal h3 i {
    color: var(--fd-color-accent);
  }

  .fd-cookie-modal > p {
    font-size: 0.875rem;
    color: var(--fd-color-text-secondary);
    line-height: 1.65;
    margin-block-end: var(--fd-space-md);
  }

  .fd-cookie-categories {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-block-end: var(--fd-space-md);
  }

  .fd-cookie-category {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.875rem 1rem;
    background-color: var(--fd-color-bg);
    border-radius: var(--fd-radius-md);
    border: 1px solid var(--fd-color-border-light);
    transition: border-color var(--fd-transition);
  }

  .fd-cookie-category:hover {
    border-color: var(--fd-color-border);
  }

  .fd-cookie-cat-info h4 {
    font-family: var(--fd-font-heading);
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--fd-color-text);
    margin-block-end: 0.2rem;
  }

  .fd-cookie-cat-info p {
    font-size: 0.8rem;
    color: var(--fd-color-text-muted);
    line-height: 1.5;
  }

  .fd-cookie-toggle {
    flex-shrink: 0;
    position: relative;
    inline-size: 44px;
    block-size: 24px;
  }

  .fd-cookie-toggle input {
    opacity: 0;
    inline-size: 0;
    block-size: 0;
    position: absolute;
  }

  .fd-toggle-track {
    position: absolute;
    inset: 0;
    background-color: var(--fd-color-border);
    border-radius: var(--fd-radius-full);
    cursor: pointer;
    transition: background-color var(--fd-transition);
  }

  .fd-toggle-track::before {
    content: '';
    position: absolute;
    inline-size: 18px;
    block-size: 18px;
    inset-block-start: 3px;
    inset-inline-start: 3px;
    background-color: white;
    border-radius: var(--fd-radius-full);
    transition: transform var(--fd-transition);
    box-shadow: var(--fd-shadow-xs);
  }

  .fd-cookie-toggle input:checked + .fd-toggle-track {
    background-color: var(--fd-color-primary);
  }

  .fd-cookie-toggle input:checked + .fd-toggle-track::before {
    transform: translateX(20px);
  }

  .fd-cookie-toggle input:disabled + .fd-toggle-track {
    background-color: var(--fd-color-primary);
    opacity: 0.6;
    cursor: not-allowed;
  }

  .fd-cookie-toggle input:disabled + .fd-toggle-track::before {
    transform: translateX(20px);
  }

  .fd-cookie-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
  }

  .fd-cookie-actions .fd-btn {
    flex: 1;
    min-inline-size: 120px;
    font-size: 0.875rem;
    padding: 0.6rem 1.25rem;
  }

  .fd-cookie-link {
    display: block;
    text-align: center;
    margin-block-start: 0.75rem;
    font-size: 0.78rem;
    color: var(--fd-color-text-muted);
    transition: color var(--fd-transition);
  }

  .fd-cookie-link:hover {
    color: var(--fd-color-primary);
  }

  .fd-reveal-item {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
  }

  .fd-reveal-item.fd-revealed {
    opacity: 1;
    transform: translateY(0);
  }
}

@layer utilities {
  .fd-text-muted {
    color: var(--fd-color-text-muted);
  }

  .fd-sr-only {
    position: absolute;
    inline-size: 1px;
    block-size: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }
}

@media (max-width: 1024px) {
  .fd-intro-grid {
    grid-template-columns: 1fr;
    gap: var(--fd-space-xl);
  }

  .fd-intro-text {
    max-inline-size: 100%;
  }

  .fd-intro-badge {
    inset-inline-start: 0;
  }

  .fd-approach-inner {
    grid-template-columns: 1fr;
  }

  .fd-approach-image img {
    aspect-ratio: 16/9;
  }

  .fd-contact-grid {
    grid-template-columns: 1fr;
  }

  .fd-footer-grid {
    grid-template-columns: 1fr 1fr;
  }

  .fd-footer-brand {
    grid-column: 1 / -1;
  }

  .fd-lecturer-profile,
  .fd-lecturer-profile--reverse {
    grid-template-columns: 1fr;
  }

  .fd-lecturer-profile--reverse .fd-lecturer-img,
  .fd-lecturer-profile--reverse .fd-lecturer-info {
    order: unset;
  }

  .fd-program-body {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .fd-nav-links {
    display: none;
  }

  .fd-hamburger {
    display: flex;
  }

  .fd-faq-grid {
    grid-template-columns: 1fr;
  }

  .fd-cta-inner {
    flex-direction: column;
    text-align: center;
  }

  .fd-cta-text p {
    max-inline-size: 100%;
  }

  .fd-cta-actions {
    justify-content: center;
  }

  .fd-hero-actions {
    flex-direction: column;
    align-items: center;
  }

  .fd-btn {
    inline-size: 100%;
    justify-content: center;
    max-inline-size: 300px;
  }

  .fd-footer-grid {
    grid-template-columns: 1fr;
  }

  .fd-footer-brand {
    grid-column: auto;
  }

  .fd-program-header {
    padding: var(--fd-space-md);
  }

  .fd-program-body {
    padding: var(--fd-space-md);
  }
}

@media (max-width: 480px) {
  :root {
    --fd-nav-height: 64px;
  }

  .fd-glass-card {
    padding: 1.75rem 1.25rem;
  }

  .fd-hero-title {
    font-size: 2rem;
  }

  .fd-courses-grid {
    grid-template-columns: 1fr;
  }

  .fd-certs-grid {
    grid-template-columns: 1fr;
  }

  .fd-areas-grid {
    grid-template-columns: 1fr;
  }

  .fd-benefits-grid {
    grid-template-columns: 1fr;
  }

  .fd-formats-grid {
    grid-template-columns: 1fr;
  }

  .fd-values-grid {
    grid-template-columns: 1fr;
  }

  .fd-team-grid {
    grid-template-columns: 1fr;
  }

  .fd-lecturer-img img {
    aspect-ratio: 16/9;
  }

  .fd-cookie-actions {
    flex-direction: column;
  }

  .fd-cookie-actions .fd-btn {
    flex: none;
    inline-size: 100%;
    max-inline-size: 100%;
  }

  .fd-thanks-actions {
    flex-direction: column;
    align-items: center;
  }
}