/* ============================================
   Zentrum Design System
   Shared utility classes for consistent UI.
   All colors use MudBlazor CSS variables for
   automatic light/dark mode support.
   ============================================ */

/* ── Design Tokens ─────────────────────────── */
:root {
    --zen-hover-shadow: 0 1px 3px var(--mud-palette-overlay-dark), 0 4px 8px 3px var(--mud-palette-overlay-dark);
}

/* ── Interactive Cards ─────────────────────── */
.zen-card {
    transition: box-shadow 0.2s ease, border-color 0.2s ease, transform 0.15s ease;
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: var(--mud-default-borderradius, 8px);
}

.zen-card:hover {
    box-shadow: var(--zen-hover-shadow);
    border-color: var(--mud-palette-primary);
    transform: translateY(-1px);
}

.zen-card-grid {
    display: grid;
    gap: 24px;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, var(--zen-card-grid-min, 12rem)), 1fr));
    align-items: stretch;
}

.zen-card-grid__item {
    min-width: 0;
}

/* ── Page Header ───────────────────────────── */
.zen-page-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px;
}

/* -- Drawers / Blades -------------------------------- */
.zen-drawer,
.zen-drawer.mud-drawer-content,
.zen-drawer .mud-drawer-content {
    height: 100%;
}

.zen-drawer-shell {
    display: flex;
    flex-direction: column;
    height: 100%;
    min-height: 0;
}

.zen-drawer-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px 24px;
    border-bottom: 1px solid var(--mud-palette-lines-default);
    background: var(--mud-palette-surface);
    flex-shrink: 0;
}

.zen-drawer-title-block {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

.zen-drawer-title-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 10px;
    color: var(--mud-palette-primary);
    background: color-mix(in srgb, var(--mud-palette-primary) 10%, transparent);
    flex-shrink: 0;
}

.zen-drawer-title {
    font-weight: 600;
    line-height: 1.2;
}

.zen-drawer-subtitle {
    color: var(--mud-palette-text-secondary);
    margin-top: 2px;
}

.zen-drawer-body {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    padding: 24px;
}

.zen-drawer-footer {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 12px;
    padding: 16px 24px;
    border-top: 1px solid var(--mud-palette-lines-default);
    background: var(--mud-palette-surface);
    flex-shrink: 0;
}

.zen-drawer-form {
    display: flex;
    flex-direction: column;
    min-height: 100%;
}

.zen-drawer-form-body {
    flex: 1 1 auto;
}

.zen-drawer-sticky-actions {
    position: sticky;
    bottom: -24px;
    z-index: 2;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 12px;
    margin: 24px -24px -24px;
    padding: 16px 24px;
    border-top: 1px solid var(--mud-palette-lines-default);
    background: var(--mud-palette-surface);
    flex-shrink: 0;
}

.zen-drawer-sticky-actions .button-h-gap {
    display: flex;
    gap: 12px;
}

@media (max-width: 600px) {
    .zen-drawer-header,
    .zen-drawer-body,
    .zen-drawer-footer {
        padding-left: 16px;
        padding-right: 16px;
    }

    .zen-drawer-footer {
        flex-direction: column-reverse;
        align-items: stretch;
    }

    .zen-drawer-sticky-actions {
        bottom: -16px;
        flex-direction: column-reverse;
        align-items: stretch;
        margin: 24px -16px -24px;
        padding-left: 16px;
        padding-right: 16px;
    }

    .zen-drawer-sticky-actions .button-h-gap {
        flex-direction: column-reverse;
        width: 100%;
    }
}

/* ── Section Title ─────────────────────────── */
.zen-section-title {
    font-weight: 600;
    margin-bottom: 16px;
}

/* ── Empty State ───────────────────────────── */
.zen-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 48px 24px;
    min-height: 300px;
    text-align: center;
}

.zen-empty-state .mud-icon-root {
    font-size: 96px;
    opacity: 0.3;
    margin-bottom: 16px;
}

/* ── Banner (Getting Started etc.) ─────────── */
.zen-banner {
    background: var(--mud-palette-surface);
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: var(--mud-default-borderradius, 8px);
    padding: 24px;
    display: flex;
    gap: 24px;
    align-items: center;
    margin-bottom: 24px;
}

.zen-banner-content {
    flex: 1;
}

.zen-banner-image {
    width: 160px;
    height: 160px;
    flex-shrink: 0;
}

.zen-banner-image img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

@media (max-width: 960px) {
    .zen-banner {
        flex-direction: column;
    }
    .zen-banner-image {
        display: none;
    }
}

/* ── Clean Table Styling ───────────────────── */
.zen-table .mud-table {
    border: none;
}

.zen-table .mud-table-head .mud-table-cell {
    background-color: var(--mud-palette-surface);
    font-weight: 600;
    color: var(--mud-palette-text-secondary);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-bottom: 1px solid var(--mud-palette-lines-default);
}

.zen-table .mud-table-body .mud-table-row:hover {
    background-color: var(--mud-palette-hover) !important;
}

/* ── Skeleton Loading Placeholder ──────────── */
.zen-skeleton-row {
    display: flex;
    gap: 16px;
    margin-bottom: 12px;
}

/* ── Danger Zone ──────────────────────────── */
.zen-danger-zone {
    background-color: color-mix(in srgb, var(--mud-palette-error) 6%, var(--mud-palette-surface));
    border: 1px solid color-mix(in srgb, var(--mud-palette-error) 30%, transparent);
}

/* ── Code / Monospace Text ────────────────── */
.zen-code-text {
    word-break: break-word;
    font-family: monospace;
}

.zen-code-chip {
    word-break: break-word;
    font-family: monospace;
    background-color: var(--mud-palette-background-grey);
    padding: 4px 8px;
    border-radius: 4px;
}

/* ── Code Editor Containers ──────────────── */
.zen-editor-container {
    height: 300px;
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: var(--mud-default-borderradius, 8px);
    overflow: hidden;
}

.zen-editor-container-tall {
    height: 400px;
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: var(--mud-default-borderradius, 8px);
    overflow: hidden;
}

/* ── Upload Zone ─────────────────────────── */
.zen-upload-zone {
    min-height: 200px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: border-color 0.2s ease;
}

.zen-upload-zone:hover {
    border-color: var(--mud-palette-primary) !important;
}

.zen-upload-zone-content {
    padding: 40px;
    text-align: center;
}

.zen-file-input-hidden {
    position: absolute;
    width: 100%;
    height: 100%;
    overflow: hidden;
    z-index: 10;
    opacity: 0;
    cursor: pointer;
}

.zen-upload-icon {
    font-size: 48px;
    color: var(--mud-palette-text-secondary);
    margin-bottom: 8px;
}

/* ── Template Browser ──────────────────────── */
.zen-template-collapse .mud-collapse-container {
    transition: all 0.3s ease-in-out;
}

.zen-card .template-row:hover {
    background-color: var(--mud-palette-hover);
}

/* ── Read-only ZTL Code Blocks ───────────────── */
.zen-ztl-code {
    overflow: hidden;
    border: 1px solid #1f2937;
    border-radius: var(--mud-default-borderradius, 8px);
    background: #0b1020;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.zen-ztl-code__pre {
    display: block;
    margin: 0;
    padding: 12px 0;
    overflow: auto;
    color: #d1d5db;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 0.875rem;
    line-height: 1.65;
    tab-size: 4;
}

.zen-ztl-code__line {
    display: grid;
    grid-template-columns: 3.25rem minmax(0, 1fr);
    min-width: max-content;
}

.zen-ztl-code__line:hover {
    background: rgba(255, 255, 255, 0.04);
}

.zen-ztl-code__line-number {
    padding-right: 0.875rem;
    color: #64748b;
    text-align: right;
    user-select: none;
    border-right: 1px solid rgba(148, 163, 184, 0.2);
}

.zen-ztl-code__line-content {
    padding-left: 1rem;
    padding-right: 1rem;
    white-space: pre;
}

.zen-ztl-code__keyword {
    color: #c084fc;
    font-weight: 600;
}

.zen-ztl-code__type {
    color: #60a5fa;
}

.zen-ztl-code__string {
    color: #86efac;
}

.zen-ztl-code__number {
    color: #fbbf24;
}

.zen-ztl-code__literal {
    color: #f87171;
}

.zen-ztl-code__punctuation {
    color: #94a3b8;
}

.zen-ztl-code__comment {
    color: #64748b;
    font-style: italic;
}

.zen-ztl-code__empty {
    padding: 16px;
    color: #94a3b8;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 0.875rem;
}

/* ── App Bar Center Search Bar ────────────── */
button.zen-appbar-center {
    /* Reset native button styles */
    appearance: none;
    -webkit-appearance: none;
    background: transparent;
    font-family: inherit;
    outline: none;
}

.zen-appbar-center {
    flex: 1 1 0%;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 7px 14px;
    max-width: 680px;
    min-width: 0;
    margin: 0 auto;
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 8px;
    cursor: pointer;
    color: var(--mud-palette-text-secondary);
    font-size: 0.875rem;
    transition: border-color 0.15s ease, background-color 0.15s ease;
    user-select: none;
    white-space: nowrap;
    overflow: hidden;
}

.zen-appbar-center:hover {
    border-color: var(--mud-palette-text-secondary);
    background-color: rgba(0, 0, 0, 0.04);
}

.zen-appbar-center:focus-visible {
    outline: 2px solid var(--mud-palette-primary);
    outline-offset: 2px;
}

.zen-appbar-center-icon {
    color: var(--mud-palette-text-secondary);
    flex-shrink: 0;
}

.zen-appbar-center-text {
    flex: 1;
    opacity: 0.6;
    overflow: hidden;
    text-overflow: ellipsis;
}

.zen-appbar-center-kbd {
    font-family: inherit;
    font-size: 0.6875rem;
    padding: 1px 6px;
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 4px;
    background: rgba(0, 0, 0, 0.04);
    color: var(--mud-palette-text-secondary);
    flex-shrink: 0;
}

/* Responsive: hide compact app chrome on very small screens */
@media (max-width: 400px) {
    .zen-hide-xxs {
        display: none !important;
    }
}

/* Responsive: hide kbd badge on small screens */
@media (max-width: 600px) {
    .zen-hide-xs {
        display: none !important;
    }
}

/* Avatar notification badge */
.zen-avatar-badge .mud-badge {
    font-size: 0.6rem;
    min-width: 16px;
    height: 16px;
}

/* ── Command Bar Overlay ─────────────────── */
.zen-command-bar-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    justify-content: center;
    padding-top: 15vh;
    background: rgba(0, 0, 0, 0.4);
    animation: zen-command-bar-fadein 0.12s ease-out;
}

@keyframes zen-command-bar-fadein {
    from { opacity: 0; }
    to { opacity: 1; }
}

.zen-command-bar-card {
    width: 680px;
    max-width: calc(100vw - 32px);
    max-height: 60vh;
    display: flex;
    flex-direction: column;
    background: var(--mud-palette-surface);
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 12px;
    box-shadow: 0 16px 48px rgba(0, 0, 0, 0.2);
    overflow: hidden;
    align-self: flex-start;
}

@media (max-width: 600px) {
    .zen-command-bar-card {
        width: 100%;
        max-width: calc(100vw - 16px);
        border-radius: 8px;
    }

    .zen-command-bar-overlay {
        padding-top: 8vh;
    }
}

.zen-command-bar-input-row {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 16px;
    border-bottom: 1px solid var(--mud-palette-lines-default);
}

.zen-command-bar-search-icon {
    color: var(--mud-palette-text-secondary);
    flex-shrink: 0;
}

.zen-command-bar-input {
    flex: 1;
    border: none;
    outline: none;
    background: transparent;
    font-size: 1rem;
    color: var(--mud-palette-text-primary);
    font-family: inherit;
}

.zen-command-bar-input::placeholder {
    color: var(--mud-palette-text-secondary);
    opacity: 0.6;
}

.zen-command-bar-spinner {
    flex-shrink: 0;
}

.zen-command-bar-results {
    overflow-y: auto;
    padding: 6px 0;
}

.zen-command-bar-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 16px;
    cursor: pointer;
    transition: background-color 0.1s ease;
}

.zen-command-bar-item:hover,
.zen-command-bar-item--selected {
    background-color: var(--mud-palette-hover);
}

.zen-command-bar-item-icon {
    color: var(--mud-palette-text-secondary);
    flex-shrink: 0;
}

.zen-command-bar-item-avatar {
    flex-shrink: 0;
}

.zen-command-bar-item-text {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
}

.zen-command-bar-item-label {
    font-size: 0.875rem;
    color: var(--mud-palette-text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.zen-command-bar-item-desc {
    font-size: 0.75rem;
    color: var(--mud-palette-text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.zen-command-bar-item-shortcut {
    font-size: 0.6875rem;
    padding: 1px 6px;
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 4px;
    color: var(--mud-palette-text-secondary);
    white-space: nowrap;
    flex-shrink: 0;
}

.zen-command-bar-item-category {
    flex-shrink: 0;
    font-size: 0.6875rem !important;
}

.zen-command-bar-empty {
    padding: 24px 16px;
    text-align: center;
}

.zen-command-bar-hint {
    cursor: pointer;
    font-weight: 600;
    color: var(--mud-palette-primary);
    padding: 0 2px;
    border-radius: 3px;
}

.zen-command-bar-hint:hover {
    text-decoration: underline;
}

.zen-command-bar-section-header {
    padding: 8px 16px 4px;
}

.zen-command-bar-footer {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    border-top: 1px solid var(--mud-palette-lines-default);
    cursor: pointer;
    color: var(--mud-palette-text-secondary);
    transition: background-color 0.1s ease;
}

.zen-command-bar-footer:hover {
    background-color: var(--mud-palette-hover);
    color: var(--mud-palette-primary);
}

/* ── Homepage Hero ─────────────────────────── */
.zen-home-hero {
    --zen-home-hero-accent: var(--mud-palette-primary);
    --zen-home-hero-accent-soft: var(--mud-palette-secondary);
    position: relative;
    overflow: hidden;
    padding: 32px;
    min-height: 320px;
    border: 1px solid color-mix(in srgb, var(--zen-home-hero-accent) 8%, var(--mud-palette-lines-default));
    border-radius: 24px;
    background:
        linear-gradient(135deg,
            color-mix(in srgb, var(--zen-home-hero-accent) 16%, var(--mud-palette-surface)) 0%,
            color-mix(in srgb, var(--zen-home-hero-accent-soft) 8%, var(--mud-palette-surface)) 48%,
            var(--mud-palette-surface) 100%);
}

.zen-home-hero--morning {
    --zen-home-hero-accent: #f59e0b;
    --zen-home-hero-accent-soft: #facc15;
}

.zen-home-hero--day {
    --zen-home-hero-accent: #2563eb;
    --zen-home-hero-accent-soft: #22d3ee;
}

.zen-home-hero--evening {
    --zen-home-hero-accent: #7c3aed;
    --zen-home-hero-accent-soft: #fb7185;
}

.zen-home-hero--night {
    --zen-home-hero-accent: #4f46e5;
    --zen-home-hero-accent-soft: #06b6d4;
}

.zen-home-hero__halo,
.zen-home-hero__mesh {
    position: absolute;
    pointer-events: none;
}

.zen-home-hero__halo {
    width: 420px;
    height: 420px;
    right: -120px;
    top: -140px;
    border-radius: 50%;
    background: radial-gradient(circle, color-mix(in srgb, var(--zen-home-hero-accent) 40%, transparent) 0%, transparent 72%);
    filter: blur(6px);
    opacity: 0.8;
}

.zen-home-hero__mesh {
    inset: 0;
    opacity: 0.35;
    background-image:
        linear-gradient(color-mix(in srgb, var(--zen-home-hero-accent) 11%, transparent) 1px, transparent 1px),
        linear-gradient(90deg, color-mix(in srgb, var(--zen-home-hero-accent-soft) 10%, transparent) 1px, transparent 1px);
    background-size: 34px 34px;
    mask-image: linear-gradient(120deg, rgba(0, 0, 0, 0.18), rgba(0, 0, 0, 0.6) 45%, rgba(0, 0, 0, 0.95));
}

.zen-home-hero__content {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1.5fr) minmax(320px, 0.95fr);
    gap: 32px;
    align-items: center;
}

.zen-home-hero__copy {
    max-width: 640px;
}

.zen-home-hero__eyebrow {
    display: inline-flex;
    padding: 6px 12px;
    border-radius: 999px;
    letter-spacing: 0.08em;
    color: color-mix(in srgb, var(--zen-home-hero-accent) 72%, var(--mud-palette-text-primary));
    background: color-mix(in srgb, var(--zen-home-hero-accent) 12%, transparent);
    margin-bottom: 16px;
}

.zen-home-hero__title {
    margin-bottom: 12px;
    max-width: 12ch;
    font-size: clamp(2rem, 4vw, 3.1rem) !important;
    line-height: 1.05;
}

.zen-home-hero__subtitle {
    max-width: 56ch;
    font-size: 1rem;
    line-height: 1.7;
    color: var(--mud-palette-text-secondary);
}

.zen-home-hero__stats {
    margin-top: 24px;
}

.zen-home-hero__stat-chip {
    background: color-mix(in srgb, var(--mud-palette-surface) 84%, transparent);
    border-color: color-mix(in srgb, var(--zen-home-hero-accent) 16%, var(--mud-palette-lines-default));
}

.zen-home-hero__stat-value {
    font-weight: 700;
    margin-right: 6px;
}

.zen-home-hero__stat-label {
    color: var(--mud-palette-text-secondary);
}

.zen-home-hero__aside {
    min-width: 0;
}

.zen-home-hero__graphic {
    position: relative;
    min-height: 256px;
    padding: 20px;
    border-radius: 28px;
    background:
        linear-gradient(180deg,
            color-mix(in srgb, var(--mud-palette-surface) 82%, transparent),
            color-mix(in srgb, var(--mud-palette-surface) 92%, var(--mud-palette-background)));
    border: 1px solid color-mix(in srgb, var(--zen-home-hero-accent) 14%, var(--mud-palette-lines-default));
    box-shadow: 0 18px 48px color-mix(in srgb, var(--zen-home-hero-accent) 12%, transparent);
    backdrop-filter: blur(18px);
}

.zen-home-hero__shape {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    opacity: 0.9;
    animation: zen-home-float 16s ease-in-out infinite;
}

.zen-home-hero__shape--one {
    width: 164px;
    height: 164px;
    right: 18px;
    top: 18px;
    background: radial-gradient(circle at 30% 30%, color-mix(in srgb, var(--zen-home-hero-accent) 28%, #fff), transparent 72%);
}

.zen-home-hero__shape--two {
    width: 128px;
    height: 128px;
    left: 24px;
    bottom: 20px;
    background: radial-gradient(circle at 40% 35%, color-mix(in srgb, var(--zen-home-hero-accent-soft) 30%, #fff), transparent 70%);
    animation-delay: -5s;
}

.zen-home-hero__shape--three {
    width: 72px;
    height: 72px;
    left: 40%;
    top: 28px;
    background: radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--mud-palette-primary) 28%, #fff), transparent 74%);
    animation-delay: -9s;
}

.zen-home-hero__signal {
    position: absolute;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--mud-palette-surface) 90%, transparent);
    border: 1px solid color-mix(in srgb, var(--zen-home-hero-accent) 14%, var(--mud-palette-lines-default));
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--mud-palette-text-secondary);
    box-shadow: 0 10px 24px color-mix(in srgb, var(--zen-home-hero-accent) 8%, transparent);
}

.zen-home-hero__signal--top {
    top: 18px;
    left: 18px;
}

.zen-home-hero__signal--bottom {
    right: 18px;
    bottom: 18px;
}

.zen-home-hero__actions {
    position: relative;
    z-index: 1;
    max-width: 360px;
    margin-left: auto;
    margin-top: 56px;
}

/* ── Quick Actions ─────────────────────────── */
.quick-actions-root {
    width: 100%;
}

.quick-actions-title {
    margin-bottom: 12px;
    color: var(--mud-palette-text-secondary);
    letter-spacing: 0.08em;
}

.quick-action-skeleton {
    border-radius: 16px;
}

.quick-action-button {
    border-radius: 16px !important;
    min-height: 76px !important;
    padding: 14px 16px !important;
    justify-content: flex-start !important;
    text-transform: none !important;
    border-width: 1px !important;
}

.quick-action-button .mud-button-label {
    width: 100%;
}

.quick-action-button__content {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 14px;
    text-align: left;
}

.quick-action-button__icon {
    width: 42px;
    height: 42px;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 14px;
    background: color-mix(in srgb, currentColor 14%, transparent);
}

.quick-action-button__copy {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.quick-action-button__label,
.quick-action-button__subtitle {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.quick-action-button__label {
    font-weight: 600;
    font-size: 0.92rem;
}

.quick-action-button__subtitle {
    font-size: 0.76rem;
    opacity: 0.82;
}

.quick-action-button.mud-button-outlined {
    background: color-mix(in srgb, var(--mud-palette-surface) 88%, transparent);
    border-color: color-mix(in srgb, currentColor 20%, var(--mud-palette-lines-default)) !important;
}

.quick-action-button.mud-button-filled {
    box-shadow: 0 14px 32px color-mix(in srgb, currentColor 18%, transparent);
}

/* ── Homepage Highlights ───────────────────── */
@keyframes zen-home-float {
    0%, 100% {
        transform: translate3d(0, 0, 0);
    }

    50% {
        transform: translate3d(0, -10px, 0);
    }
}

@media (max-width: 960px) {
    .zen-home-hero {
        padding: 24px;
    }

    .zen-home-hero__content {
        grid-template-columns: 1fr;
    }

    .zen-home-hero__title {
        max-width: none;
    }

    .zen-home-hero__actions {
        max-width: none;
        margin-top: 96px;
    }
}

@media (max-width: 600px) {
    .zen-home-hero {
        min-height: 0;
        border-radius: 20px;
        padding: 20px;
    }

    .zen-home-hero__graphic {
        min-height: 0;
        padding: 16px;
    }

    .zen-home-hero__signal--bottom {
        position: static;
        margin-bottom: 16px;
    }

    .zen-home-hero__signal--top {
        position: static;
        margin-bottom: 12px;
    }

    .zen-home-hero__actions {
        margin-top: 20px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .zen-home-hero,
    .zen-home-hero__shape,
    .quick-action-button {
        animation: none !important;
        transition: none !important;
    }
}
