
:root {
    --color-foundation: #f9f6f1;
    --color-calm: #ad8b73;
    --color-accent: #b2babb;
    --color-ink: #2f2a26;
    --color-overlay: rgba(24, 22, 20, 0.45);
    --glass-panel: rgba(255, 255, 255, 0.42);
    --font-serif: 'Cormorant Garamond', serif;
    --font-sans: 'Inter', sans-serif;
    --space-xs: 0.5rem;
    --space-sm: 0.75rem;
    --space-md: 1rem;
    --space-lg: 1.75rem;
    --space-xl: 2.5rem;
    --radius-lg: 2rem;
    --radius-pill: 999rem;
    --shadow-soft: 0 1rem 2.5rem rgba(46, 40, 34, 0.15);
    --trans-fast: 0.3s ease;
}

* {
    box-sizing: border-box
}

html {
    font-size: 100%;
    overflow-x: hidden;
    scroll-behavior: smooth
}

body {
    margin: 0;
    font-family: var(--font-sans);
    color: var(--color-ink);
    background: radial-gradient(circle at 10% 10%, #fff 0%, var(--color-foundation) 50%, #efe9e2 100%);
    line-height: 1.5;
  overflow-x: hidden;
}

img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover
}

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

.site-shell {
    width: min(92%, 86rem);
    margin: 0 auto;
    padding: var(--space-md) 0 var(--space-xl)
}

.shell-header {
    display: grid;
    grid-template-columns:auto 1fr auto;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-sm) var(--space-md);
    border: 0.0625rem solid rgba(173, 139, 115, 0.35);
    border-radius: var(--radius-pill);
    background: var(--glass-panel);
    backdrop-filter: blur(0.9rem);
    position: relative;
    z-index: 20
}

.brand-line {
    font-family: var(--font-serif);
    font-size: 1.4rem;
    letter-spacing: 0.06rem
}

.main-nav {
    display: flex;
    justify-content: center;
    flex-wrap: wrap
}

.main-nav a, .mobile-drawer a, .footer-nav a {
    padding: 0.45rem 0.85rem;
    border-radius: var(--radius-pill);
    transition: background var(--trans-fast), color var(--trans-fast)
}

.main-nav a:hover, .mobile-drawer a:hover, .footer-nav a:hover {
    background: rgba(173, 139, 115, 0.16)
}

.menu-toggle {
    display: none;
    width: 2.8rem;
    height: 2.8rem;
    border: 0;
    border-radius: 50%;
    background: rgba(173, 139, 115, 0.2);
    cursor: pointer;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 0.25rem
}

.menu-toggle span {
    width: 1.1rem;
    height: 0.12rem;
    background: var(--color-ink)
}

.mobile-drawer {
    display: grid;
    grid-template-columns:1fr;
    gap: 0.3rem;
    max-height: 0;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.92);
    border-radius: 1.5rem;
    margin-top: 0.6rem;
    transition: max-height var(--trans-fast), padding var(--trans-fast)
}

.mobile-drawer.is-open {
    max-height: 30rem;
    padding: 0.6rem
}

.hero-banner {
    position: relative;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    min-height: 24rem;
    overflow: hidden;
    margin-top: var(--space-md)
}

.hero-banner > img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%
}

.hero-overlay {
    position: relative;
    z-index: 1;
    min-height: 24rem;
    display: grid;
    align-content: center;
    gap: var(--space-sm);
    padding: clamp(2rem, 8vw, 6rem) clamp(1rem, 6vw, 5rem);
    background: linear-gradient(130deg, var(--color-overlay), rgba(33, 30, 27, 0.2));
    color: #fff;
    max-width: 50rem
}

.hero-overlay h1, .hero-overlay h2 {
    font-family: var(--font-serif);
    font-weight: 500;
    margin: 0;
    font-size: clamp(2rem, 4vw, 3.7rem);
    letter-spacing: 0.05rem
}

.hero-overlay p {
    margin: 0;
    max-width: 40rem
}

.kicker-line {
    letter-spacing: 0.18rem;
    text-transform: uppercase;
    font-size: 0.82rem
}

.primary-link, .secondary-link {
    width: fit-content;
    border-radius: var(--radius-pill);
    padding: 0.65rem 1.1rem;
    font-weight: 500;
    border: 0.0625rem solid transparent;
    transition: transform var(--trans-fast), background var(--trans-fast)
}

.primary-link {
    background: #f4ede4;
    color: #2d2723
}

.secondary-link {
    background: rgba(255, 255, 255, 0.18);
    border-color: rgba(255, 255, 255, 0.4);
    color: black;
}

.primary-link:hover, .secondary-link:hover {
    transform: translateY(-0.1rem)
}

.section-wrap {
    margin: var(--space-xl) 0;
    display: grid;
    gap: var(--space-md)
}

.intro-cluster, .narrative-columns {
    grid-template-columns:repeat(auto-fit, minmax(16rem, 1fr))
}

.intro-cluster article, .narrative-columns article, .value-grid article, .supporting-cards article, .legal-grid article, .product-grid article, .timeline-river article, .modality-grid article, .map-block, .contact-grid article, .contact-form-shell, .action-strip, .metrics-ribbon div, .journal-layout article, .visual-card-a, .visual-card-b, .visual-card-c {
    background: rgba(255, 255, 255, 0.76);
    border: 0.0625rem solid rgba(178, 186, 187, 0.38);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    box-shadow: var(--shadow-soft)
}

.image-panel-grid, .value-grid, .supporting-cards, .metrics-ribbon, .legal-grid, .product-grid, .modality-grid, .journal-layout {
    grid-template-columns:repeat(auto-fit, minmax(14rem, 1fr))
}

.image-panel-grid img, .modality-grid img {
    border-radius: 1.3rem;
    margin-bottom: var(--space-sm);
    aspect-ratio: 4/3
}

.timeline-river article {
    position: relative;
    overflow: hidden
}

.timeline-river span {
    font-size: 2rem;
    font-family: var(--font-serif);
    color: rgba(173, 139, 115, 0.82)
}

.metrics-ribbon div h3, .action-strip h2, .value-grid h3, .supporting-cards h3, .product-grid h2, .modality-grid h2, .legal-grid h2, .map-block h2 {
    margin-top: 0;
    font-family: var(--font-serif)
}

.price-tag {
    font-weight: 600;
    letter-spacing: 0.06rem
}

.contact-grid {
    grid-template-columns:repeat(auto-fit, minmax(18rem, 1fr));
    align-items: start
}

.contact-form-shell {
    display: grid;
    gap: 0.55rem
}

.contact-form-shell input, .contact-form-shell textarea {
    border: 0.0625rem solid rgba(173, 139, 115, 0.42);
    border-radius: 1rem;
    padding: 0.7rem 0.8rem;
    font: inherit;
    background: rgba(255, 255, 255, 0.94)
}

.contact-form-shell button {
    border: 0;
    cursor: pointer
}

.consent-check {
    display: grid;
    grid-template-columns:auto 1fr;
    gap: 0.5rem;
    align-items: start;
    font-size: 0.95rem
}

.map-block iframe {
    width: 100%;
    border: 0;
    border-radius: 1.2rem;
    min-height: 20rem
}

.action-strip {
    text-align: center;
    justify-items: center
}

.site-footer {
    margin-top: var(--space-xl);
    background: rgba(28, 26, 24, 0.95);
    color: #f8f3ed;
    border-radius: 2rem;
    padding: var(--space-lg);
    display: grid;
    gap: var(--space-sm)
}

.footer-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem
}

.footer-grid-wrap p, .legal-note, .year-line {
    margin: 0
}

.consent-banner {
    position: fixed;
    left: 1rem;
    right: 1rem;
    bottom: 1rem;
    background: rgba(255, 255, 255, 0.95);
    border: 0.0625rem solid rgba(173, 139, 115, 0.48);
    border-radius: 1.2rem;
    padding: 0.9rem;
    z-index: 45;
    box-shadow: var(--shadow-soft);
    display: grid;
    gap: 0.5rem
}

.consent-actions {
    display: flex;
    gap: 0.5rem
}

.consent-actions button {
    border: 0;
    border-radius: 99rem;
    padding: 0.45rem 0.85rem;
    cursor: pointer;
    background: rgba(173, 139, 115, 0.2)
}

.pulse-trigger {
    position: fixed;
    right: 1rem;
    bottom: 5.2rem;
    width: 2.7rem;
    height: 2.7rem;
    border-radius: 50%;
    border: 0;
    background: #6d8f86;
    color: #fff;
    box-shadow: var(--shadow-soft);
    cursor: pointer;
    z-index: 42
}

.breath-guide {
    position: fixed;
    right: 1rem;
    bottom: 8.5rem;
    width: min(85%, 17rem);
    background: rgba(255, 255, 255, 0.97);
    border-radius: 1rem;
    border: 0.0625rem solid rgba(178, 186, 187, 0.48);
    padding: 0.8rem;
    z-index: 42;
    opacity: 0;
    pointer-events: none;
    transform: translateY(0.6rem);
    transition: opacity var(--trans-fast), transform var(--trans-fast)
}

.breath-guide.is-open {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto
}

@media (max-width: 63.9375rem) {
    .main-nav {
        display: none
    }

    .menu-toggle {
        display: inline-flex
    }
}

@media (min-width: 64rem) {
    .mobile-drawer {
        display: none
    }
}

@media (max-width: 40rem) {
    .site-shell {
        width: 94%
    }

    .shell-header {
        grid-template-columns:1fr auto
    }

    .brand-line {
        font-size: 1.1rem
    }

    .hero-overlay {
        min-height: 20rem
    }

    .pulse-trigger {
        bottom: 6.6rem
    }
}

.legal-hero-text {
    margin-top: var(--space-xl)
}

.legal-hero-panel {
    background: linear-gradient(135deg, rgba(173, 139, 115, 0.24), rgba(178, 186, 187, 0.2));
    border: 0.0625rem solid rgba(178, 186, 187, 0.44);
    border-radius: var(--radius-lg);
    padding: var(--space-xl);
    box-shadow: var(--shadow-soft)
}

.legal-hero-panel h1 {
    margin-top: 0;
    font-family: var(--font-serif);
    font-size: clamp(2rem, 4vw, 3rem)
}
