.constructor-shell {
    padding-bottom: clamp(22px, 3vw, 44px);
}

.constructor-main {
    display: grid;
    gap: clamp(12px, 1.5vw, 20px);
    padding-top: clamp(10px, 1vw, 16px);
}

.constructor-main section[id] {
    scroll-margin-top: calc(var(--header-height) + 8px);
}

.reveal-card {
    opacity: 0;
    transform: translateY(36px) scale(0.988);
    transition: transform 0.7s cubic-bezier(0.2, 1, 0.2, 1), opacity 0.7s ease;
}

.reveal-card.is-visible {
    opacity: 1;
    transform: translateY(0) scale(1);
}

.glass-card,
.workspace-card {
    position: relative;
    border: 1px solid var(--border);
    border-radius: var(--radius-xl);
    background: color-mix(in srgb, var(--card-bg) 100%, transparent);
    box-shadow: var(--shadow);
    overflow: hidden;
}

.glass-card::before,
.workspace-card::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.2), transparent 38%);
}

.glass-card > *,
.workspace-card > * {
    position: relative;
    z-index: 1;
}

.constructor-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
    gap: clamp(16px, 2vw, 24px);
    min-height: clamp(360px, 56svh, 600px);
    padding: clamp(20px, 2.2vw, 34px);
}

.hero-copy {
    max-width: 720px;
}

.hero-copy h1 {
    margin: 0;
    font-family: var(--font-display);
    font-size: clamp(2.2rem, 4.8vw, 5rem);
    line-height: 0.9;
    letter-spacing: -0.03em;
    max-width: 11ch;
}

.hero-lead {
    margin: 16px 0 0;
    color: var(--text-soft);
    line-height: 1.7;
    max-width: 64ch;
}

.hero-ribbon {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 18px;
}

.hero-ribbon span {
    padding: 8px 12px;
    border: 1px solid var(--border);
    border-radius: 999px;
    font-size: 0.83rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    color: var(--text-soft);
    background: color-mix(in srgb, var(--card-strong) 86%, transparent);
}

.hero-metrics {
    display: grid;
    gap: 10px;
    align-content: start;
}

.metric-tile {
    display: grid;
    gap: 6px;
    padding: 14px;
    border-radius: var(--radius-md);
    border: 1px solid var(--border);
    background: color-mix(in srgb, var(--card-strong) 90%, transparent);
}

.metric-tile span {
    color: var(--text-soft);
    font-size: 0.8rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.metric-tile strong {
    font-family: var(--font-display);
    font-size: clamp(1.25rem, 2.2vw, 1.9rem);
    line-height: 1;
}

.metric-tile.accent {
    border-color: color-mix(in srgb, var(--teal) 48%, var(--border));
    background: linear-gradient(145deg, color-mix(in srgb, var(--teal) 14%, var(--card-strong)), color-mix(in srgb, var(--navy) 8%, var(--card-strong)));
}

.builder-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(0, 1fr) minmax(0, 0.9fr);
    gap: clamp(10px, 1.2vw, 16px);
}

.workspace-card {
    display: grid;
    gap: 14px;
    align-content: start;
    padding: clamp(16px, 1.8vw, 26px);
}

.card-head h2,
.section-head h2 {
    margin: 0;
    font-family: var(--font-display);
    font-size: clamp(1.45rem, 2.4vw, 2.5rem);
    line-height: 0.98;
}

.card-lead {
    margin: 0;
    color: var(--text-soft);
}

.inline-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: 10px;
}

.canvas-toolbar {
    display: inline-flex;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.ghost-button.tiny,
.selected-actions button {
    min-height: 36px;
    padding: 8px 12px;
    border-radius: 12px;
    font-size: 0.82rem;
    font-weight: 700;
}

.module-list {
    display: grid;
    gap: 10px;
    max-height: clamp(420px, 64svh, 780px);
    overflow: auto;
    padding-right: 4px;
}

.module-list::-webkit-scrollbar,
.selected-list::-webkit-scrollbar {
    width: 8px;
}

.module-list::-webkit-scrollbar-thumb,
.selected-list::-webkit-scrollbar-thumb {
    background: color-mix(in srgb, var(--text-soft) 34%, transparent);
    border-radius: 999px;
}

.module-card,
.selected-item {
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    background: color-mix(in srgb, var(--card-strong) 92%, transparent);
    padding: 12px;
}

.module-card {
    display: grid;
    gap: 10px;
}

.module-head,
.selected-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 8px;
}

.module-head strong,
.selected-top strong {
    font-family: var(--font-display);
    font-size: 1.05rem;
    line-height: 1.05;
}

.module-group {
    display: inline-flex;
    align-items: center;
    padding: 4px 9px;
    border-radius: 999px;
    border: 1px solid var(--border);
    color: var(--text-soft);
    font-size: 0.74rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.module-note,
.selected-note,
.selected-meta,
.module-dependency {
    margin: 0;
    color: var(--text-soft);
    line-height: 1.55;
    font-size: 0.88rem;
}

.module-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.module-meta span,
.selected-meta span {
    padding: 4px 8px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--navy) 10%, transparent);
    border: 1px solid var(--border);
    font-size: 0.77rem;
    font-weight: 600;
}

.module-card button,
.selected-actions button {
    width: 100%;
    border: 1px solid var(--border);
    background: color-mix(in srgb, var(--card-strong) 88%, transparent);
    color: var(--text);
    cursor: pointer;
    transition: transform 0.2s ease, background 0.2s ease;
}

.module-card button:hover,
.selected-actions button:hover {
    transform: translateY(-1px);
    background: color-mix(in srgb, var(--teal) 16%, var(--card-strong));
}

.module-card button:disabled {
    cursor: not-allowed;
    opacity: 0.62;
    transform: none;
}

.selected-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 9px;
    max-height: clamp(360px, 58svh, 720px);
    overflow: auto;
    padding-right: 4px;
}

.selected-item {
    border-left: 5px solid var(--teal);
    display: grid;
    gap: 8px;
}

.selected-item[data-group="Коммуникации"] {
    border-left-color: var(--teal);
}

.selected-item[data-group="Операции"] {
    border-left-color: var(--gold);
}

.selected-item[data-group="Управление"] {
    border-left-color: var(--navy);
}

.selected-item[data-group="Клиентский путь"] {
    border-left-color: var(--coral);
}

.selected-actions {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
}

.canvas-hint,
.status-message {
    margin: 0;
    color: var(--text-soft);
    line-height: 1.55;
}

.status-message {
    min-height: 24px;
    padding: 8px 10px;
    border-radius: 10px;
    border: 1px dashed transparent;
}

.status-message.is-positive {
    border-color: color-mix(in srgb, var(--teal) 54%, var(--border));
    background: color-mix(in srgb, var(--teal) 10%, transparent);
    color: color-mix(in srgb, var(--teal) 72%, var(--text));
}

.status-message.is-warning {
    border-color: color-mix(in srgb, var(--coral) 55%, var(--border));
    background: color-mix(in srgb, var(--coral) 11%, transparent);
    color: color-mix(in srgb, var(--coral) 72%, var(--text));
}

.summary-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 9px;
}

.summary-tile {
    display: grid;
    gap: 5px;
    padding: 11px;
    border-radius: 14px;
    border: 1px solid var(--border);
    background: color-mix(in srgb, var(--card-strong) 92%, transparent);
}

.summary-tile span {
    color: var(--text-soft);
    font-size: 0.76rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.summary-tile strong {
    font-family: var(--font-display);
    font-size: 1.06rem;
    line-height: 1.1;
}

.summary-tile.accent {
    border-color: color-mix(in srgb, var(--gold) 54%, var(--border));
    background: color-mix(in srgb, var(--gold) 11%, var(--card-strong));
}

.module-summary h3 {
    margin: 4px 0 0;
    font-family: var(--font-display);
    font-size: 1.1rem;
}

.config-output {
    margin: 0;
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 12px;
    background: color-mix(in srgb, var(--page-bg) 74%, transparent);
    color: var(--text);
    line-height: 1.5;
    font-size: 0.88rem;
    max-height: 260px;
    overflow: auto;
    white-space: pre-wrap;
    font-family: "Cascadia Code", "Consolas", monospace;
}

.vertical-actions {
    display: grid;
    gap: 8px;
}

.webshell-card {
    display: grid;
    gap: 14px;
    padding: clamp(18px, 2vw, 30px);
}

.webshell-lead {
    max-width: 78ch;
}

.webshell-buildbar {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    padding: 12px;
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    background:
        radial-gradient(circle at top left, color-mix(in srgb, var(--teal) 12%, transparent), transparent 44%),
        color-mix(in srgb, var(--card-strong) 92%, transparent);
}

.webshell-buildbar__copy {
    display: grid;
    gap: 6px;
}

.webshell-buildbar__copy strong {
    font-family: var(--font-display);
    font-size: 1.06rem;
    line-height: 1.08;
}

.webshell-buildbar__copy p {
    margin: 0;
    color: var(--text-soft);
    line-height: 1.5;
}

.webshell-buildbar__actions {
    display: inline-flex;
    align-items: flex-start;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.live-webshell-modules {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
}

.live-webshell-modules li {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 7px 11px;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: color-mix(in srgb, var(--card-strong) 94%, transparent);
    color: var(--text-soft);
    font-size: 0.82rem;
    line-height: 1;
}

.live-webshell-modules li strong {
    color: var(--text);
    font-size: 0.83rem;
    font-family: var(--font-display);
    line-height: 1;
}

.live-webshell-modules li.empty {
    border-style: dashed;
}

.live-webshell-status {
    margin: 0;
    min-height: 24px;
    padding: 8px 10px;
    border-radius: 10px;
    border: 1px dashed var(--border);
    color: var(--text-soft);
    background: color-mix(in srgb, var(--card-strong) 92%, transparent);
    line-height: 1.45;
}

.live-webshell-status.is-positive {
    border-color: color-mix(in srgb, var(--teal) 54%, var(--border));
    background: color-mix(in srgb, var(--teal) 11%, transparent);
    color: color-mix(in srgb, var(--teal) 74%, var(--text));
}

.live-webshell-status.is-warning {
    border-color: color-mix(in srgb, var(--coral) 56%, var(--border));
    background: color-mix(in srgb, var(--coral) 10%, transparent);
    color: color-mix(in srgb, var(--coral) 74%, var(--text));
}

.live-webshell-frame-wrap {
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 10px;
    background:
        radial-gradient(circle at top left, color-mix(in srgb, var(--navy) 11%, transparent), transparent 54%),
        color-mix(in srgb, var(--card-strong) 94%, transparent);
}

.live-webshell-frame {
    display: block;
    width: 100%;
    min-height: clamp(560px, 72svh, 920px);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    background: #0b0b0f;
}

.presets-card,
.roles-card {
    padding: clamp(18px, 2vw, 30px);
}

.section-head {
    display: grid;
    gap: 6px;
    margin-bottom: 14px;
}

.preset-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.preset-card {
    appearance: none;
    width: 100%;
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 14px;
    text-align: left;
    display: grid;
    gap: 7px;
    background: color-mix(in srgb, var(--card-strong) 90%, transparent);
    color: var(--text);
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.preset-card span {
    color: var(--text-soft);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 0.76rem;
}

.preset-card strong {
    font-family: var(--font-display);
    font-size: 1.12rem;
    line-height: 1.1;
}

.preset-card small {
    color: var(--text-soft);
    line-height: 1.5;
}

.preset-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 16px 30px rgba(10, 28, 40, 0.15);
    border-color: color-mix(in srgb, var(--teal) 45%, var(--border));
}

.role-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 12px;
}

.role-tab {
    appearance: none;
    border: 1px solid var(--border);
    border-radius: 999px;
    min-height: 40px;
    padding: 8px 14px;
    font-size: 0.9rem;
    font-weight: 700;
    background: color-mix(in srgb, var(--card-strong) 85%, transparent);
    color: var(--text-soft);
    cursor: pointer;
    transition: transform 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.role-tab:hover,
.role-tab.is-active {
    color: var(--text);
    border-color: color-mix(in srgb, var(--teal) 42%, var(--border));
    transform: translateY(-1px);
}

.role-panel {
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 14px;
    background: color-mix(in srgb, var(--card-strong) 90%, transparent);
}

.role-panel h3 {
    margin: 0;
    font-family: var(--font-display);
    font-size: 1.2rem;
}

.role-feature-list {
    margin: 10px 0 0;
    padding-left: 20px;
    display: grid;
    gap: 6px;
    color: var(--text-soft);
}

@media (max-width: 1280px) {
    .builder-layout {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    }

    .module-summary {
        grid-column: 1 / -1;
    }

    .config-output {
        max-height: 210px;
    }
}

@media (max-width: 940px) {
    .constructor-hero {
        grid-template-columns: 1fr;
    }

    .hero-copy h1 {
        max-width: 14ch;
    }

    .builder-layout,
    .preset-grid,
    .summary-grid {
        grid-template-columns: 1fr;
    }

    .webshell-buildbar {
        grid-template-columns: 1fr;
    }

    .webshell-buildbar__actions {
        justify-content: flex-start;
    }

    .inline-head {
        grid-template-columns: 1fr;
    }

    .canvas-toolbar {
        justify-content: flex-start;
    }
}

@media (max-width: 680px) {
    .workspace-card,
    .presets-card,
    .roles-card,
    .webshell-card,
    .constructor-hero {
        padding: 14px;
        border-radius: var(--radius-lg);
    }

    .hero-copy h1 {
        font-size: clamp(1.8rem, 10vw, 2.8rem);
    }

    .module-head,
    .selected-top {
        flex-direction: column;
        align-items: flex-start;
    }

    .selected-actions {
        grid-template-columns: 1fr;
    }

    .role-tab {
        width: 100%;
        justify-content: center;
    }

    .live-webshell-modules {
        flex-direction: column;
        align-items: stretch;
    }

    .live-webshell-modules li {
        justify-content: space-between;
    }

    .live-webshell-frame {
        min-height: clamp(500px, 74svh, 780px);
    }
}
