@layer base, layout, components, utilities;

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

  :root {
    --clr-bg: #f5f4f0;
    --clr-surface: #ffffff;
    --clr-surface2: #f0ede6;
    --clr-primary: #1a2744;
    --clr-primary-light: #243560;
    --clr-accent: #4a7c6f;
    --clr-accent2: #6b9e8f;
    --clr-accent-light: #d4e8e3;
    --clr-teal: #2d6a5e;
    --clr-gold: #c9a84c;
    --clr-text: #1e1c18;
    --clr-text-muted: #5a5750;
    --clr-text-light: #f5f4f0;
    --clr-border: #ddd9d0;
    --clr-iso1: #4a7c6f;
    --clr-iso2: #2d6a5e;
    --clr-iso3: #1a4a3f;

    --shadow-xs: 0 1px 2px rgba(26,39,68,0.06), 0 1px 3px rgba(26,39,68,0.04);
    --shadow-sm: 0 2px 4px rgba(26,39,68,0.08), 0 4px 8px rgba(26,39,68,0.05);
    --shadow-md: 0 4px 8px rgba(26,39,68,0.1), 0 8px 16px rgba(26,39,68,0.07);
    --shadow-lg: 0 8px 16px rgba(26,39,68,0.12), 0 16px 32px rgba(26,39,68,0.08);
    --shadow-xl: 0 12px 24px rgba(26,39,68,0.14), 0 24px 48px rgba(26,39,68,0.1);

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

    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-5: 1.25rem;
    --space-6: 1.5rem;
    --space-8: 2rem;
    --space-10: 2.5rem;
    --space-12: 3rem;
    --space-16: 4rem;
    --space-20: 5rem;
    --space-24: 6rem;

    --header-h: 72px;
    --menu-w: 320px;

    --transition-fast: 150ms ease;
    --transition-base: 250ms ease;
    --transition-slow: 400ms ease;
  }

  html {
    scroll-behavior: smooth;
    font-size: 16px;
  }

  body {
    font-family: 'Inter', system-ui, sans-serif;
    background-color: var(--clr-bg);
    color: var(--clr-text);
    line-height: 1.7;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
  }

  h1, h2, h3, h4, h5, h6 {
    font-family: 'Lora', Georgia, serif;
    line-height: 1.25;
    color: var(--clr-primary);
    font-weight: 600;
  }

  a {
    color: var(--clr-accent);
    text-decoration: none;
    transition: color var(--transition-fast);
  }

  a:hover { color: var(--clr-teal); }

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

  ul { list-style: none; }

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

  address { font-style: normal; }
}

@layer layout {
  .container {
    inline-size: 100%;
    max-inline-size: 1200px;
    margin-inline: auto;
    padding-inline: var(--space-6);
  }

  .container--narrow {
    max-inline-size: 760px;
  }

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

  .pageWrapper {
    min-block-size: 100dvh;
    display: flex;
    flex-direction: column;
    transition: transform var(--transition-slow), scale var(--transition-slow);
    transform-origin: right center;
  }

  .pageWrapper main { flex: 1; }
}

@layer components {

  .pace .pace-progress {
    background: var(--clr-accent) !important;
    block-size: 3px !important;
  }

  
  .siteHeader {
    position: fixed;
    inset-block-start: 0;
    inset-inline: 0;
    z-index: 100;
    background-color: var(--clr-surface);
    box-shadow: var(--shadow-sm);
    block-size: var(--header-h);
    transition: box-shadow var(--transition-base);
  }

  .siteHeader--scrolled {
    box-shadow: var(--shadow-md);
  }

  .siteHeader_inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    block-size: 100%;
    padding-inline: var(--space-6);
    max-inline-size: 1280px;
    margin-inline: auto;
  }

  .siteHeader_logo {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    text-decoration: none;
    color: var(--clr-primary);
  }

  .siteHeader_logoImg {
    block-size: 36px;
    inline-size: auto;
  }

  .siteHeader_logoText {
    font-family: 'Lora', serif;
    font-weight: 700;
    font-size: 1.2rem;
    color: var(--clr-primary);
    letter-spacing: -0.01em;
  }

  .siteNav { display: none; }

  @media (min-width: 1024px) {
    .siteNav { display: block; }
  }

  .siteNav_list {
    display: flex;
    align-items: center;
    gap: var(--space-2);
  }

  .siteNav_link {
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--clr-text-muted);
    padding: var(--space-2) var(--space-4);
    border-radius: var(--radius-full);
    transition: color var(--transition-fast), background-color var(--transition-fast);
    text-decoration: none;
  }

  .siteNav_link:hover,
  .siteNav_link--active {
    color: var(--clr-primary);
    background-color: var(--clr-surface2);
  }

  .siteHeader_actions {
    display: flex;
    align-items: center;
    gap: var(--space-3);
  }

  .siteHeader_searchBtn,
  .siteHeader_menuBtn {
    display: flex;
    align-items: center;
    justify-content: center;
    inline-size: 44px;
    block-size: 44px;
    border-radius: var(--radius-sm);
    color: var(--clr-text-muted);
    transition: color var(--transition-fast), background-color var(--transition-fast);
  }

  .siteHeader_searchBtn:hover,
  .siteHeader_menuBtn:hover {
    color: var(--clr-primary);
    background-color: var(--clr-surface2);
  }

  .siteHeader_menuBtn {
    flex-direction: column;
    gap: 5px;
    padding: var(--space-3);
  }

  .siteHeader_menuIcon {
    display: block;
    inline-size: 20px;
    block-size: 2px;
    background-color: currentColor;
    border-radius: 2px;
    transition: transform var(--transition-base), opacity var(--transition-base);
  }

  @media (min-width: 1024px) {
    .siteHeader_menuBtn { display: none; }
  }

  
  .searchOverlay {
    position: fixed;
    inset: 0;
    z-index: 200;
    background-color: rgba(26, 39, 68, 0.95);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--transition-base);
  }

  .searchOverlay--open {
    opacity: 1;
    pointer-events: all;
  }

  .searchOverlay_inner {
    inline-size: min(600px, 90vw);
    display: flex;
    align-items: center;
    gap: var(--space-4);
    border-block-end: 2px solid var(--clr-accent);
    padding-block-end: var(--space-4);
  }

  .searchOverlay_input {
    flex: 1;
    background: none;
    border: none;
    font-family: 'Lora', serif;
    font-size: clamp(1.2rem, 3vw, 1.8rem);
    color: var(--clr-text-light);
    outline: none;
  }

  .searchOverlay_input::placeholder { color: rgba(245,244,240,0.4); }

  .searchOverlay_close {
    color: var(--clr-text-light);
    font-size: 1.4rem;
    padding: var(--space-2);
    opacity: 0.7;
    transition: opacity var(--transition-fast);
    background: none;
    border: none;
    cursor: pointer;
  }

  .searchOverlay_close:hover { opacity: 1; }

  
  .mobileMenu {
    position: fixed;
    inset-block: 0;
    inset-inline-end: 0;
    inline-size: var(--menu-w);
    max-inline-size: 85vw;
    background-color: var(--clr-primary);
    z-index: 150;
    display: flex;
    flex-direction: column;
    padding: var(--space-6);
    transform: translateX(100%);
    transition: transform var(--transition-slow);
    box-shadow: -8px 0 32px rgba(26,39,68,0.25);
  }

  .mobileMenu--open {
    transform: translateX(0);
  }

  .mobileMenu_header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-block-end: var(--space-8);
  }

  .mobileMenu_brand {
    font-family: 'Lora', serif;
    font-weight: 700;
    font-size: 1.2rem;
    color: var(--clr-text-light);
  }

  .mobileMenu_close {
    color: var(--clr-text-light);
    font-size: 1.2rem;
    inline-size: 44px;
    block-size: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-sm);
    opacity: 0.7;
    transition: opacity var(--transition-fast), background-color var(--transition-fast);
    background: none;
    border: none;
    cursor: pointer;
  }

  .mobileMenu_close:hover {
    opacity: 1;
    background-color: rgba(255,255,255,0.1);
  }

  .mobileMenu_list { display: flex; flex-direction: column; gap: var(--space-2); }

  .mobileMenu_link {
    display: block;
    font-size: 1.1rem;
    font-weight: 500;
    color: rgba(245,244,240,0.8);
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-sm);
    transition: color var(--transition-fast), background-color var(--transition-fast);
    text-decoration: none;
  }

  .mobileMenu_link:hover {
    color: var(--clr-text-light);
    background-color: rgba(255,255,255,0.1);
  }

  .mobileMenu_footer {
    margin-block-start: auto;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    padding-block-start: var(--space-6);
    border-block-start: 1px solid rgba(255,255,255,0.15);
  }

  .mobileMenu_contact {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    color: rgba(245,244,240,0.7);
    font-size: 0.9rem;
    text-decoration: none;
    transition: color var(--transition-fast);
  }

  .mobileMenu_contact:hover { color: var(--clr-text-light); }

  
  .isoShape {
    position: absolute;
    transform-style: preserve-3d;
  }

  .isoShape--large {
    inline-size: 200px;
    block-size: 200px;
    background: linear-gradient(135deg, var(--clr-iso1) 0%, var(--clr-iso2) 100%);
    transform: rotate(45deg) skewX(-15deg) skewY(-15deg);
    opacity: 0.12;
    inset-block-start: -40px;
    inset-inline-end: 5%;
    border-radius: var(--radius-md);
  }

  .isoShape--medium {
    inline-size: 120px;
    block-size: 120px;
    background: linear-gradient(135deg, var(--clr-iso2) 0%, var(--clr-iso3) 100%);
    transform: rotate(45deg) skewX(-15deg) skewY(-15deg);
    opacity: 0.15;
    inset-block-start: 60px;
    inset-inline-end: 12%;
    border-radius: var(--radius-sm);
  }

  .isoShape--small {
    inline-size: 60px;
    block-size: 60px;
    background: var(--clr-accent);
    transform: rotate(45deg) skewX(-20deg) skewY(-20deg);
    opacity: 0.2;
    inset-block-start: 20px;
    inset-inline-end: 20%;
    border-radius: var(--radius-xs);
  }

  .isoShape--line {
    inline-size: 180px;
    block-size: 3px;
    background: linear-gradient(90deg, transparent, var(--clr-accent));
    opacity: 0.3;
    inset-block-start: 50%;
    inset-inline-end: 3%;
    transform: rotate(-30deg);
  }

  .isoShape--dot {
    inline-size: 12px;
    block-size: 12px;
    background: var(--clr-gold);
    border-radius: 50%;
    opacity: 0.5;
    inset-block-start: 30%;
    inset-inline-end: 25%;
  }

  .isoShape--teal {
    inline-size: 160px;
    block-size: 160px;
    background: rgba(255,255,255,0.08);
    transform: rotate(45deg) skewX(-15deg) skewY(-15deg);
    inset-block-start: -30px;
    inset-inline-end: 8%;
    border-radius: var(--radius-md);
  }

  .isoShape--tealSmall {
    inline-size: 80px;
    block-size: 80px;
    background: rgba(255,255,255,0.06);
    transform: rotate(45deg) skewX(-20deg) skewY(-20deg);
    inset-block-start: 60px;
    inset-inline-end: 18%;
    border-radius: var(--radius-sm);
  }

  .isoMini {
    position: absolute;
    transform-style: preserve-3d;
  }

  .isoMini--a {
    inline-size: 80px;
    block-size: 80px;
    background: linear-gradient(135deg, var(--clr-iso1), var(--clr-iso2));
    transform: rotate(45deg) skewX(-15deg) skewY(-15deg);
    opacity: 0.2;
    inset-block-start: -20px;
    inset-inline-end: -20px;
    border-radius: var(--radius-xs);
  }

  .isoMini--b {
    inline-size: 40px;
    block-size: 40px;
    background: var(--clr-gold);
    transform: rotate(45deg) skewX(-20deg) skewY(-20deg);
    opacity: 0.3;
    inset-block-start: 40px;
    inset-inline-end: 20px;
    border-radius: 2px;
  }

  .isoGrid--bg {
    position: absolute;
    inset: 0;
    background-image:
      linear-gradient(var(--clr-accent) 1px, transparent 1px),
      linear-gradient(90deg, var(--clr-accent) 1px, transparent 1px);
    background-size: 40px 40px;
    opacity: 0.04;
    transform: perspective(600px) rotateX(15deg);
    pointer-events: none;
  }

  
  .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-6);
    border-radius: var(--radius-md);
    font-family: 'Inter', sans-serif;
    font-size: 0.95rem;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    border: 2px solid transparent;
    transition:
      background-color var(--transition-base),
      color var(--transition-base),
      border-color var(--transition-base),
      box-shadow var(--transition-base),
      transform var(--transition-fast);
    min-block-size: 48px;
    white-space: nowrap;
  }

  .btn:hover { transform: translateY(-1px); }
  .btn:active { transform: translateY(0); }

  .btn--primary {
    background-color: var(--clr-accent);
    color: var(--clr-text-light);
    border-color: var(--clr-accent);
    box-shadow: var(--shadow-sm);
  }

  .btn--primary:hover {
    background-color: var(--clr-teal);
    border-color: var(--clr-teal);
    color: var(--clr-text-light);
    box-shadow: var(--shadow-md);
  }

  .btn--ghost {
    background-color: rgba(255,255,255,0.15);
    color: var(--clr-primary);
    border-color: var(--clr-border);
    backdrop-filter: blur(4px);
  }

  .btn--ghost:hover {
    background-color: var(--clr-surface);
    border-color: var(--clr-accent);
    color: var(--clr-accent);
  }

  .btn--outline {
    background-color: transparent;
    color: var(--clr-accent);
    border-color: var(--clr-accent);
  }

  .btn--outline:hover {
    background-color: var(--clr-accent);
    color: var(--clr-text-light);
  }

  .btn--light {
    background-color: var(--clr-text-light);
    color: var(--clr-primary);
    border-color: var(--clr-text-light);
  }

  .btn--light:hover {
    background-color: var(--clr-surface2);
    color: var(--clr-accent);
  }

  .btn--fullWidth { inline-size: 100%; }

  .btn--sm {
    padding: var(--space-2) var(--space-4);
    font-size: 0.875rem;
    min-block-size: 40px;
  }

  .btn--large {
    padding: var(--space-4) var(--space-8);
    font-size: 1rem;
    min-block-size: 56px;
  }

  
  .sectionLabel {
    display: inline-block;
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--clr-accent);
    margin-block-end: var(--space-4);
  }

  .sectionLabel--light { color: var(--clr-accent2); }

  .sectionTitle {
    font-size: clamp(1.6rem, 4vw, 2.4rem);
    font-weight: 700;
    color: var(--clr-primary);
    margin-block-end: var(--space-6);
    line-height: 1.2;
  }

  .sectionTitle--center { text-align: center; }
  .sectionTitle--light { color: var(--clr-text-light); }

  .sectionIntro {
    font-size: 1.05rem;
    color: var(--clr-text-muted);
    max-inline-size: 620px;
    margin-inline: auto;
    text-align: center;
    margin-block-end: var(--space-10);
    line-height: 1.8;
  }

  .sectionIntro--left {
    text-align: start;
    margin-inline: 0;
  }

  .linkArrow {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-weight: 600;
    color: var(--clr-accent);
    text-decoration: none;
    font-size: 0.95rem;
    transition: gap var(--transition-fast), color var(--transition-fast);
  }

  .linkArrow:hover {
    gap: var(--space-3);
    color: var(--clr-teal);
  }

  
  .mainHero {
    position: relative;
    overflow: hidden;
    padding-block-start: var(--header-h);
    background: linear-gradient(135deg, var(--clr-bg) 0%, var(--clr-surface2) 100%);
  }

  .mainHero_isoDecor {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
  }

  .mainHero_inner {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-8);
    padding-block: var(--space-16) var(--space-10);
    max-inline-size: 1200px;
    margin-inline: auto;
    padding-inline: var(--space-6);
    align-items: center;
  }

  @media (min-width: 900px) {
    .mainHero_inner {
      grid-template-columns: 3fr 2fr;
      gap: var(--space-16);
    }
  }

  .mainHero_visual { order: -1; }

  @media (min-width: 900px) {
    .mainHero_visual { order: 1; }
  }

  .mainHero_imgWrap {
    position: relative;
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-xl);
    aspect-ratio: 4/3;
  }

  .mainHero_img {
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
    transition: transform 600ms ease;
  }

  .mainHero_imgWrap:hover .mainHero_img { transform: scale(1.03); }

  .mainHero_imgAccent {
    position: absolute;
    inset-block-end: -20px;
    inset-inline-end: -20px;
    inline-size: 120px;
    block-size: 120px;
    background: linear-gradient(135deg, var(--clr-iso1), var(--clr-iso2));
    transform: rotate(45deg) skewX(-15deg) skewY(-15deg);
    opacity: 0.25;
    border-radius: var(--radius-md);
    z-index: -1;
  }

  .mainHero_label {
    display: inline-block;
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--clr-accent);
    margin-block-end: var(--space-4);
    padding: var(--space-2) var(--space-4);
    background-color: var(--clr-accent-light);
    border-radius: var(--radius-full);
  }

  .mainHero_title {
    font-size: clamp(2rem, 5vw, 3.5rem);
    font-weight: 700;
    color: var(--clr-primary);
    line-height: 1.1;
    margin-block-end: var(--space-5);
    letter-spacing: -0.02em;
  }

  .mainHero_desc {
    font-size: 1.05rem;
    color: var(--clr-text-muted);
    line-height: 1.8;
    margin-block-end: var(--space-8);
    max-inline-size: 480px;
  }

  .mainHero_cta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-4);
  }

  .mainHero_trustBar {
    background-color: var(--clr-primary);
    padding-block: var(--space-5);
    margin-block-start: var(--space-10);
  }

  .trustBar_inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-6);
    max-inline-size: 1200px;
    margin-inline: auto;
    padding-inline: var(--space-6);
  }

  .trustBar_item {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    color: rgba(245,244,240,0.85);
    font-size: 0.88rem;
    font-weight: 500;
    white-space: nowrap;
  }

  .trustBar_icon {
    color: var(--clr-accent2);
    font-size: 1rem;
  }

  
  .introSection {
    padding-block: var(--space-20);
  }

  .introSection_grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-12);
    align-items: center;
  }

  @media (min-width: 768px) {
    .introSection_grid {
      grid-template-columns: 1fr 1fr;
      gap: var(--space-16);
    }
  }

  .introSection_text p {
    color: var(--clr-text-muted);
    margin-block-end: var(--space-5);
    line-height: 1.8;
    font-size: 1.02rem;
  }

  .introSection_text p:last-of-type { margin-block-end: var(--space-8); }

  .introSection_visual { position: relative; }

  .introSection_imgWrap {
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
    aspect-ratio: 4/3;
  }

  .introSection_img {
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
    transition: transform 500ms ease;
  }

  .introSection_imgWrap:hover .introSection_img { transform: scale(1.04); }

  .introSection_isoAccent {
    position: absolute;
    inset-block-end: -30px;
    inset-inline-start: -30px;
    inline-size: 100px;
    block-size: 100px;
    pointer-events: none;
  }

  
  .workshopsSection {
    position: relative;
    padding-block: var(--space-20);
    background-color: var(--clr-surface2);
    overflow: hidden;
  }

  .workshopsSection_bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
  }

  .workshopsSection_header {
    text-align: center;
    margin-block-end: var(--space-12);
  }

  .workshopsGrid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }

  @media (min-width: 640px) {
    .workshopsGrid { grid-template-columns: 1fr 1fr; }
  }

  @media (min-width: 1024px) {
    .workshopsGrid { grid-template-columns: repeat(4, 1fr); }
  }

  .workshopCard {
    position: relative;
    background-color: var(--clr-surface);
    border-radius: var(--radius-lg);
    padding: var(--space-8) var(--space-6);
    box-shadow: var(--shadow-sm);
    transition: box-shadow var(--transition-base), transform var(--transition-base);
    overflow: hidden;
  }

  .workshopCard:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-4px);
  }

  .workshopCard_isoTop {
    position: absolute;
    inset-block-start: -20px;
    inset-inline-end: -20px;
    inline-size: 80px;
    block-size: 80px;
    background: linear-gradient(135deg, var(--clr-iso1), var(--clr-iso2));
    transform: rotate(45deg) skewX(-15deg) skewY(-15deg);
    opacity: 0.1;
    border-radius: var(--radius-sm);
  }

  .workshopCard_icon {
    font-size: 1.8rem;
    color: var(--clr-accent);
    margin-block-end: var(--space-5);
    inline-size: 56px;
    block-size: 56px;
    background-color: var(--clr-accent-light);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .workshopCard_title {
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--clr-primary);
    margin-block-end: var(--space-4);
    line-height: 1.3;
  }

  .workshopCard_desc {
    font-size: 0.92rem;
    color: var(--clr-text-muted);
    line-height: 1.7;
    margin-block-end: var(--space-6);
  }

  .workshopCard_link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--clr-accent);
    text-decoration: none;
    transition: gap var(--transition-fast), color var(--transition-fast);
  }

  .workshopCard_link:hover {
    gap: var(--space-3);
    color: var(--clr-teal);
  }

  
  .approachSection {
    padding-block: var(--space-20);
  }

  .approachSection_grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-12);
    align-items: center;
  }

  @media (min-width: 900px) {
    .approachSection_grid { grid-template-columns: 1fr 1fr; }
  }

  .approachSection_visual { position: relative; }

  .approachSection_img {
    inline-size: 100%;
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-lg);
    aspect-ratio: 4/3;
    object-fit: cover;
    transition: transform 500ms ease;
  }

  .approachSection_img:hover { transform: scale(1.02); }

  .approachSection_floatCard {
    position: absolute;
    inset-block-end: var(--space-6);
    inset-inline-start: var(--space-6);
    background-color: var(--clr-surface);
    border-radius: var(--radius-md);
    padding: var(--space-4) var(--space-5);
    box-shadow: var(--shadow-lg);
    display: flex;
    align-items: center;
    gap: var(--space-3);
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--clr-primary);
    max-inline-size: 240px;
  }

  .approachSection_floatCard i {
    color: var(--clr-gold);
    font-size: 1.2rem;
    flex-shrink: 0;
  }

  .approachList {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
    margin-block-start: var(--space-6);
  }

  .approachItem {
    display: grid;
    grid-template-columns: 48px 1fr;
    gap: var(--space-4);
    align-items: start;
  }

  .approachItem_num {
    font-family: 'Lora', serif;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--clr-accent);
    background-color: var(--clr-accent-light);
    inline-size: 44px;
    block-size: 44px;
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
  }

  .approachItem_text strong {
    display: block;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--clr-primary);
    margin-block-end: var(--space-2);
  }

  .approachItem_text p {
    font-size: 0.92rem;
    color: var(--clr-text-muted);
    line-height: 1.7;
    margin: 0;
  }

  
  .ctaDualSection {
    padding-block: var(--space-16);
    background-color: var(--clr-surface2);
  }

  .ctaDual_grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }

  @media (min-width: 640px) {
    .ctaDual_grid { grid-template-columns: 1fr 1fr; }
  }

  .ctaDual_card {
    position: relative;
    border-radius: var(--radius-xl);
    padding: var(--space-10) var(--space-8);
    overflow: hidden;
  }

  .ctaDual_card--primary {
    background: linear-gradient(135deg, var(--clr-primary) 0%, var(--clr-primary-light) 100%);
    color: var(--clr-text-light);
    box-shadow: var(--shadow-xl);
  }

  .ctaDual_card--secondary {
    background-color: var(--clr-surface);
    border: 2px solid var(--clr-border);
    box-shadow: var(--shadow-md);
  }

  .ctaDual_isoAccent {
    position: absolute;
    inset-block-start: -30px;
    inset-inline-end: -30px;
    inline-size: 120px;
    block-size: 120px;
    background: rgba(255,255,255,0.06);
    transform: rotate(45deg) skewX(-15deg) skewY(-15deg);
    border-radius: var(--radius-md);
    pointer-events: none;
  }

  .ctaDual_icon {
    font-size: 2rem;
    margin-block-end: var(--space-5);
  }

  .ctaDual_card--primary .ctaDual_icon { color: var(--clr-accent2); }
  .ctaDual_card--secondary .ctaDual_icon { color: var(--clr-accent); }

  .ctaDual_title {
    font-size: 1.5rem;
    font-weight: 700;
    margin-block-end: var(--space-4);
  }

  .ctaDual_card--primary .ctaDual_title { color: var(--clr-text-light); }
  .ctaDual_card--secondary .ctaDual_title { color: var(--clr-primary); }

  .ctaDual_desc {
    font-size: 0.95rem;
    line-height: 1.7;
    margin-block-end: var(--space-8);
  }

  .ctaDual_card--primary .ctaDual_desc { color: rgba(245,244,240,0.8); }
  .ctaDual_card--secondary .ctaDual_desc { color: var(--clr-text-muted); }

  
  .faqSection {
    padding-block: var(--space-20);
  }

  .faqSection_header {
    text-align: center;
    margin-block-end: var(--space-12);
  }

  .faqGrid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }

  @media (min-width: 768px) {
    .faqGrid { grid-template-columns: 1fr 1fr; }
  }

  .faqCard {
    background-color: var(--clr-surface);
    border-radius: var(--radius-lg);
    border: 1px solid var(--clr-border);
    overflow: hidden;
    box-shadow: var(--shadow-xs);
    transition: box-shadow var(--transition-base);
  }

  .faqCard:hover { box-shadow: var(--shadow-sm); }

  .faqCard_question {
    inline-size: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    padding: var(--space-5) var(--space-6);
    font-family: 'Inter', sans-serif;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--clr-primary);
    text-align: start;
    background: none;
    border: none;
    cursor: pointer;
    transition: color var(--transition-fast), background-color var(--transition-fast);
    min-block-size: 60px;
  }

  .faqCard_question:hover {
    color: var(--clr-accent);
    background-color: var(--clr-surface2);
  }

  .faqCard_question[aria-expanded="true"] {
    color: var(--clr-accent);
    background-color: var(--clr-accent-light);
  }

  .faqCard_icon {
    flex-shrink: 0;
    font-size: 0.8rem;
    color: var(--clr-accent);
    transition: transform var(--transition-base);
  }

  .faqCard_question[aria-expanded="true"] .faqCard_icon {
    transform: rotate(45deg);
  }

  .faqCard_answer {
    padding: var(--space-5) var(--space-6) var(--space-6);
    font-size: 0.93rem;
    color: var(--clr-text-muted);
    line-height: 1.8;
    border-block-start: 1px solid var(--clr-border);
  }

  .faqCard_answer[hidden] { display: none; }

  
  .blogSection {
    padding-block: var(--space-20);
    background-color: var(--clr-surface2);
  }

  .blogSection_header {
    margin-block-end: var(--space-10);
  }

  .blogGrid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }

  @media (min-width: 768px) {
    .blogGrid { grid-template-columns: repeat(3, 1fr); }
  }

  .blogCard {
    background-color: var(--clr-surface);
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: box-shadow var(--transition-base), transform var(--transition-base);
  }

  .blogCard:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-4px);
  }

  .blogCard_imgWrap {
    aspect-ratio: 16/9;
    overflow: hidden;
  }

  .blogCard_img {
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
    transition: transform 500ms ease;
  }

  .blogCard:hover .blogCard_img { transform: scale(1.05); }

  .blogCard_body {
    padding: var(--space-6);
  }

  .blogCard_tag {
    display: inline-block;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--clr-accent);
    background-color: var(--clr-accent-light);
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
    margin-block-end: var(--space-4);
  }

  .blogCard_title {
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--clr-primary);
    margin-block-end: var(--space-3);
    line-height: 1.35;
  }

  .blogCard_excerpt {
    font-size: 0.9rem;
    color: var(--clr-text-muted);
    line-height: 1.7;
    margin-block-end: var(--space-5);
  }

  .blogCard_readMore {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--clr-accent);
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    transition: gap var(--transition-fast), color var(--transition-fast);
  }

  .blogCard_readMore:hover {
    gap: var(--space-3);
    color: var(--clr-teal);
  }

  
  .blogModal {
    position: fixed;
    inset: 0;
    z-index: 300;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-6);
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--transition-base);
  }

  .blogModal--open {
    opacity: 1;
    pointer-events: all;
  }

  .blogModal_overlay {
    position: absolute;
    inset: 0;
    background-color: rgba(26,39,68,0.85);
    cursor: pointer;
  }

  .blogModal_content {
    position: relative;
    background-color: var(--clr-surface);
    border-radius: var(--radius-xl);
    padding: var(--space-10);
    max-inline-size: 700px;
    inline-size: 100%;
    max-block-size: 80vh;
    overflow-y: auto;
    box-shadow: var(--shadow-xl);
    transform: translateY(20px);
    transition: transform var(--transition-base);
  }

  .blogModal--open .blogModal_content {
    transform: translateY(0);
  }

  .blogModal_close {
    position: absolute;
    inset-block-start: var(--space-5);
    inset-inline-end: var(--space-5);
    inline-size: 44px;
    block-size: 44px;
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--clr-text-muted);
    font-size: 1rem;
    transition: color var(--transition-fast), background-color var(--transition-fast);
    background: none;
    border: none;
    cursor: pointer;
  }

  .blogModal_close:hover {
    color: var(--clr-primary);
    background-color: var(--clr-surface2);
  }

  .blogModal_body h2 {
    font-size: 1.5rem;
    margin-block-end: var(--space-6);
    padding-inline-end: var(--space-12);
  }

  .blogModal_body p {
    font-size: 0.97rem;
    color: var(--clr-text-muted);
    line-height: 1.8;
    margin-block-end: var(--space-5);
  }

  
  .contactTeaser {
    padding-block: var(--space-20);
    background: linear-gradient(135deg, var(--clr-primary) 0%, var(--clr-primary-light) 100%);
    position: relative;
    overflow: hidden;
  }

  .contactTeaser_inner { position: relative; }

  .contactTeaser_isoDecor {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
  }

  .contactTeaser_content {
    max-inline-size: 600px;
  }

  .contactTeaser_content p {
    color: rgba(245,244,240,0.8);
    font-size: 1.05rem;
    line-height: 1.8;
    margin-block-end: var(--space-8);
  }

  .contactTeaser_actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-6);
  }

  .contactTeaser_phone {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    color: rgba(245,244,240,0.85);
    font-size: 1rem;
    font-weight: 600;
    text-decoration: none;
    transition: color var(--transition-fast);
  }

  .contactTeaser_phone:hover { color: var(--clr-accent2); }

  
  .pageHero {
    position: relative;
    overflow: hidden;
    padding-block: var(--space-20);
    padding-block-start: calc(var(--header-h) + var(--space-16));
    background: linear-gradient(135deg, var(--clr-primary) 0%, var(--clr-primary-light) 100%);
  }

  .pageHero_isoDecor {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
  }

  .pageHero_content {
    position: relative;
    max-inline-size: 700px;
  }

  .pageHero_title {
    font-size: clamp(2rem, 5vw, 3.2rem);
    font-weight: 700;
    color: var(--clr-text-light);
    margin-block-end: var(--space-5);
    line-height: 1.15;
  }

  .pageHero_desc {
    font-size: 1.1rem;
    color: rgba(245,244,240,0.8);
    line-height: 1.8;
    max-inline-size: 580px;
  }

  
  .teamSection {
    padding-block: var(--space-20);
  }

  .teamSection_intro {
    max-inline-size: 700px;
    margin-block-end: var(--space-12);
  }

  .teamSection_intro p {
    font-size: 1.05rem;
    color: var(--clr-text-muted);
    line-height: 1.8;
  }

  .teamGrid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  @media (min-width: 768px) {
    .teamGrid { grid-template-columns: 1fr 1fr; }
  }

  .teamCard {
    background-color: var(--clr-surface);
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-md);
    transition: box-shadow var(--transition-base), transform var(--transition-base);
  }

  .teamCard:hover {
    box-shadow: var(--shadow-xl);
    transform: translateY(-4px);
  }

  .teamCard_imgWrap {
    position: relative;
    aspect-ratio: 4/3;
    overflow: hidden;
  }

  .teamCard_img {
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
    transition: transform 500ms ease;
  }

  .teamCard:hover .teamCard_img { transform: scale(1.05); }

  .teamCard_isoAccent {
    position: absolute;
    inset-block-start: var(--space-4);
    inset-inline-end: var(--space-4);
    inline-size: 60px;
    block-size: 60px;
    background: linear-gradient(135deg, var(--clr-iso1), var(--clr-iso2));
    transform: rotate(45deg) skewX(-15deg) skewY(-15deg);
    opacity: 0.2;
    border-radius: var(--radius-xs);
  }

  .teamCard_body {
    padding: var(--space-8);
  }

  .teamCard_name {
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--clr-primary);
    margin-block-end: var(--space-2);
  }

  .teamCard_role {
    display: block;
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--clr-accent);
    margin-block-end: var(--space-5);
  }

  .teamCard_bio {
    font-size: 0.95rem;
    color: var(--clr-text-muted);
    line-height: 1.8;
    margin-block-end: var(--space-6);
  }

  .teamCard_areas {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
  }

  .teamCard_area {
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--clr-accent);
    background-color: var(--clr-accent-light);
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
  }

  
  .valuesSection {
    position: relative;
    padding-block: var(--space-20);
    background-color: var(--clr-surface2);
    overflow: hidden;
  }

  .valuesSection_bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
  }

  .valuesSection_header {
    text-align: center;
    margin-block-end: var(--space-12);
  }

  .valuesGrid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }

  @media (min-width: 640px) {
    .valuesGrid { grid-template-columns: 1fr 1fr; }
  }

  @media (min-width: 1024px) {
    .valuesGrid { grid-template-columns: repeat(4, 1fr); }
  }

  .valueCard {
    background-color: var(--clr-surface);
    border-radius: var(--radius-lg);
    padding: var(--space-8) var(--space-6);
    box-shadow: var(--shadow-sm);
    transition: box-shadow var(--transition-base), transform var(--transition-base);
  }

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

  .valueCard_icon {
    font-size: 1.6rem;
    color: var(--clr-accent);
    inline-size: 52px;
    block-size: 52px;
    background-color: var(--clr-accent-light);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-block-end: var(--space-5);
  }

  .valueCard_title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--clr-primary);
    margin-block-end: var(--space-3);
  }

  .valueCard p {
    font-size: 0.9rem;
    color: var(--clr-text-muted);
    line-height: 1.7;
  }

  
  .teamCta {
    padding-block: var(--space-16);
  }

  .teamCta_inner {
    text-align: center;
    max-inline-size: 500px;
    margin-inline: auto;
  }

  .teamCta_inner p {
    color: var(--clr-text-muted);
    margin-block-end: var(--space-8);
    font-size: 1.05rem;
  }

  .teamCta_actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-4);
  }

  
  .locationSection {
    padding-block: var(--space-20);
  }

  .locationSection_grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-12);
    align-items: center;
  }

  @media (min-width: 900px) {
    .locationSection_grid { grid-template-columns: 1fr 1fr; }
  }

  .locationSection_content p {
    color: var(--clr-text-muted);
    line-height: 1.8;
    margin-block-end: var(--space-5);
    font-size: 1.02rem;
  }

  .locationDetails {
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
    margin-block-start: var(--space-8);
  }

  .locationDetail {
    display: flex;
    align-items: flex-start;
    gap: var(--space-4);
  }

  .locationDetail i {
    color: var(--clr-accent);
    font-size: 1rem;
    margin-block-start: 3px;
    flex-shrink: 0;
    inline-size: 20px;
  }

  .locationDetail strong {
    display: block;
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--clr-primary);
    margin-block-end: var(--space-1);
  }

  .locationDetail span {
    font-size: 0.9rem;
    color: var(--clr-text-muted);
  }

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

  
  .scheduleSection {
    position: relative;
    padding-block: var(--space-20);
    background-color: var(--clr-surface2);
    overflow: hidden;
  }

  .scheduleSection_bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
  }

  .scheduleSection_header {
    text-align: center;
    margin-block-end: var(--space-12);
  }

  .scheduleList {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    margin-block-end: var(--space-8);
  }

  .scheduleItem {
    background-color: var(--clr-surface);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    box-shadow: var(--shadow-sm);
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-5);
    transition: box-shadow var(--transition-base), transform var(--transition-base);
    border-inline-start: 4px solid var(--clr-accent);
  }

  @media (min-width: 768px) {
    .scheduleItem {
      grid-template-columns: 80px 1fr auto;
      align-items: center;
    }
  }

  .scheduleItem:hover {
    box-shadow: var(--shadow-md);
    transform: translateX(4px);
  }

  .scheduleItem_date {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
  }

  @media (min-width: 768px) {
    .scheduleItem_date { align-items: center; }
  }

  .scheduleItem_day {
    font-family: 'Lora', serif;
    font-size: 2rem;
    font-weight: 700;
    color: var(--clr-primary);
    line-height: 1;
  }

  .scheduleItem_month {
    font-size: 0.78rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--clr-accent);
  }

  .scheduleItem_title {
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--clr-primary);
    margin-block-end: var(--space-3);
  }

  .scheduleItem_desc {
    font-size: 0.9rem;
    color: var(--clr-text-muted);
    line-height: 1.7;
    margin-block-end: var(--space-4);
  }

  .scheduleItem_meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-4);
    font-size: 0.83rem;
    color: var(--clr-text-muted);
  }

  .scheduleItem_meta span {
    display: flex;
    align-items: center;
    gap: var(--space-2);
  }

  .scheduleItem_meta i { color: var(--clr-accent); }

  .scheduleSection_note {
    display: flex;
    align-items: flex-start;
    gap: var(--space-4);
    background-color: var(--clr-accent-light);
    border-radius: var(--radius-md);
    padding: var(--space-5) var(--space-6);
    font-size: 0.92rem;
    color: var(--clr-teal);
  }

  .scheduleSection_note i {
    font-size: 1.1rem;
    flex-shrink: 0;
    margin-block-start: 2px;
  }

  .scheduleSection_note p { margin: 0; line-height: 1.6; }

  
  .stationaryCta {
    padding-block: var(--space-16);
  }

  .stationaryCta_inner {
    text-align: center;
    max-inline-size: 500px;
    margin-inline: auto;
  }

  .stationaryCta_inner p {
    color: var(--clr-text-muted);
    margin-block-end: var(--space-8);
    font-size: 1.05rem;
    line-height: 1.8;
  }

  
  .orderPage {
    position: relative;
    padding-block: calc(var(--header-h) + var(--space-12)) var(--space-20);
    overflow: hidden;
  }

  .orderPage_isoDecor {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
  }

  .orderPage_header {
    text-align: center;
    margin-block-end: var(--space-10);
  }

  .orderPage_title {
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 700;
    color: var(--clr-primary);
    margin-block-end: var(--space-5);
  }

  .orderPage_desc {
    font-size: 1.05rem;
    color: var(--clr-text-muted);
    line-height: 1.8;
    max-inline-size: 560px;
    margin-inline: auto;
  }

  
  .contactPage {
    position: relative;
    padding-block: calc(var(--header-h) + var(--space-12)) var(--space-20);
    overflow: hidden;
  }

  .contactPage_isoDecor {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
  }

  .contactPage_header {
    text-align: center;
    margin-block-end: var(--space-10);
  }

  .contactPage_title {
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 700;
    color: var(--clr-primary);
    margin-block-end: var(--space-5);
  }

  .contactPage_desc {
    font-size: 1.05rem;
    color: var(--clr-text-muted);
    line-height: 1.8;
    max-inline-size: 560px;
    margin-inline: auto;
  }

  
  .orderForm,
  .contactForm {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
  }

  .formGroup {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
  }

  .formGroup_helper {
    font-size: 0.82rem;
    color: var(--clr-text-muted);
    line-height: 1.5;
    padding-inline-start: var(--space-2);
  }

  .formGroup_error {
    background-color: #fee2e2;
    color: #b91c1c;
    border-radius: var(--radius-sm);
    padding: var(--space-4) var(--space-5);
    font-size: 0.92rem;
    font-weight: 500;
  }

  
  .floatLabel {
    position: relative;
  }

  .floatLabel_input {
    inline-size: 100%;
    padding: var(--space-5) var(--space-5) var(--space-3);
    font-family: 'Inter', sans-serif;
    font-size: 1rem;
    color: var(--clr-text);
    background-color: var(--clr-surface);
    border: 2px solid var(--clr-border);
    border-radius: var(--radius-md);
    outline: none;
    transition: border-color var(--transition-base), box-shadow var(--transition-base);
    appearance: none;
    block-size: 58px;
  }

  .floatLabel_input--textarea {
    block-size: auto;
    min-block-size: 140px;
    padding-block-start: var(--space-6);
    resize: vertical;
    line-height: 1.6;
  }

  .floatLabel_input--select {
    cursor: pointer;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235a5750' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right var(--space-5) center;
    padding-inline-end: var(--space-10);
  }

  .floatLabel_input:focus {
    border-color: var(--clr-accent);
    box-shadow: 0 0 0 3px rgba(74,124,111,0.15);
  }

  .floatLabel_label {
    position: absolute;
    inset-block-start: 50%;
    inset-inline-start: var(--space-5);
    transform: translateY(-50%);
    font-size: 1rem;
    color: var(--clr-text-muted);
    pointer-events: none;
    transition:
      inset-block-start var(--transition-base),
      font-size var(--transition-base),
      color var(--transition-base),
      transform var(--transition-base);
    background: transparent;
    padding-inline: var(--space-1);
    line-height: 1;
  }

  .floatLabel_input--textarea ~ .floatLabel_label {
    inset-block-start: var(--space-5);
    transform: none;
  }

  .floatLabel_input:focus ~ .floatLabel_label,
  .floatLabel_input:not(:placeholder-shown) ~ .floatLabel_label {
    inset-block-start: var(--space-2);
    font-size: 0.72rem;
    color: var(--clr-accent);
    font-weight: 600;
    letter-spacing: 0.04em;
    transform: none;
  }

  .floatLabel_input--textarea:focus ~ .floatLabel_label,
  .floatLabel_input--textarea:not(:placeholder-shown) ~ .floatLabel_label {
    inset-block-start: var(--space-2);
    font-size: 0.72rem;
    color: var(--clr-accent);
    font-weight: 600;
    letter-spacing: 0.04em;
  }

  .floatLabel_input--select:valid ~ .floatLabel_label,
  .floatLabel_input--select:focus ~ .floatLabel_label {
    inset-block-start: var(--space-2);
    font-size: 0.72rem;
    color: var(--clr-accent);
    font-weight: 600;
    letter-spacing: 0.04em;
    transform: none;
  }

  .floatLabel_label--phone {
    inset-block-start: 50%;
    transform: translateY(-50%);
    inset-inline-start: 56px;
  }

  .floatLabel_input:focus ~ .floatLabel_label--phone,
  .floatLabel_input:not(:placeholder-shown) ~ .floatLabel_label--phone {
    inset-block-start: var(--space-2);
    inset-inline-start: var(--space-5);
    transform: none;
    font-size: 0.72rem;
    color: var(--clr-accent);
    font-weight: 600;
  }

  
  .formGroup--checkbox { gap: var(--space-3); }

  .checkboxLabel {
    display: flex;
    align-items: flex-start;
    gap: var(--space-4);
    cursor: pointer;
  }

  .checkboxLabel_input {
    position: absolute;
    opacity: 0;
    inline-size: 0;
    block-size: 0;
  }

  .checkboxLabel_custom {
    flex-shrink: 0;
    inline-size: 22px;
    block-size: 22px;
    border: 2px solid var(--clr-border);
    border-radius: var(--radius-xs);
    background-color: var(--clr-surface);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: border-color var(--transition-base), background-color var(--transition-base);
    margin-block-start: 2px;
  }

  .checkboxLabel_input:checked + .checkboxLabel_custom {
    background-color: var(--clr-accent);
    border-color: var(--clr-accent);
  }

  .checkboxLabel_input:checked + .checkboxLabel_custom::after {
    content: '';
    inline-size: 5px;
    block-size: 9px;
    border: 2px solid white;
    border-block-start: none;
    border-inline-start: none;
    transform: rotate(45deg) translateY(-1px);
    display: block;
  }

  .checkboxLabel_input:focus + .checkboxLabel_custom {
    box-shadow: 0 0 0 3px rgba(74,124,111,0.2);
  }

  .checkboxLabel_text {
    font-size: 0.92rem;
    color: var(--clr-text-muted);
    line-height: 1.6;
  }

  .checkboxLabel_text a {
    color: var(--clr-accent);
    text-decoration: underline;
    text-underline-offset: 2px;
  }

  
  .urgentContact {
    padding-block: var(--space-16);
    background-color: var(--clr-surface2);
  }

  .urgentContact_inner {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-6);
    background-color: var(--clr-surface);
    border-radius: var(--radius-xl);
    padding: var(--space-10) var(--space-8);
    box-shadow: var(--shadow-md);
    border-inline-start: 6px solid var(--clr-accent);
  }

  @media (min-width: 768px) {
    .urgentContact_inner {
      flex-direction: row;
      align-items: center;
    }
  }

  .urgentContact_icon {
    font-size: 2.5rem;
    color: var(--clr-accent);
    flex-shrink: 0;
    inline-size: 72px;
    block-size: 72px;
    background-color: var(--clr-accent-light);
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .urgentContact_content { flex: 1; }

  .urgentContact_title {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--clr-primary);
    margin-block-end: var(--space-3);
  }

  .urgentContact_content p {
    font-size: 0.97rem;
    color: var(--clr-text-muted);
    line-height: 1.8;
    margin-block-end: var(--space-6);
  }

  
  .mapSection {
    padding-block: var(--space-16);
  }

  .mapSection_header {
    margin-block-end: var(--space-8);
  }

  .mapSection_header p {
    color: var(--clr-text-muted);
    font-size: 1rem;
    margin-block-start: var(--space-3);
  }

  .mapSection_mapWrap {
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
    border: 1px solid var(--clr-border);
  }

  .mapSection_iframe {
    display: block;
    inline-size: 100%;
    block-size: 420px;
    border: none;
  }

  
  .thanksPage {
    position: relative;
    min-block-size: calc(100dvh - var(--header-h));
    display: flex;
    align-items: center;
    justify-content: center;
    padding-block: calc(var(--header-h) + var(--space-16)) var(--space-20);
    overflow: hidden;
    background: linear-gradient(135deg, var(--clr-bg) 0%, var(--clr-surface2) 100%);
  }

  .thanksPage_isoDecor {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
  }

  .thanksPage_inner {
    position: relative;
    text-align: center;
    max-inline-size: 560px;
    padding-inline: var(--space-6);
  }

  .thanksPage_iconWrap {
    inline-size: 100px;
    block-size: 100px;
    background: linear-gradient(135deg, var(--clr-accent), var(--clr-teal));
    border-radius: var(--radius-xl);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-inline: auto;
    margin-block-end: var(--space-8);
    box-shadow: var(--shadow-lg);
  }

  .thanksPage_icon {
    font-size: 2.5rem;
    color: white;
  }

  .thanksPage_title {
    font-size: clamp(1.8rem, 4vw, 2.5rem);
    font-weight: 700;
    color: var(--clr-primary);
    margin-block-end: var(--space-5);
  }

  .thanksPage_text {
    font-size: 1.05rem;
    color: var(--clr-text-muted);
    line-height: 1.8;
    margin-block-end: var(--space-4);
  }

  .thanksPage_sub {
    font-size: 0.95rem;
    color: var(--clr-text-muted);
    line-height: 1.7;
    margin-block-end: var(--space-10);
  }

  .thanksPage_sub a {
    color: var(--clr-accent);
    text-decoration: underline;
    text-underline-offset: 2px;
  }

  
  .legalPage {
    padding-block: calc(var(--header-h) + var(--space-12)) var(--space-20);
  }

  .legalPage_header {
    margin-block-end: var(--space-10);
  }

  .legalPage_title {
    font-size: clamp(1.8rem, 4vw, 2.8rem);
    font-weight: 700;
    color: var(--clr-primary);
    margin-block-end: var(--space-3);
  }

  .legalPage_meta {
    font-size: 0.88rem;
    color: var(--clr-text-muted);
    margin-block-end: var(--space-6);
    font-weight: 500;
  }

  .legalPage_intro {
    font-size: 1rem;
    color: var(--clr-text-muted);
    line-height: 1.8;
    max-inline-size: 720px;
    padding: var(--space-6);
    background-color: var(--clr-accent-light);
    border-radius: var(--radius-md);
    border-inline-start: 4px solid var(--clr-accent);
  }

  
  .accordionList {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
  }

  .accordionItem {
    background-color: var(--clr-surface);
    border-radius: var(--radius-lg);
    border: 1px solid var(--clr-border);
    overflow: hidden;
    box-shadow: var(--shadow-xs);
    transition: box-shadow var(--transition-base);
  }

  .accordionItem:hover { box-shadow: var(--shadow-sm); }

  .accordionItem--open .accordionItem_body { display: block; }

  .accordionItem_header {
    inline-size: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    padding: var(--space-5) var(--space-6);
    font-family: 'Lora', serif;
    font-size: 1rem;
    font-weight: 600;
    color: var(--clr-primary);
    text-align: start;
    background: none;
    border: none;
    cursor: pointer;
    transition: color var(--transition-fast), background-color var(--transition-fast);
    min-block-size: 64px;
  }

  .accordionItem_header:hover {
    color: var(--clr-accent);
    background-color: var(--clr-surface2);
  }

  .accordionItem_header[aria-expanded="true"] {
    color: var(--clr-accent);
    background-color: var(--clr-accent-light);
  }

  .accordionItem_icon {
    flex-shrink: 0;
    font-size: 0.85rem;
    color: var(--clr-accent);
    transition: transform var(--transition-base);
  }

  .accordionItem_header[aria-expanded="true"] .accordionItem_icon {
    transform: rotate(180deg);
  }

  .accordionItem_body {
    padding: var(--space-6) var(--space-6) var(--space-8);
    font-size: 0.95rem;
    color: var(--clr-text-muted);
    line-height: 1.8;
    border-block-start: 1px solid var(--clr-border);
  }

  .accordionItem_body[hidden] { display: none; }

  .accordionItem_body p { margin-block-end: var(--space-4); }
  .accordionItem_body p:last-child { margin-block-end: 0; }

  .accordionItem_body ul {
    list-style: disc;
    padding-inline-start: var(--space-6);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    margin-block: var(--space-3);
  }

  .accordionItem_body ul li { font-size: 0.93rem; }
  .accordionItem_body strong { color: var(--clr-primary); font-weight: 600; }

  .accordionItem_body a {
    color: var(--clr-accent);
    text-decoration: underline;
    text-underline-offset: 2px;
  }

  
  .pageFooter {
    background-color: var(--clr-primary);
    color: rgba(245,244,240,0.75);
    padding-block: var(--space-16) var(--space-8);
    margin-block-start: auto;
  }

  .pageFooter_grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-10);
    margin-block-end: var(--space-10);
  }

  @media (min-width: 640px) {
    .pageFooter_grid { grid-template-columns: 1fr 1fr; }
  }

  @media (min-width: 1024px) {
    .pageFooter_grid { grid-template-columns: 2fr 1fr 1fr 1fr; }
  }

  .pageFooter_logo {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    text-decoration: none;
    margin-block-end: var(--space-5);
  }

  .pageFooter_logoImg {
    block-size: 32px;
    inline-size: auto;
    filter: brightness(0) invert(1) opacity(0.9);
  }

  .pageFooter_logo span {
    font-family: 'Lora', serif;
    font-weight: 700;
    font-size: 1.1rem;
    color: var(--clr-text-light);
  }

  .pageFooter_tagline {
    font-size: 0.88rem;
    line-height: 1.7;
    margin-block-end: var(--space-5);
    max-inline-size: 280px;
  }

  .pageFooter_address {
    font-size: 0.88rem;
    line-height: 1.8;
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
  }

  .pageFooter_address i {
    color: var(--clr-accent2);
    margin-block-start: 4px;
    flex-shrink: 0;
  }

  .pageFooter_navTitle {
    font-family: 'Inter', sans-serif;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(245,244,240,0.5);
    margin-block-end: var(--space-5);
  }

  .pageFooter_links {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
  }

  .pageFooter_link {
    font-size: 0.9rem;
    color: rgba(245,244,240,0.7);
    text-decoration: none;
    transition: color var(--transition-fast);
  }

  .pageFooter_link:hover { color: var(--clr-text-light); }

  .pageFooter_contact {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
  }

  .pageFooter_contactItem {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    font-size: 0.9rem;
    color: rgba(245,244,240,0.7);
    text-decoration: none;
    transition: color var(--transition-fast);
  }

  .pageFooter_contactItem:hover { color: var(--clr-text-light); }
  .pageFooter_contactItem i { color: var(--clr-accent2); font-size: 0.9rem; }

  .pageFooter_bottom {
    border-block-start: 1px solid rgba(255,255,255,0.1);
    padding-block-start: var(--space-6);
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: var(--space-3);
    font-size: 0.82rem;
    color: rgba(245,244,240,0.45);
  }

  
  .cookieCard {
    position: fixed;
    inset-block-end: var(--space-6);
    inset-inline-start: 50%;
    transform: translateX(-50%);
    z-index: 500;
    background-color: var(--clr-surface);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-xl);
    border: 1px solid var(--clr-border);
    inline-size: min(480px, calc(100vw - var(--space-8)));
    overflow: hidden;
    transition:
      inline-size var(--transition-slow),
      max-block-size var(--transition-slow),
      opacity var(--transition-base);
    opacity: 0;
    max-block-size: 0;
    pointer-events: none;
  }

  .cookieCard--visible {
    opacity: 1;
    max-block-size: 700px;
    pointer-events: all;
  }

  .cookieCard--expanded {
    inline-size: min(560px, calc(100vw - var(--space-8)));
  }

  .cookieCard_compact {
    padding: var(--space-5) var(--space-6);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
  }

  @media (min-width: 480px) {
    .cookieCard_compact {
      flex-direction: row;
      align-items: center;
    }
  }

  .cookieCard_text {
    flex: 1;
    font-size: 0.88rem;
    color: var(--clr-text-muted);
    line-height: 1.6;
  }

  .cookieCard_text strong {
    display: block;
    color: var(--clr-primary);
    font-weight: 600;
    margin-block-end: var(--space-1);
    font-size: 0.95rem;
  }

  .cookieCard_text a {
    color: var(--clr-accent);
    text-decoration: underline;
    text-underline-offset: 2px;
    font-size: 0.82rem;
  }

  .cookieCard_actions {
    display: flex;
    gap: var(--space-3);
    flex-shrink: 0;
    flex-wrap: wrap;
  }

  .cookieCard_btnAccept {
    background-color: var(--clr-accent);
    color: white;
    border: none;
    border-radius: var(--radius-md);
    padding: var(--space-2) var(--space-5);
    font-size: 0.88rem;
    font-weight: 600;
    cursor: pointer;
    transition: background-color var(--transition-fast), transform var(--transition-fast);
    min-block-size: 40px;
    white-space: nowrap;
    font-family: inherit;
  }

  .cookieCard_btnAccept:hover {
    background-color: var(--clr-teal);
    transform: translateY(-1px);
  }

  .cookieCard_btnSettings {
    background-color: transparent;
    color: var(--clr-text-muted);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-md);
    padding: var(--space-2) var(--space-4);
    font-size: 0.88rem;
    font-weight: 500;
    cursor: pointer;
    transition: color var(--transition-fast), border-color var(--transition-fast), background-color var(--transition-fast);
    min-block-size: 40px;
    white-space: nowrap;
    font-family: inherit;
  }

  .cookieCard_btnSettings:hover {
    color: var(--clr-primary);
    border-color: var(--clr-accent);
    background-color: var(--clr-accent-light);
  }

  .cookieCard_expanded {
    display: none;
    padding: var(--space-6);
    border-block-start: 1px solid var(--clr-border);
  }

  .cookieCard--expanded .cookieCard_expanded { display: block; }

  .cookieCard_expandedTitle {
    font-family: 'Lora', serif;
    font-size: 1rem;
    font-weight: 600;
    color: var(--clr-primary);
    margin-block-end: var(--space-5);
  }

  .cookieToggle {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-4);
    padding-block: var(--space-4);
    border-block-end: 1px solid var(--clr-border);
  }

  .cookieToggle:last-of-type { border-block-end: none; }

  .cookieToggle_info { flex: 1; }

  .cookieToggle_name {
    display: block;
    font-size: 0.92rem;
    font-weight: 600;
    color: var(--clr-primary);
    margin-block-end: var(--space-1);
  }

  .cookieToggle_desc {
    font-size: 0.82rem;
    color: var(--clr-text-muted);
    line-height: 1.5;
  }

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

  .cookieToggle_input {
    opacity: 0;
    inline-size: 0;
    block-size: 0;
    position: absolute;
  }

  .cookieToggle_slider {
    position: absolute;
    inset: 0;
    background-color: var(--clr-border);
    border-radius: var(--radius-full);
    cursor: pointer;
    transition: background-color var(--transition-base);
  }

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

  .cookieToggle_input:checked + .cookieToggle_slider {
    background-color: var(--clr-accent);
  }

  .cookieToggle_input:checked + .cookieToggle_slider::before {
    transform: translateX(20px);
  }

  .cookieToggle_input:disabled + .cookieToggle_slider {
    opacity: 0.6;
    cursor: not-allowed;
  }

  .cookieCard_expandedActions {
    display: flex;
    gap: var(--space-3);
    margin-block-start: var(--space-6);
    flex-wrap: wrap;
  }

  .cookieCard_btnSave {
    flex: 1;
    background-color: var(--clr-accent);
    color: white;
    border: none;
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-5);
    font-size: 0.9rem;
    font-weight: 600;
    cursor: pointer;
    transition: background-color var(--transition-fast);
    min-block-size: 44px;
    font-family: inherit;
  }

  .cookieCard_btnSave:hover { background-color: var(--clr-teal); }

  .cookieCard_btnRejectAll {
    background-color: transparent;
    color: var(--clr-text-muted);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-4);
    font-size: 0.88rem;
    font-weight: 500;
    cursor: pointer;
    transition: color var(--transition-fast), border-color var(--transition-fast);
    min-block-size: 44px;
    white-space: nowrap;
    font-family: inherit;
  }

  .cookieCard_btnRejectAll:hover {
    color: var(--clr-primary);
    border-color: var(--clr-primary);
  }

  
  .revealOnScroll {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 600ms ease, transform 600ms ease;
  }

  .revealOnScroll--visible {
    opacity: 1;
    transform: translateY(0);
  }
}

@layer utilities {
  .visually-hidden {
    position: absolute;
    inline-size: 1px;
    block-size: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
  }

  @media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
      animation-duration: 0.01ms !important;
      transition-duration: 0.01ms !important;
    }

    .revealOnScroll {
      opacity: 1;
      transform: none;
    }
  }
}