:root {
    --home-bg: var(--octap-bg, #0b0e13);
    --home-surface: var(--octap-surface, rgba(18, 22, 28, 0.94));
    --home-surface-soft: var(--octap-surface-soft, rgba(255, 255, 255, 0.035));
    --home-surface-hover: var(--octap-surface-hover, rgba(255, 255, 255, 0.06));
    --home-card: var(--octap-card, rgba(22, 26, 33, 0.92));
    --home-card-hover: var(--octap-card-hover, rgba(25, 30, 38, 0.96));
    --home-thumb: var(--octap-thumb, #20252c);
    --home-line: var(--octap-line, rgba(255, 255, 255, 0.06));
    --home-line-strong: var(--octap-line-strong, rgba(255, 255, 255, 0.11));
    --home-text: var(--octap-text, #f5f6fe);
    --home-muted: var(--octap-muted, #a9abb2);
    --home-faint: var(--octap-faint, #6b6e76);
    --home-accent: var(--octap-accent, #ffa84f);
    --home-accent-strong: var(--octap-accent-strong, #ff9500);
    --home-accent-soft: var(--octap-accent-soft, rgba(255, 168, 79, 0.1));
    --home-accent-line: var(--octap-accent-line, rgba(255, 168, 79, 0.22));
    --home-shadow: var(--octap-shadow-panel, 0 18px 50px rgba(0, 0, 0, 0.42));
    --home-ease: var(--octap-ease, cubic-bezier(.22, .61, .36, 1));
}

body[data-theme="light"] {
    --home-bg: var(--octap-page-bg, #f4f6fa);
    --home-surface: var(--octap-surface, rgba(255, 255, 255, 0.86));
    --home-surface-soft: var(--octap-surface-soft, rgba(255, 255, 255, 0.72));
    --home-surface-hover: var(--octap-surface-hover, #fff);
    --home-card: var(--octap-card, rgba(255, 255, 255, 0.72));
    --home-card-hover: var(--octap-card-hover, rgba(255, 255, 255, 0.92));
    --home-thumb: var(--octap-thumb, #e2e5ea);
    --home-line: var(--octap-line, rgba(14, 20, 30, 0.08));
    --home-line-strong: var(--octap-line-strong, rgba(14, 20, 30, 0.14));
    --home-text: var(--octap-text, #151922);
    --home-muted: var(--octap-muted, #555d6b);
    --home-faint: var(--octap-faint, #8a92a0);
    --home-accent: var(--octap-accent, #e68c0f);
    --home-accent-strong: var(--octap-accent-strong, #f5a02a);
    --home-accent-soft: var(--octap-accent-soft, rgba(230, 140, 15, 0.11));
    --home-accent-line: var(--octap-accent-line, rgba(230, 140, 15, 0.22));
    --home-shadow: var(--octap-shadow-panel, 0 18px 44px rgba(29, 39, 55, 0.1));
}

body:not([data-octap-home-route="canvas"]) .app-shell {
    visibility: hidden;
    pointer-events: none;
}

body:not([data-octap-home-route="canvas"]) .selection-group-fixed-toolbar,
body:not([data-octap-home-route="canvas"]) .canvas-group-fixed-toolbar,
body:not([data-octap-home-route="canvas"]) .create-menu,
body:not([data-octap-home-route="canvas"]) .node-context-menu,
body:not([data-octap-home-route="canvas"]) .sidebar-add-node-menu,
body:not([data-octap-home-route="canvas"]) .sidebar-help-menu,
body:not([data-octap-home-route="canvas"]) .project-board-panel,
body:not([data-octap-home-route="canvas"]) .project-board-context-menu {
    display: none !important;
    pointer-events: none !important;
}

body[data-octap-home-route="canvas"] .octap-home-shell {
    display: none;
}

.octap-home-shell {
    position: fixed;
    inset: 0;
    z-index: 500;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    background: var(--home-bg);
    color: var(--home-text);
    font-family: var(--octap-font-family-ui, Inter, Manrope, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif);
    letter-spacing: 0;
    -webkit-font-smoothing: antialiased;
    text-rendering: geometricPrecision;
}

.octap-home-shell *,
.octap-home-shell *::before,
.octap-home-shell *::after {
    box-sizing: border-box;
}

.octap-home-shell button,
.octap-home-shell input,
.octap-home-shell textarea {
    font: inherit;
}

.octap-home-bg {
    position: fixed;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
    background: radial-gradient(rgba(255, 149, 0, 0.055) 1px, transparent 0) 0 0 / 42px 42px;
}

body[data-theme="light"] .octap-home-bg {
    background:
        radial-gradient(rgba(255, 149, 0, 0.08) 1px, transparent 0) 0 0 / 42px 42px,
        linear-gradient(180deg, #f7f9fc 0%, #eef2f7 100%);
}

.octap-home-bg-canvas {
    position: absolute;
    inset: 0;
    display: block;
    width: 100%;
    height: 100%;
    opacity: 0.98;
    mix-blend-mode: screen;
}

body[data-theme="light"] .octap-home-bg-canvas {
    opacity: 0.72;
    mix-blend-mode: multiply;
}

@media (prefers-reduced-motion: reduce) {
    .octap-home-bg-canvas {
        display: none;
    }
}

.octap-home-topbar {
    position: relative;
    z-index: 3;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 22px;
    flex: 0 0 auto;
}

.octap-home-brand,
.octap-home-left,
.octap-home-actions,
.octap-home-center,
.octap-home-nav,
.octap-workspace-nav {
    display: flex;
    align-items: center;
}

.octap-home-left {
    gap: 8px;
    min-width: 0;
}

body[data-octap-home-route="home"] .octap-home-shell .project-title-root,
body[data-octap-home-route="project"] .octap-home-shell .project-title-root,
body[data-octap-home-route="home"] .octap-home-shell .octap-home-top-menu,
body[data-octap-home-route="project"] .octap-home-shell .octap-home-top-menu {
    display: none;
}

.octap-home-shell .octap-home-top-menu {
    display: flex;
    align-items: center;
}

.octap-home-brand {
    gap: 11px;
    border: 0;
    background: transparent;
    color: var(--home-text);
    cursor: pointer;
}

.octap-home-logo {
    width: 36px;
    height: 36px;
    display: grid;
    place-items: center;
    filter: drop-shadow(0 4px 14px rgba(255, 149, 0, 0.38));
}

.octap-home-logo img {
    display: block;
    width: auto;
    height: 36px;
    max-width: 36px;
    object-fit: contain;
}

.octap-home-wordmark {
    font-size: var(--octap-font-18, 18px);
    font-weight: var(--octap-weight-brand, 760);
    line-height: 1;
}

.octap-home-wordmark b {
    color: var(--home-accent);
}

.octap-home-shell .project-title-button {
    border-color: transparent;
    background: transparent;
    color: var(--home-text);
}

.octap-home-shell .project-title-input {
    border-color: var(--home-line);
    background: var(--home-surface-soft);
    color: var(--home-text);
}

.octap-home-shell .project-title-button:hover {
    border-color: transparent;
    background: var(--home-surface-hover);
}

.octap-home-shell .project-title-input:focus {
    border-color: var(--home-accent);
    box-shadow: 0 0 0 2px var(--home-accent-soft);
}

.octap-home-center {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    justify-content: center;
}

.octap-home-nav,
.octap-workspace-nav {
    gap: 4px;
}

.octap-workspace-nav {
    display: none;
    gap: 16px;
}

.octap-home-nav-button,
.octap-workspace-nav-button {
    display: flex;
    align-items: center;
    gap: 7px;
    height: var(--octap-control-lg, 36px);
    padding: 0 16px;
    border: 0;
    border-radius: var(--octap-radius-pill, 999px);
    background: transparent;
    color: var(--home-muted);
    font-size: var(--octap-font-14, 14px);
    font-weight: var(--octap-weight-semibold, 620);
    white-space: nowrap;
    cursor: pointer;
    transition: color .16s ease, background .16s ease;
}

.octap-home-nav-button svg,
.octap-workspace-nav-button svg {
    width: var(--octap-icon-md, 16px);
    height: var(--octap-icon-md, 16px);
    opacity: .72;
}

.octap-home-nav-button:hover,
.octap-workspace-nav-button:hover {
    color: var(--home-text);
}

.octap-home-nav-button.is-active {
    color: var(--home-accent);
    background: var(--home-accent-soft);
}

.octap-home-nav-button.is-active svg,
.octap-workspace-nav-button.is-active svg {
    opacity: 1;
}

.octap-workspace-nav-button {
    position: relative;
    height: 30px;
    padding: 0 2px;
    border-radius: 0;
    background: transparent;
    font-weight: 640;
}

.octap-workspace-nav-button svg {
    display: none;
}

.octap-workspace-nav-button.is-active {
    color: var(--home-accent);
}

.octap-workspace-nav-button.is-active::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -4px;
    height: 2px;
    border-radius: 2px;
    background: var(--home-accent);
}

.octap-home-actions {
    gap: 10px;
    flex: 0 0 auto;
}

.octap-credit-button,
.octap-icon-button {
    height: var(--octap-control-lg, 36px);
    border: 1px solid var(--home-line);
    background: var(--home-surface-soft);
    color: var(--home-muted);
    cursor: pointer;
    transition: background .15s ease, border-color .15s ease, color .15s ease;
}

.octap-credit-button:hover,
.octap-icon-button:hover {
    background: var(--home-surface-hover);
    border-color: var(--home-line-strong);
    color: var(--home-text);
}

.octap-credit-button svg {
    width: var(--octap-icon-sm, 15px);
    height: var(--octap-icon-sm, 15px);
    color: var(--home-accent);
}

.octap-home-credits {
    display: flex;
    align-items: center;
    gap: 8px;
}

.octap-credit-button {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 0 13px;
    border-radius: var(--octap-radius-pill, 999px);
    color: var(--home-text);
    font-size: var(--octap-font-13, 13px);
    font-weight: var(--octap-weight-bold, 700);
    white-space: nowrap;
}

.octap-icon-button {
    position: relative;
    width: 36px;
    border-radius: 50%;
    display: grid;
    place-items: center;
}

.octap-icon-button svg {
    width: var(--octap-icon-lg, 17px);
    height: var(--octap-icon-lg, 17px);
}

.octap-icon-button .sun-icon {
    display: none;
}

body[data-theme="light"] .octap-icon-button .moon-icon {
    display: none;
}

body[data-theme="light"] .octap-icon-button .sun-icon {
    display: block;
}

.octap-icon-dot {
    position: absolute;
    top: 7px;
    right: 8px;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--home-accent);
    border: 2px solid var(--home-bg);
}

.octap-home-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    border: 0;
    color: #1a1206;
    background: linear-gradient(135deg, #ffc979, #ff8a00);
    font-weight: 780;
    cursor: pointer;
}

.octap-home-stage {
    position: relative;
    z-index: 2;
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    scrollbar-width: thin;
    scrollbar-color: rgba(255, 255, 255, 0.12) transparent;
}

.octap-home-stage::-webkit-scrollbar {
    width: 9px;
}

.octap-home-stage::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.1);
    border-radius: 9px;
    border: 2px solid transparent;
    background-clip: padding-box;
}

.octap-home-wrap {
    width: min(1180px, calc(100vw - 80px));
    margin: 0 auto;
}

.octap-home-view {
    display: none;
}

body[data-octap-home-route="home"] .octap-home-view[data-view="home"],
body[data-octap-home-route="project"] .octap-home-view[data-view="project"] {
    display: block;
}

.octap-hero-zone {
    padding: 107px 0 34px;
    text-align: center;
}

.octap-hero-title {
    margin: 0;
    color: var(--home-text);
    font-size: 32px;
    font-weight: 820;
    line-height: 1.12;
}

.octap-hero-title span {
    color: var(--home-accent);
}

.octap-hero-sub {
    margin: 14px 0 0;
    color: var(--home-muted);
    font-size: 15px;
    font-weight: 520;
}

.octap-composer {
    --composer-pad-x: 18px;
    --composer-pad-y: 12px;
    --composer-media-left: 10px;
    --composer-media-rail: 132px;
    --composer-input-collapsed-offset: 56px;
    --composer-input-offset: var(--composer-input-collapsed-offset);
    --composer-media-card-w: 44px;
    --composer-media-card-h: 60px;
    width: min(920px, 100%);
    margin: 24px auto 0;
    padding: var(--composer-pad-y) var(--composer-pad-x) 14px;
    position: relative;
    border: 1px solid var(--home-line-strong);
    border-radius: 20px;
    background: rgba(17, 21, 28, 0.96);
    box-shadow: var(--home-shadow);
    text-align: left;
    transition: border-color .16s ease, background .16s ease;
}

body[data-theme="light"] .octap-composer {
    background: rgba(255, 255, 255, 0.82);
    border-color: rgba(14, 20, 30, 0.12);
}

.octap-composer:focus-within {
    border-color: rgba(255, 255, 255, 0.16);
}

.octap-composer.is-drag-over {
    border-color: rgba(255, 255, 255, 0.28);
    background: rgba(19, 24, 32, 0.98);
}

.octap-composer.has-composer-images {
    --composer-input-offset: var(--composer-input-collapsed-offset, 82px);
}

.octap-composer-media-row {
    position: absolute;
    left: var(--composer-media-left);
    top: var(--composer-pad-y);
    bottom: 62px;
    z-index: 12;
    width: var(--composer-media-rail);
    min-height: 96px;
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    margin: 0;
    pointer-events: none;
}

.octap-composer-upload-stack {
    position: relative;
    width: var(--composer-media-card-w);
    height: var(--composer-media-card-h);
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 0;
    transition: width .2s var(--home-ease);
    margin-left: 0;
    pointer-events: auto;
}

.octap-composer-upload-stack.has-images {
    width: var(--composer-stack-collapsed-w, 86px);
    margin-left: 0;
}

.octap-composer-upload-stack.has-images.is-expanded,
.octap-composer.is-drag-over .octap-composer-upload-stack.has-images {
    width: min(var(--composer-expanded-stack-w, 204px), calc(100vw - 72px));
    gap: 0;
}

.octap-composer-media-list {
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.octap-composer-upload-stack.has-images .octap-composer-media-list {
    position: absolute;
    left: 0;
    top: 0;
    width: var(--composer-stack-collapsed-w, 86px);
    height: var(--composer-media-card-h);
    display: block;
}

.octap-composer-upload-stack.has-images.is-expanded .octap-composer-media-list,
.octap-composer.is-drag-over .octap-composer-upload-stack.has-images .octap-composer-media-list {
    position: absolute;
    left: 0;
    top: 0;
    width: var(--composer-expanded-list-w, 148px);
    height: var(--composer-media-card-h);
    display: flex;
    gap: 8px;
}

.octap-composer-image-thumb,
.octap-composer-upload-card {
    position: relative;
    width: var(--composer-media-card-w);
    height: var(--composer-media-card-h);
    flex: 0 0 auto;
    border-radius: 6px;
}

.octap-composer-image-thumb {
    display: grid;
    place-items: center;
    border: 1px solid rgba(255, 255, 255, 0.14);
    background: linear-gradient(145deg, #313640, #181d25);
    background-size: cover;
    background-position: center;
    box-shadow: inset 0 -14px 18px rgba(0, 0, 0, 0.28);
    cursor: grab;
    overflow: visible;
    transition: transform .18s var(--home-ease), left .18s var(--home-ease), top .18s var(--home-ease), opacity .14s ease;
}

.octap-composer-image-thumb.is-video {
    color: #ffad38;
    background: linear-gradient(145deg, rgba(255, 154, 32, 0.22), rgba(20, 24, 31, 0.96));
}

.octap-composer-media-kind {
    width: 26px;
    height: 26px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: rgba(5, 7, 10, 0.72);
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.28);
}

.octap-composer-upload-stack.has-images .octap-composer-image-thumb {
    position: absolute;
    left: var(--thumb-stack-left, 0);
    top: var(--thumb-stack-top, 0);
    transform: rotate(var(--thumb-tilt, 0deg));
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.28), inset 0 -14px 18px rgba(0, 0, 0, 0.28);
}

.octap-composer-upload-stack.has-images.is-expanded .octap-composer-image-thumb,
.octap-composer.is-drag-over .octap-composer-upload-stack.has-images .octap-composer-image-thumb {
    position: absolute;
    left: var(--thumb-expanded-left, 0);
    top: var(--thumb-expanded-top, 0);
    transform: rotate(var(--thumb-expanded-tilt, 0deg)) scale(1);
}

.octap-composer-upload-stack.has-images.is-drag-previewing .octap-composer-image-thumb {
    left: var(--thumb-preview-left, var(--thumb-expanded-left, 0));
    top: var(--thumb-preview-top, var(--thumb-expanded-top, 0));
    transform: rotate(var(--thumb-preview-tilt, var(--thumb-expanded-tilt, 0deg))) scale(1);
    transition: left .18s cubic-bezier(.2, 1.28, .34, 1), top .18s cubic-bezier(.2, 1.28, .34, 1), transform .18s cubic-bezier(.2, 1.28, .34, 1), opacity .14s ease;
}

.octap-composer-upload-stack.has-images.is-expanded .octap-composer-image-thumb:hover,
.octap-composer-upload-stack.has-images.is-expanded .octap-composer-image-thumb:focus-visible,
.octap-composer.is-drag-over .octap-composer-upload-stack.has-images .octap-composer-image-thumb:hover {
    transform: rotate(var(--thumb-expanded-tilt, 0deg)) scale(var(--composer-card-hover-scale, 1.08));
    z-index: 80 !important;
}

.octap-composer-upload-stack.has-images.is-drag-previewing .octap-composer-image-thumb:hover,
.octap-composer-upload-stack.has-images.is-drag-previewing .octap-composer-image-thumb:focus-visible {
    transform: rotate(var(--thumb-preview-tilt, var(--thumb-expanded-tilt, 0deg))) scale(1);
}

.octap-composer-image-thumb:active {
    cursor: grabbing;
}

.octap-composer-image-thumb.is-dragging {
    opacity: .48;
}

.octap-composer-image-thumb.is-drag-source {
    transition: opacity .14s ease;
}

.octap-composer-reference-label {
    position: absolute;
    left: 4px;
    right: 4px;
    bottom: 4px;
    z-index: 2;
    min-width: 0;
    border-radius: 5px;
    padding: 2px 3px;
    background: rgba(5, 7, 10, 0.68);
    color: #f7fafc;
    font-size: 9px;
    font-weight: 720;
    line-height: 1.05;
    text-align: center;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    pointer-events: none;
}

.octap-composer-image-thumb.is-video .octap-composer-reference-label {
    background: rgba(84, 42, 8, 0.72);
    color: #fff1dd;
}

.octap-composer-image-thumb::after {
    content: attr(data-reference-title);
    position: absolute;
    left: 50%;
    bottom: calc(100% + 8px);
    max-width: 180px;
    padding: 6px 9px;
    border-radius: 7px;
    background: #191d24;
    color: #f2f5fa;
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.34);
    font-size: 11px;
    font-weight: 650;
    line-height: 1;
    opacity: 0;
    pointer-events: none;
    transform: translate(-50%, 5px);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: opacity .14s ease, transform .14s ease;
}

.octap-composer-image-thumb:hover::after {
    opacity: 1;
    transform: translate(-50%, 0);
}

.octap-composer-remove-image {
    position: absolute;
    right: -5px;
    top: -5px;
    width: 15px;
    height: 15px;
    display: grid;
    place-items: center;
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 999px;
    background: #050607;
    color: #fff;
    font-size: 11px;
    line-height: 1;
    padding: 0;
    opacity: 0;
    transform: scale(.86);
    transition: opacity .14s ease, transform .14s ease;
}

.octap-composer-image-thumb:hover .octap-composer-remove-image,
.octap-composer-remove-image:focus-visible {
    opacity: 1;
    transform: scale(1);
}

.octap-composer-upload-card {
    width: var(--composer-media-card-w);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    padding: 0;
    border: 1px solid rgba(255, 255, 255, 0.15);
    background: linear-gradient(160deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.035));
    color: #c3ccd8;
    overflow: hidden;
    cursor: pointer;
    transform: rotate(-6deg);
    transition: width .18s var(--home-ease), border-color .16s ease, background .16s ease, color .16s ease, transform .16s ease;
}

.octap-composer-upload-card span {
    position: absolute;
    width: 1px;
    height: 1px;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    opacity: 0;
    overflow: hidden;
}

.octap-composer-upload-card:hover,
.octap-composer-upload-card:focus-visible,
.octap-composer.is-drag-over .octap-composer-upload-card {
    border-color: rgba(255, 255, 255, 0.28);
    background: rgba(255, 255, 255, 0.07);
    color: #fff;
    transform: rotate(-3deg);
}

.octap-composer-upload-stack.has-images .octap-composer-upload-card {
    position: absolute;
    left: var(--composer-stack-plus-left, 58px);
    top: 40px;
    width: 24px;
    height: 24px;
    border-radius: 999px;
    border-style: solid;
    border-color: rgba(255, 255, 255, 0.18);
    background: rgba(16, 20, 27, 0.92);
    color: #d7dde6;
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.28), inset 0 1px 0 rgba(255, 255, 255, 0.08);
    transform: none;
    z-index: 40;
}

.octap-composer-upload-stack.has-images .octap-composer-upload-card svg {
    width: 13px;
    height: 13px;
}

.octap-composer-upload-stack.has-images.is-expanded .octap-composer-upload-card,
.octap-composer.is-drag-over .octap-composer-upload-stack.has-images .octap-composer-upload-card {
    position: absolute;
    left: var(--composer-expanded-plus-left, 156px);
    top: 0;
    width: var(--composer-media-card-w);
    height: var(--composer-media-card-h);
    border-radius: 6px;
    border-style: dashed;
    border-color: rgba(255, 255, 255, 0.16);
    background: linear-gradient(160deg, rgba(28, 34, 44, 0.96), rgba(17, 21, 28, 0.9));
    color: #cbd3de;
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.24);
    transform: rotate(-3deg);
}

.octap-composer-upload-stack.has-images.is-expanded .octap-composer-upload-card svg,
.octap-composer.is-drag-over .octap-composer-upload-stack.has-images .octap-composer-upload-card svg {
    width: 16px;
    height: 16px;
}

.octap-composer-upload-stack.has-images.is-expanded .octap-composer-upload-card:hover,
.octap-composer-upload-stack.has-images.is-expanded .octap-composer-upload-card:focus-visible {
    border-color: rgba(255, 255, 255, 0.28);
    color: #fff;
    transform: rotate(-3deg) scale(1.06);
}

body[data-theme="light"] .octap-composer-upload-card {
    border-color: rgba(15, 23, 36, 0.12);
    background: linear-gradient(160deg, rgba(255, 255, 255, 0.98), rgba(241, 244, 248, 0.92));
    color: #9aa4b1;
}

body[data-theme="light"] .octap-composer-upload-stack.has-images .octap-composer-upload-card {
    border-color: rgba(15, 23, 36, 0.1);
    background: rgba(255, 255, 255, 0.94);
    color: #8f99a6;
    box-shadow: 0 10px 22px rgba(18, 26, 38, 0.16), inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

body[data-theme="light"] .octap-composer-upload-stack.has-images.is-expanded .octap-composer-upload-card,
body[data-theme="light"] .octap-composer.is-drag-over .octap-composer-upload-stack.has-images .octap-composer-upload-card {
    border-color: rgba(15, 23, 36, 0.1);
    background: linear-gradient(160deg, rgba(255, 255, 255, 0.98), rgba(236, 240, 245, 0.94));
    color: #9ba5b1;
}

.octap-home-image-preview {
    position: fixed;
    inset: 0;
    z-index: 22000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 34px;
    opacity: 0;
    pointer-events: none;
    transition: opacity .16s ease;
}

.octap-home-image-preview.is-open {
    opacity: 1;
    pointer-events: auto;
}

.octap-home-image-preview-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.88);
    backdrop-filter: blur(7px);
}

.octap-home-image-preview-stage {
    position: relative;
    z-index: 1;
    width: fit-content;
    max-width: min(72vw, 1120px);
    max-height: min(70vh, 760px);
    display: block;
}

.octap-home-image-preview-viewport {
    position: relative;
    max-width: min(72vw, 1120px);
    max-height: min(68vh, 720px);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: visible;
    border-radius: 0;
    cursor: grab;
}

.octap-home-image-preview-img {
    display: block;
    width: min(70vw, 1120px);
    max-width: 100%;
    max-height: min(66vh, 700px);
    height: auto;
    object-fit: contain;
    border-radius: 6px;
    background: transparent;
    box-shadow: 0 28px 86px rgba(0, 0, 0, 0.44);
    user-select: none;
    pointer-events: none;
    transform-origin: center;
    transition: transform .08s ease-out;
}

.octap-home-image-preview-viewport.is-zoomed {
    cursor: move;
}

.octap-home-image-preview-viewport.is-panning .octap-home-image-preview-img {
    transition: none;
}

.octap-home-image-preview-strip {
    position: fixed;
    left: 50%;
    bottom: 36px;
    z-index: 22002;
    width: min(var(--home-preview-strip-w, 86px), calc(100vw - 64px));
    height: 58px;
    max-width: calc(100vw - 64px);
    transform: translateX(-50%);
    padding: 0;
}

.octap-home-image-preview-strip[hidden] {
    display: none;
}

.octap-home-image-preview-thumb {
    position: absolute;
    left: var(--preview-thumb-left, 0);
    top: 3px;
    width: 86px;
    height: 52px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 5px;
    background: rgba(16, 20, 27, 0.72);
    background-size: cover;
    background-position: center;
    box-shadow: 0 14px 38px rgba(0, 0, 0, 0.32);
    cursor: grab;
    opacity: .78;
    transition: left .18s cubic-bezier(.2, 1.28, .34, 1), transform .16s cubic-bezier(.2, 1.2, .34, 1), opacity .16s ease, border-color .16s ease, box-shadow .16s ease;
}

.octap-home-image-preview-strip.is-drag-previewing .octap-home-image-preview-thumb {
    left: var(--preview-thumb-preview-left, var(--preview-thumb-left, 0));
    transform: translateY(0) scale(1);
    transition: left .18s cubic-bezier(.2, 1.28, .34, 1), transform .18s cubic-bezier(.2, 1.28, .34, 1), opacity .16s ease, border-color .16s ease, box-shadow .16s ease;
}

.octap-home-image-preview-thumb.is-active,
.octap-home-image-preview-thumb:hover,
.octap-home-image-preview-thumb:focus-visible {
    border-color: rgba(255, 255, 255, 0.96);
    opacity: 1;
    box-shadow: 0 0 0 2px rgba(255, 168, 79, 0.42), 0 16px 42px rgba(0, 0, 0, 0.36);
    transform: translateY(-2px) scale(1.04);
}

.octap-home-image-preview-strip.is-drag-previewing .octap-home-image-preview-thumb:hover,
.octap-home-image-preview-strip.is-drag-previewing .octap-home-image-preview-thumb:focus-visible {
    transform: translateY(0) scale(1);
}

.octap-home-image-preview-thumb.is-dragging {
    opacity: .45;
    transform: scale(.94);
}

.octap-home-image-preview-close,
.octap-home-image-preview-reset {
    position: fixed;
    top: 56px;
    z-index: 22003;
    width: 32px;
    height: 32px;
    display: grid;
    place-items: center;
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.86);
    font-size: 18px;
    line-height: 1;
    padding: 0;
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.28);
    transition: background .15s ease, color .15s ease;
}

.octap-home-image-preview-close {
    right: 20px;
}

.octap-home-image-preview-reset {
    right: 58px;
    font-size: 0;
}

.octap-home-image-preview-reset svg {
    width: 15px;
    height: 15px;
    stroke-width: 2;
}

.octap-home-image-preview-close:hover,
.octap-home-image-preview-close:focus-visible,
.octap-home-image-preview-reset:hover,
.octap-home-image-preview-reset:focus-visible {
    background: rgba(255, 255, 255, 0.18);
    color: #fff;
}

body[data-theme="light"] .octap-home-image-preview-backdrop {
    background: rgba(0, 0, 0, 0.82);
}

body[data-theme="light"] .octap-home-image-preview-close,
body[data-theme="light"] .octap-home-image-preview-reset {
    border-color: rgba(15, 23, 36, 0.12);
    background: rgba(255, 255, 255, 0.9);
    color: #1d2532;
}

body[data-theme="light"] .octap-home-image-preview-thumb {
    border-color: rgba(15, 23, 36, 0.1);
    background-color: rgba(255, 255, 255, 0.88);
    box-shadow: 0 16px 38px rgba(18, 26, 38, 0.16);
}

.octap-home-shell .octap-composer-input {
    box-sizing: border-box;
    width: 100%;
    height: 96px;
    min-height: 96px;
    max-height: 96px;
    display: block;
    padding: 0 0 0 var(--composer-input-offset);
    resize: none;
    border: 0;
    outline: none;
    background: transparent;
    color: var(--home-text);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
    font-size: 13px;
    font-weight: 400;
    line-height: 1.55;
    letter-spacing: 0;
    text-align: left;
    caret-color: var(--home-text);
    overflow-y: auto;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
    word-break: break-word;
    user-select: text;
    scrollbar-width: thin;
    scrollbar-color: rgba(126, 136, 150, 0.46) transparent;
}

.octap-composer-input::placeholder {
    color: var(--home-faint);
}

.octap-composer-input:empty::before {
    content: attr(data-placeholder);
    color: var(--home-faint);
    pointer-events: none;
}

.octap-composer-reference-token {
    display: inline-block;
    box-sizing: border-box;
    min-width: 54px;
    max-width: none;
    height: 18px;
    margin: 0 3px;
    padding: 0 7px 0 3px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 6px;
    background: rgba(255, 255, 255, 0.09);
    color: rgba(248, 252, 255, 0.96);
    font-size: 13px;
    font-weight: 680;
    line-height: 16px;
    text-align: left;
    vertical-align: middle;
    white-space: nowrap;
    cursor: default;
}

.octap-composer-reference-token-preview {
    display: inline-block;
    width: 14px;
    height: 14px;
    margin-right: 4px;
    border-radius: 4px;
    background: rgba(255, 255, 255, 0.14) center / cover no-repeat;
    color: currentColor;
    vertical-align: -2.5px;
}

.octap-composer-reference-token:not(.is-video) .octap-composer-reference-token-preview {
    cursor: zoom-in;
}

.octap-composer-reference-token.is-video {
    border-color: rgba(255, 168, 79, 0.28);
    background: rgba(255, 168, 79, 0.12);
    color: #ffd19b;
}

.octap-composer-reference-token-text {
    display: inline-block;
    vertical-align: top;
}

.octap-reference-mention-menu {
    position: absolute;
    left: var(--home-reference-menu-left, var(--composer-input-offset));
    top: var(--home-reference-menu-top, 38px);
    z-index: 34;
    width: min(240px, calc(100% - 28px));
    display: none;
    flex-direction: column;
    gap: 4px;
    padding: 6px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 10px;
    background: rgba(18, 22, 29, 0.98);
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.42);
    text-align: left;
}

.octap-reference-mention-menu.is-open {
    display: flex;
}

.octap-reference-mention-option {
    width: 100%;
    min-height: 42px;
    display: grid;
    grid-template-columns: 30px auto 1fr;
    align-items: center;
    gap: 8px;
    border: 0;
    border-radius: 8px;
    padding: 6px 8px;
    background: transparent;
    color: #f4f6fb;
    text-align: left;
    cursor: pointer;
}

.octap-reference-mention-option:hover,
.octap-reference-mention-option.is-active {
    background: rgba(255, 255, 255, 0.08);
}

.octap-reference-mention-preview {
    width: 30px;
    height: 30px;
    display: grid;
    place-items: center;
    overflow: hidden;
    border-radius: 7px;
    background: #252b35 center / cover no-repeat;
    color: #d9dee7;
}

.octap-reference-mention-preview.is-video {
    background-color: rgba(255, 168, 79, 0.14);
    color: #ffd6a8;
}

.octap-reference-mention-label {
    color: #f6f7fb;
    font-size: 12px;
    font-weight: 720;
    line-height: 1;
    white-space: nowrap;
}

.octap-reference-mention-title {
    min-width: 0;
    overflow: hidden;
    color: #aeb5c0;
    font-size: 11.5px;
    font-weight: 500;
    line-height: 1.1;
    text-overflow: ellipsis;
    white-space: nowrap;
}

body[data-theme="light"] .octap-reference-mention-menu {
    border-color: rgba(14, 20, 30, 0.1);
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 18px 36px rgba(29, 39, 55, 0.14);
}

body[data-theme="light"] .octap-reference-mention-option {
    color: #151922;
}

body[data-theme="light"] .octap-reference-mention-option:hover,
body[data-theme="light"] .octap-reference-mention-option.is-active {
    background: rgba(14, 20, 30, 0.06);
}

body[data-theme="light"] .octap-reference-mention-preview {
    background-color: #edf0f5;
    color: #465061;
}

body[data-theme="light"] .octap-reference-mention-preview.is-video {
    background-color: rgba(255, 168, 79, 0.17);
    color: #9b5814;
}

body[data-theme="light"] .octap-reference-mention-label {
    color: #171c25;
}

body[data-theme="light"] .octap-reference-mention-title {
    color: #687180;
}

.octap-composer-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 14px;
    gap: 16px;
}

.octap-composer-left,
.octap-composer-actions,
.octap-quickstart {
    display: flex;
    align-items: center;
}

.octap-composer-left {
    min-width: 0;
    gap: 8px;
    flex-wrap: wrap;
}

.octap-composer-actions {
    gap: 10px;
}

.octap-composer-pill {
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    padding: 0 11px;
    border: 1px solid var(--home-line);
    border-radius: 10px;
    background: var(--home-surface-soft);
    color: var(--home-muted);
    font-size: 12.5px;
    font-weight: 650;
    white-space: nowrap;
    cursor: pointer;
    transition: border-color .15s ease, background .15s ease, color .15s ease;
}

.octap-icon-pill {
    width: 32px;
    padding: 0;
    gap: 0;
}

.octap-composer-pill:hover,
.octap-composer-pill[aria-expanded="true"] {
    border-color: rgba(255, 255, 255, 0.18);
    background: rgba(255, 255, 255, 0.07);
    color: var(--home-text);
}

.octap-composer-pill svg {
    width: 15px;
    height: 15px;
    stroke-width: 1.75;
}

.octap-preference-trigger {
    position: relative;
}

.octap-auto-badge {
    position: absolute;
    right: -8px;
    top: -9px;
    padding: 0 2px;
    border-radius: 2px;
    background: rgba(9, 11, 14, .92);
    color: var(--home-accent);
    font-size: 8px;
    font-weight: 900;
    line-height: 1.1;
}

.octap-composer[data-preference-auto="false"] .octap-auto-badge {
    display: none;
}

.octap-composer[data-home-composer-mode="image"] .octap-execution-trigger,
.octap-composer[data-home-composer-mode="video"] .octap-execution-trigger {
    display: none;
}

.octap-send-button {
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    border: 1px solid var(--home-accent-line);
    border-radius: 50%;
    background: var(--home-accent-soft);
    color: var(--home-accent);
    cursor: pointer;
    transition: background .15s ease, transform .15s ease;
}

.octap-composer-enter-button {
    width: auto;
    height: 32px;
    min-width: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    padding: 0 11px;
    border: 1px solid var(--home-line);
    border-radius: 10px;
    background: var(--home-surface-soft);
    color: var(--home-muted);
    font-size: 12.5px;
    font-weight: 650;
    white-space: nowrap;
    cursor: pointer;
    transition: border-color .15s ease, background .15s ease, color .15s ease;
}

.octap-composer-enter-button:hover {
    border-color: rgba(255, 255, 255, 0.18);
    background: rgba(255, 255, 255, 0.07);
    color: var(--home-text);
}

.octap-composer-enter-button svg {
    width: 15px;
    height: 15px;
    stroke-width: 1.75;
}

.octap-send-button:hover {
    transform: scale(1.06);
    background: rgba(255, 168, 79, 0.18);
}

.octap-home-floating-menu {
    position: absolute;
    z-index: 20;
    bottom: 58px;
    display: none;
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 10px;
    background: rgba(18, 22, 29, 0.98);
    box-shadow: 0 18px 46px rgba(0, 0, 0, 0.42);
    color: #f3f6fb;
    text-align: left;
}

.octap-home-floating-menu.is-open {
    display: block;
}

.octap-home-skill-menu {
    left: max(12px, var(--composer-input-offset, 56px));
    right: auto;
    top: auto;
    bottom: calc(100% + 8px);
    z-index: 36;
    width: min(330px, calc(100% - 28px));
    padding: 0;
    overflow: hidden;
}

.octap-home-skill-menu .ai-v4-skill-list {
    max-height: min(268px, calc(100vh - 260px));
}

.octap-home-mode-menu {
    left: var(--home-mode-menu-left, 157px);
    top: var(--home-mode-menu-top, calc(100% - 48px));
    bottom: auto;
    transform: translateX(-50%);
    width: 278px;
    padding: 5px;
}

.octap-home-execution-menu {
    left: var(--home-execution-menu-left, 247px);
    top: var(--home-execution-menu-top, calc(100% - 48px));
    bottom: auto;
    transform: translateX(-50%);
    width: 230px;
    padding: 5px;
}

.octap-home-preference-menu {
    left: var(--home-preference-menu-left, calc(100% - 190px));
    right: auto;
    top: var(--home-preference-menu-top, calc(100% - 48px));
    bottom: auto;
    transform: translateX(-50%);
    width: min(344px, calc(100% - 16px));
    padding: 10px;
    background: rgba(18, 22, 29, 0.98);
    border-color: rgba(255, 255, 255, 0.14);
    box-shadow: 0 18px 46px rgba(0, 0, 0, 0.42);
}

.octap-home-menu-row {
    width: 100%;
    min-height: 42px;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 9px;
    border: 0;
    border-radius: 8px;
    background: transparent;
    color: #f3f6fb;
    padding: 7px 9px;
    text-align: left;
    cursor: pointer;
}

.octap-home-menu-row:hover,
.octap-home-menu-row.is-selected {
    background: rgba(255, 255, 255, 0.07);
}

.octap-home-menu-row.is-selected {
    outline: 1px solid rgba(255, 168, 79, 0.32);
}

.octap-home-menu-row svg {
    width: 16px;
    height: 16px;
    color: #c8cdd5;
    stroke-width: 1.65;
}

.octap-home-menu-row strong {
    display: block;
    color: #f5f6f8;
    font-size: 12px;
    line-height: 1.12;
}

.octap-home-menu-row small {
    display: block;
    margin-top: 2px;
    color: #939aa6;
    font-size: 11px;
    font-weight: 500;
    line-height: 1.2;
}

.octap-home-menu-row b {
    color: #f1f3f7;
    font-size: 12px;
}

.octap-preference-head,
.octap-preference-tabs,
.octap-preference-grid,
.octap-model-toggle,
.octap-model-option {
    display: flex;
    align-items: center;
}

.octap-preference-head {
    justify-content: space-between;
    margin-bottom: 8px;
}

.octap-preference-head strong {
    color: #f5f7fb;
    font-size: 13px;
    font-weight: 780;
    line-height: 1;
}

.octap-auto-toggle {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    border: 0;
    background: transparent;
    color: #dce3ee;
    font-size: 10.5px;
    font-weight: 660;
    cursor: pointer;
}

.octap-auto-toggle i {
    width: 30px;
    height: 17px;
    display: block;
    box-sizing: border-box;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: rgba(255, 255, 255, 0.075);
    padding: 1px;
    transition: background .14s ease, border-color .14s ease, box-shadow .14s ease;
}

.octap-auto-toggle i::before {
    content: "";
    width: 13px;
    height: 13px;
    display: block;
    border-radius: 999px;
    background: #e5e7eb;
    transition: transform .14s ease, background .14s ease, box-shadow .14s ease;
}

.octap-auto-toggle.is-on i {
    border-color: rgba(255, 168, 79, 0.42);
    background: rgba(255, 168, 79, 0.08);
    box-shadow: inset 0 0 0 1px rgba(255, 168, 79, 0.06);
}

.octap-auto-toggle.is-on i::before {
    transform: translateX(13px);
    background: #f3f4f6;
    box-shadow: 0 0 0 1px rgba(255, 168, 79, 0.34), 0 0 8px rgba(255, 168, 79, 0.18);
}

.octap-preference-tabs {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 4px;
    margin-bottom: 9px;
    padding: 3px;
    border-radius: 8px;
    background: rgba(0, 0, 0, 0.24);
}

.octap-preference-tabs button {
    flex: 1;
    height: 26px;
    border: 1px solid transparent;
    border-radius: 7px;
    background: transparent;
    color: #8d96a5;
    font-size: 12px;
    font-weight: 760;
    cursor: pointer;
}

.octap-preference-tabs button.is-active {
    color: #f1f4f9;
    background: rgba(255, 255, 255, 0.085);
}

.octap-composer[data-home-composer-mode="image"] .octap-preference-tabs,
.octap-composer[data-home-composer-mode="video"] .octap-preference-tabs {
    display: none;
}

.octap-preference-section {
    display: none;
}

.octap-preference-section.is-active {
    display: block;
}

.octap-preference-controls {
    display: grid;
    gap: 8px;
}

.octap-home-preference-menu.is-auto .octap-preference-controls {
    opacity: 1;
}

.octap-preference-group {
    display: grid;
    gap: 5px;
    margin-top: 0;
}

.octap-preference-group > span {
    color: #8d95a3;
    font-size: 11px;
    font-weight: 620;
    line-height: 1;
}

.octap-preference-group em {
    margin-left: 6px;
    padding: 1px 5px;
    border-radius: 999px;
    color: #ffca87;
    background: rgba(255, 168, 79, 0.12);
    font-style: normal;
    font-size: 10px;
}

.octap-preference-group > span.is-inline {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.octap-preference-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 5px;
}

.octap-preference-grid.is-compact {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.octap-preference-option {
    min-height: 30px;
    display: grid;
    place-items: center;
    gap: 5px;
    border: 1px solid transparent;
    border-radius: 7px;
    background: rgba(255, 255, 255, 0.055);
    color: #adb6c5;
    padding: 0 8px;
    font-size: 11px;
    font-weight: 760;
    cursor: pointer;
    line-height: 1;
}

.octap-preference-option:hover:not(:disabled) {
    color: #fff;
    background: rgba(255, 255, 255, 0.13);
}

.octap-preference-option.is-selected {
    color: #ffbd5a;
    background: rgba(255, 159, 28, 0.14);
    box-shadow: inset 0 0 0 1px rgba(255, 159, 28, 0.42);
}

.octap-preference-option:disabled,
.octap-model-toggle[data-home-auto-disabled="true"] {
    cursor: default;
    opacity: .58;
}

.octap-ratio-icon {
    width: 12px;
    height: 9px;
    border: 1px solid currentColor;
    border-radius: 2px;
    opacity: .75;
}

.octap-ratio-icon.auto,
.octap-ratio-icon.square {
    width: 9px;
    height: 9px;
}

.octap-ratio-icon.auto {
    border-radius: 999px;
}

.octap-ratio-icon.wide {
    width: 14px;
    height: 7px;
}

.octap-ratio-icon.tall {
    width: 7px;
    height: 14px;
}

.octap-preference-option-label {
    line-height: 1;
    white-space: nowrap;
}

.octap-model-list {
    position: relative;
}

.octap-composer-model-list {
    display: none;
    min-width: 0;
}

.octap-composer-model-list.is-active {
    display: block;
}

.octap-model-toggle {
    width: 100%;
    height: 32px;
    justify-content: space-between;
    gap: 8px;
    border: 1px solid rgba(255, 255, 255, 0.09);
    border-radius: 7px;
    background: rgba(255, 255, 255, 0.035);
    color: #dbe1eb;
    padding: 0 9px;
    font-size: 11px;
    font-weight: 620;
    cursor: pointer;
}

.octap-composer-model-list .octap-model-toggle {
    width: auto;
    min-width: 142px;
    max-width: 188px;
}

.octap-model-toggle svg {
    width: 13px;
    height: 13px;
    color: #aeb6c4;
    stroke-width: 1.8;
}

.octap-model-toggle span {
    min-width: 0;
    flex: 1;
    text-align: left;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.octap-model-dropdown {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + 6px);
    z-index: 28;
    display: none;
    padding: 5px;
    border: 1px solid rgba(255, 255, 255, 0.13);
    border-radius: 9px;
    background: #15181d;
    box-shadow: 0 16px 38px rgba(0, 0, 0, 0.4);
}

.octap-composer-model-list .octap-model-dropdown {
    width: 236px;
    min-width: 100%;
    top: calc(100% + 8px);
    z-index: 38;
}

.octap-model-list.is-open .octap-model-dropdown {
    display: grid;
    gap: 4px;
}

.octap-model-auto-hint {
    display: none;
    padding: 5px 7px 6px;
    color: #ffbd5a;
    font-size: 10.5px;
    font-weight: 650;
    line-height: 1.35;
    border-radius: 7px;
    background: rgba(255, 159, 28, 0.08);
}

.octap-composer[data-model-auto-locked="true"] .octap-composer-model-list .octap-model-auto-hint {
    display: block;
}

.octap-model-option {
    width: 100%;
    min-height: 30px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    text-align: left;
}

.octap-model-option small {
    color: #87909d;
    font-size: 10px;
    font-weight: 600;
}

.octap-duration-row {
    height: 31px;
    display: flex;
    gap: 0;
    overflow-x: auto;
    overscroll-behavior: contain;
    touch-action: pan-x;
    user-select: none;
    padding: 2px;
    border: 1px solid rgba(255, 255, 255, 0.075);
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.045);
    cursor: grab;
    scrollbar-width: none;
    -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 18px, #000 calc(100% - 18px), transparent 100%);
    mask-image: linear-gradient(90deg, transparent 0, #000 18px, #000 calc(100% - 18px), transparent 100%);
}

.octap-duration-row::-webkit-scrollbar {
    display: none;
}

.octap-duration-row.is-dragging {
    cursor: grabbing;
}

.octap-duration-row:not(.can-scroll-left) {
    -webkit-mask-image: linear-gradient(90deg, #000 0, #000 calc(100% - 18px), transparent 100%);
    mask-image: linear-gradient(90deg, #000 0, #000 calc(100% - 18px), transparent 100%);
}

.octap-duration-row:not(.can-scroll-right) {
    -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 18px, #000 100%);
    mask-image: linear-gradient(90deg, transparent 0, #000 18px, #000 100%);
}

.octap-duration-row:not(.can-scroll-left):not(.can-scroll-right) {
    -webkit-mask-image: none;
    mask-image: none;
}

.octap-duration-row .octap-preference-option {
    flex: 0 0 auto;
    min-width: 41px;
    min-height: 25px;
    height: 25px;
    border: 0;
    border-radius: 8px;
    background: transparent;
    color: rgba(243, 245, 250, 0.58);
    box-shadow: none;
    font-size: 10.5px;
    font-weight: 690;
}

.octap-duration-row .octap-preference-option:hover:not(:disabled) {
    color: #fff;
    background: rgba(255, 255, 255, 0.13);
    border-color: transparent;
    box-shadow: none;
}

.octap-duration-row .octap-preference-option.is-selected {
    color: #ffbd5a;
    background: rgba(255, 159, 28, 0.14);
    box-shadow: inset 0 0 0 1px rgba(255, 159, 28, 0.42);
}

.octap-home-shell .octap-auto-toggle {
    font-size: 10.5px;
    font-weight: 660;
}

.octap-home-shell .octap-preference-option {
    font-size: 11px;
    font-weight: 760;
}

.octap-home-shell .octap-model-toggle {
    font-size: 11px;
    font-weight: 620;
}

.octap-home-shell .octap-duration-row .octap-preference-option {
    font-size: 10.5px;
    font-weight: 690;
}

.octap-home-preference-menu.is-auto .octap-preference-option {
    pointer-events: none;
}

.octap-composer[data-model-auto-locked="true"] .octap-composer-model-list .octap-model-option {
    cursor: not-allowed;
    opacity: .62;
}

.octap-quickstart {
    width: min(920px, 100%);
    margin: 18px auto 0;
    justify-content: center;
    flex-wrap: wrap;
    gap: 10px;
}

.octap-quick-chip {
    height: 38px;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0 16px;
    border: 1px solid var(--home-line);
    border-radius: 999px;
    background: var(--home-surface-soft);
    color: var(--home-muted);
    font-size: 13px;
    font-weight: 650;
    cursor: pointer;
    transition: transform .16s var(--home-ease), background .16s ease, border-color .16s ease, color .16s ease;
}

.octap-quick-chip svg {
    width: 15px;
    height: 15px;
    color: var(--home-accent);
}

.octap-quick-chip:hover {
    color: var(--home-text);
    border-color: var(--home-accent-line);
    background: var(--home-accent-soft);
    transform: translateY(-1px);
}

.octap-section {
    padding: 13px 0 120px;
}

.octap-section-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    margin-bottom: 14px;
}

.octap-section-title {
    display: flex;
    align-items: center;
    gap: 9px;
    font-size: 18px;
    font-weight: 760;
    letter-spacing: -.3px;
}

.octap-section-title span {
    color: var(--home-faint);
    font-size: 13px;
    font-weight: 650;
}

.octap-link-button {
    display: flex;
    align-items: center;
    gap: 4px;
    border: 0;
    background: transparent;
    color: var(--home-faint);
    font-size: 13px;
    font-weight: 650;
    cursor: pointer;
}

.octap-link-button:hover {
    color: var(--home-accent);
}

.octap-project-strip {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 16px;
}

.octap-project-card,
.octap-new-card {
    min-height: 204px;
    border: 1px solid rgba(255, 255, 255, 0.068);
    border-radius: 12px;
    background: var(--home-card);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03), 0 18px 40px rgba(0, 0, 0, 0.18);
    cursor: pointer;
    transition: transform .18s var(--home-ease), border-color .18s ease, background .18s ease;
}

body[data-theme="light"] .octap-project-card,
body[data-theme="light"] .octap-new-card {
    border-color: rgba(18, 24, 33, 0.1);
}

.octap-project-card {
    position: relative;
    display: flex;
    flex-direction: column;
    padding: 9px 9px 10px;
    overflow: hidden;
}

.octap-project-card:hover,
.octap-new-card:hover {
    border-color: rgba(255, 255, 255, 0.14);
    background: var(--home-card-hover);
}

.octap-project-card:hover {
    transform: translateY(-2px);
}

.octap-project-thumb {
    position: relative;
    height: 136px;
    flex: 0 0 136px;
    border: 1px solid rgba(255, 255, 255, 0.036);
    border-radius: 8px;
    background: var(--home-thumb);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.032), inset 0 -1px 0 rgba(0, 0, 0, 0.16);
    overflow: hidden;
}

body[data-theme="light"] .octap-project-thumb {
    border-color: rgba(18, 24, 33, 0.06);
}

.octap-card-menu-button {
    position: absolute;
    right: 8px;
    top: 8px;
    z-index: 3;
    width: 28px;
    height: 28px;
    display: grid;
    place-items: center;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 9px;
    background: rgba(9, 12, 17, 0.62);
    color: var(--home-muted);
    opacity: 0;
    cursor: pointer;
    transition: opacity .16s ease, color .16s ease, border-color .16s ease, background .16s ease;
}

.octap-project-card:hover .octap-card-menu-button,
.octap-card-menu-button:focus-visible {
    opacity: 1;
}

.octap-card-menu-button:hover {
    color: var(--home-text);
    border-color: rgba(255, 255, 255, 0.14);
    background: rgba(9, 12, 17, 0.86);
}

.octap-folder-preview {
    --folder-scale: 1;
    position: absolute;
    left: -1px;
    right: -1px;
    bottom: -1px;
    height: 116px;
    transform: scale(var(--folder-scale));
    transform-origin: bottom center;
    pointer-events: none;
}

.octap-folder-paper {
    position: absolute;
    bottom: 28px;
    width: 52px;
    height: 76px;
    border: 1px solid rgba(255, 255, 255, 0.34);
    border-radius: 13px;
    background:
        radial-gradient(circle at 20px 17px, rgba(47, 55, 65, 0.22) 0 3px, transparent 3.5px),
        linear-gradient(160deg, #f2f5f4 0%, #d6dcdb 50%, #b7c0be 100%);
    box-shadow: 0 16px 28px rgba(0, 0, 0, 0.3), inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.octap-folder-paper::after {
    content: "";
    position: absolute;
    left: 15px;
    top: 14px;
    width: 12px;
    height: 12px;
    border: 1.5px solid rgba(41, 48, 58, 0.34);
    border-radius: 50%;
}

.octap-folder-paper.is-left {
    left: calc(50% - 56px);
    transform: rotate(-12deg);
}

.octap-folder-paper.is-center {
    left: calc(50% - 26px);
    bottom: 38px;
    z-index: 1;
    transform: rotate(-1deg);
}

.octap-folder-paper.is-right {
    right: calc(50% - 58px);
    transform: rotate(12deg);
}

.octap-folder-pocket {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 2;
    height: 55px;
    border-top: 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
    border-radius: 14px 14px 8px 8px;
    background: linear-gradient(180deg, rgba(75, 88, 91, 0.94) 0%, rgba(34, 42, 47, 0.98) 100%);
    box-shadow: 0 -8px 24px rgba(5, 8, 11, 0.26), inset 0 1px 0 rgba(255, 255, 255, 0.08);
    overflow: hidden;
}

.octap-folder-pocket::before,
.octap-folder-pocket::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    pointer-events: none;
}

.octap-folder-pocket::before {
    top: -1px;
    z-index: 2;
    height: 18px;
    background: url("data:image/svg+xml,%3Csvg viewBox='0 0 100 18' preserveAspectRatio='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 6 H47 L56 13 H100' fill='none' stroke='%23dce7e5' stroke-opacity='.36' stroke-width='1.2' vector-effect='non-scaling-stroke'/%3E%3Cpath d='M0 7 H46 L55 14 H100' fill='none' stroke='%23050a0d' stroke-opacity='.28' stroke-width='.8' vector-effect='non-scaling-stroke'/%3E%3C/svg%3E") center top / 100% 18px no-repeat;
}

.octap-folder-pocket::after {
    top: 1px;
    bottom: 0;
    background: linear-gradient(90deg, rgba(255, 255, 255, 0.05), transparent 34%, rgba(255, 255, 255, 0.035));
}

.octap-project-body {
    margin-top: auto;
    padding: 8px 2px 0;
}

.octap-project-name {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--home-text);
    font-size: 13.5px;
    font-weight: 760;
}

.octap-project-meta {
    margin-top: 4px;
    color: var(--home-faint);
    font-size: 11.5px;
}

.octap-project-list-cell,
.octap-library-list-head {
    display: none;
}

.octap-new-card {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 9px;
    color: var(--home-muted);
    overflow: hidden;
}

.octap-new-card::before {
    content: "";
    position: absolute;
    inset: 9px;
    border: 1px solid rgba(255, 255, 255, 0.036);
    border-radius: 8px;
    background: var(--home-thumb);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.032), inset 0 -1px 0 rgba(0, 0, 0, 0.16);
}

body[data-theme="light"] .octap-new-card::before {
    border-color: rgba(18, 24, 33, 0.06);
}

.octap-new-plus,
.octap-new-card span {
    position: relative;
    z-index: 1;
}

.octap-new-plus {
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    border: 1px solid var(--home-line);
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.035);
}

.octap-new-card span {
    font-size: 13.5px;
    font-weight: 760;
}

.octap-project-view {
    padding: 86px 0 90px;
}

.octap-project-toolbar {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 22px;
}

.octap-project-tabs {
    display: flex;
    gap: 24px;
}

.octap-project-tab {
    position: relative;
    padding: 0 0 8px;
    border: 0;
    background: transparent;
    color: var(--home-faint);
    font-size: 16px;
    font-weight: 760;
    cursor: pointer;
}

.octap-project-tab.is-active {
    color: var(--home-text);
}

.octap-project-tab.is-active::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 2px;
    border-radius: 2px;
    background: var(--home-accent);
}

.octap-project-tools {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-left: auto;
}

.octap-search {
    width: 210px;
    height: 36px;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0 13px;
    border: 1px solid var(--home-line);
    border-radius: 10px;
    background: var(--home-surface-soft);
    color: var(--home-faint);
}

.octap-search svg {
    width: 15px;
    height: 15px;
}

.octap-search input {
    width: 100%;
    border: 0;
    outline: none;
    background: transparent;
    color: var(--home-text);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
    font-size: 13px;
    font-weight: 400;
    line-height: 1.55;
    letter-spacing: 0;
}

.octap-search input::placeholder {
    color: var(--home-faint);
}

.octap-tool-button,
.octap-new-project-button {
    height: 36px;
    display: flex;
    align-items: center;
    gap: 7px;
    border: 1px solid var(--home-line);
    border-radius: 10px;
    background: var(--home-surface-soft);
    color: var(--home-muted);
    font-size: 13px;
    font-weight: 650;
    cursor: pointer;
}

.octap-tool-button {
    padding: 0 12px;
}

.octap-view-toggle {
    height: 36px;
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 2px;
    border: 1px solid var(--home-line);
    border-radius: 11px;
    background: var(--home-surface-soft);
}

.octap-view-button {
    width: 32px;
    height: 30px;
    display: grid;
    place-items: center;
    border: 0;
    border-radius: 8px;
    background: transparent;
    color: var(--home-faint);
    cursor: pointer;
}

.octap-view-button:hover {
    color: var(--home-muted);
}

.octap-view-button.is-active {
    color: var(--home-accent);
    background: var(--home-accent-soft);
}

.octap-folder-tool {
    width: 36px;
    justify-content: center;
    padding: 0;
}

.octap-new-project-button {
    padding: 0 15px;
    color: var(--home-accent);
    border-color: var(--home-accent-line);
    background: var(--home-accent-soft);
}

.octap-tool-button:hover,
.octap-new-project-button:hover {
    border-color: var(--home-accent-line);
    color: var(--home-accent);
}

.octap-library-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
    padding-bottom: 70px;
}

.octap-project-folder-bar[hidden] {
    display: none;
}

.octap-project-folder-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin: -8px 0 18px;
    color: var(--home-muted);
}

.octap-project-folder-path {
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 620;
}

.octap-project-folder-path button,
.octap-project-folder-back {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border: 0;
    background: transparent;
    color: var(--home-faint);
    font: inherit;
    cursor: pointer;
}

.octap-project-folder-path button:hover,
.octap-project-folder-back:hover {
    color: var(--home-accent);
}

.octap-project-folder-path strong {
    max-width: 260px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--home-text);
}

.octap-project-folder-path em {
    color: var(--home-faint);
    font-style: normal;
    font-size: 12px;
}

.octap-project-folder-back {
    height: 30px;
    padding: 0 10px;
    border: 1px solid var(--home-line);
    border-radius: 9px;
    background: var(--home-surface-soft);
    font-size: 12px;
    font-weight: 650;
}

.octap-project-card.is-selected {
    border-color: var(--home-accent-line);
    box-shadow: inset 0 0 0 1px rgba(255, 168, 79, 0.24), 0 18px 40px rgba(0, 0, 0, 0.18);
}

.octap-project-card.is-dragging {
    opacity: .45;
}

.octap-project-card.is-drop-before {
    box-shadow: inset 3px 0 0 var(--home-accent), 0 18px 40px rgba(0, 0, 0, 0.18);
}

.octap-project-card.is-drop-after {
    box-shadow: inset -3px 0 0 var(--home-accent), 0 18px 40px rgba(0, 0, 0, 0.18);
}

body[data-octap-project-view="list"] .octap-project-card.is-drop-before {
    box-shadow: inset 0 3px 0 var(--home-accent);
}

body[data-octap-project-view="list"] .octap-project-card.is-drop-after {
    box-shadow: inset 0 -3px 0 var(--home-accent);
}

.octap-project-card.is-folder-drop-target {
    border-color: var(--home-accent-line);
    background: rgba(255, 168, 79, 0.08);
}

.octap-project-card.is-folder-drop-target .octap-project-thumb {
    border-color: rgba(255, 168, 79, 0.32);
}

.octap-project-name-input {
    width: 100%;
    height: 25px;
    min-width: 0;
    padding: 0 7px;
    border: 1px solid var(--home-accent-line);
    border-radius: 7px;
    outline: none;
    background: rgba(5, 8, 11, 0.72);
    color: var(--home-text);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
    font-size: 13px;
    font-weight: 640;
    letter-spacing: 0;
}

.octap-project-empty {
    min-height: 204px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 20px;
    border: 1px dashed var(--home-line-strong);
    border-radius: 12px;
    color: var(--home-faint);
    background: rgba(255, 255, 255, 0.018);
    text-align: center;
}

.octap-project-empty strong {
    color: var(--home-muted);
    font-size: 13px;
}

.octap-project-empty span {
    font-size: 12px;
}

body[data-octap-project-view="list"] .octap-library-list-head {
    display: grid;
    grid-template-columns: 88px minmax(180px, 1.45fr) 120px 150px 190px 170px 38px;
    align-items: center;
    padding: 0 28px;
    height: 54px;
    border: 1px solid var(--home-line);
    border-bottom: 1px solid var(--home-line);
    border-radius: 14px 14px 0 0;
    background: rgba(255, 255, 255, 0.028);
    color: var(--home-faint);
    font-size: 12px;
    font-weight: 600;
}

body[data-octap-project-view="list"] .octap-library-grid {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 0 28px 16px;
    border: 1px solid var(--home-line);
    border-top: 0;
    border-radius: 0 0 14px 14px;
    background: rgba(255, 255, 255, 0.028);
}

body[data-octap-project-view="list"] .octap-library-grid .octap-project-card {
    min-height: 72px;
    display: grid;
    grid-template-columns: 88px minmax(180px, 1.45fr) 120px 150px 190px 170px 38px;
    align-items: center;
    padding: 0;
    border: 0;
    border-bottom: 1px solid var(--home-line);
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

body[data-octap-project-view="list"] .octap-library-grid .octap-project-card:hover {
    background: rgba(255, 255, 255, 0.026);
    transform: none;
}

body[data-octap-project-view="list"] .octap-library-grid .octap-project-thumb {
    width: 72px;
    height: 48px;
    align-self: center;
    border-radius: 10px;
}

body[data-octap-project-view="list"] .octap-library-grid .octap-project-body {
    margin-top: 0;
    padding: 0 12px 0 8px;
    align-self: center;
}

body[data-octap-project-view="list"] .octap-library-grid .octap-project-meta {
    display: none;
}

body[data-octap-project-view="list"] .octap-library-grid .octap-project-list-cell {
    display: flex;
    align-items: center;
    min-width: 0;
    padding-right: 18px;
    color: var(--home-muted);
    font-size: 13px;
    font-weight: 640;
    white-space: nowrap;
}

body[data-octap-project-view="list"] .octap-library-grid .octap-project-list-content,
body[data-octap-project-view="list"] .octap-library-grid .octap-project-list-updated {
    color: var(--home-faint);
}

body[data-octap-project-view="list"] .octap-library-grid .octap-folder-preview {
    --folder-scale: .36;
    left: 50%;
    right: auto;
    bottom: -4px;
    width: 168px;
    transform: translateX(-50%) scale(var(--folder-scale));
}

body[data-octap-project-view="list"] .octap-library-grid .octap-folder-pocket {
    display: none;
}

body[data-octap-project-view="list"] .octap-library-grid .octap-card-menu-button {
    position: static;
    grid-column: 7;
    justify-self: end;
    align-self: center;
    opacity: 1;
    transform: none;
}

body[data-octap-project-view="list"] .octap-library-grid .octap-new-card {
    display: none;
}

body[data-octap-project-view="list"] .octap-library-grid .octap-new-card::before {
    position: static;
    grid-column: 1;
    grid-row: 1;
    width: 72px;
    height: 48px;
    align-self: center;
}

body[data-octap-project-view="list"] .octap-library-grid .octap-new-plus {
    grid-column: 1;
    grid-row: 1;
    justify-self: center;
    width: 34px;
    height: 34px;
}

body[data-octap-project-view="list"] .octap-library-grid .octap-new-card > span:last-child {
    grid-column: 2;
    grid-row: 1;
    justify-self: start;
}

.octap-project-menu {
    position: fixed;
    z-index: 900;
    min-width: 154px;
    padding: 6px;
    border: 1px solid var(--home-line-strong);
    border-radius: 12px;
    background: rgba(17, 21, 27, 0.98);
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.38), inset 0 1px 0 rgba(255, 255, 255, 0.035);
    opacity: 0;
    pointer-events: none;
    transform: translateY(4px);
    transition: opacity .12s ease, transform .12s ease;
    backdrop-filter: blur(14px);
}

.octap-project-menu.is-visible {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

.octap-project-menu-item {
    width: 100%;
    height: 33px;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0 10px;
    border: 0;
    border-radius: 8px;
    background: transparent;
    color: var(--home-muted);
    font-size: 13px;
    font-weight: 620;
    text-align: left;
    cursor: pointer;
}

.octap-project-menu-item svg {
    width: 14px;
    height: 14px;
    color: var(--home-accent);
}

.octap-project-menu-title {
    padding: 6px 10px 7px;
    color: var(--home-faint);
    font-size: 12px;
    font-weight: 700;
}

.octap-project-menu-item:hover {
    background: var(--home-surface-hover);
    color: var(--home-text);
}

.octap-project-menu-item.is-danger {
    color: #e07070;
}

.octap-project-menu-item.is-danger:hover {
    background: rgba(224, 112, 112, 0.1);
    color: #ff8c8c;
}

.octap-project-menu-divider {
    height: 1px;
    margin: 5px -6px;
    background: var(--home-line);
}

.octap-toast {
    position: fixed;
    left: 50%;
    bottom: 80px;
    z-index: 550;
    padding: 11px 18px;
    border: 1px solid var(--home-line-strong);
    border-radius: 12px;
    background: var(--home-surface);
    color: var(--home-text);
    box-shadow: var(--home-shadow);
    font-size: 13px;
    font-weight: 650;
    opacity: 0;
    pointer-events: none;
    transform: translate(-50%, 12px);
    transition: opacity .18s ease, transform .18s ease;
}

.octap-toast.is-visible {
    opacity: 1;
    transform: translate(-50%, 0);
}

body[data-octap-home-route="fullscreen-chat"] .octap-toast {
    left: auto;
    right: 24px;
    bottom: 24px;
    transform: translate(0, 12px);
}

body[data-octap-home-route="fullscreen-chat"] .octap-toast.is-visible {
    transform: translate(0, 0);
}

@media (max-width: 1080px) {
    .octap-project-strip,
    .octap-library-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .octap-project-tools {
        flex-wrap: wrap;
        justify-content: flex-end;
    }
}

@media (max-width: 920px) {
    .octap-home-wrap {
        width: min(100vw - 44px, 720px);
    }

    .octap-home-nav {
        display: none;
    }

    .octap-project-strip,
    .octap-library-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .octap-composer-bar,
    .octap-project-toolbar {
        align-items: stretch;
        flex-direction: column;
    }

    .octap-composer-actions {
        align-self: flex-end;
    }

    .octap-project-tools {
        margin-left: 0;
        justify-content: flex-start;
    }
}

@media (max-width: 560px) {
    .octap-home-topbar {
        padding: 0 14px;
    }

    .octap-home-wordmark,
    .octap-workspace-nav {
        display: none;
    }

    .octap-home-actions {
        gap: 6px;
    }

    .octap-credit-button {
        width: 36px;
        padding: 0;
        justify-content: center;
    }

    .octap-credit-button svg {
        flex: 0 0 auto;
    }

    .octap-credit-button {
        font-size: 0;
    }

    .octap-hero-zone {
        padding-top: 72px;
    }

    .octap-home-wrap {
        width: min(100vw - 28px, 720px);
    }

    .octap-hero-title {
        font-size: 28px;
    }

    .octap-composer {
        --composer-pad-x: 14px;
        --composer-pad-y: 12px;
        --composer-input-collapsed-offset: 52px;
        --composer-input-offset: var(--composer-input-collapsed-offset);
        --composer-media-rail: 106px;
        --composer-media-card-w: 40px;
        --composer-media-card-h: 56px;
        padding: var(--composer-pad-y) var(--composer-pad-x) 14px;
        border-radius: 16px;
    }

    .octap-composer-media-row {
        width: var(--composer-media-rail);
    }

    .octap-composer-left {
        gap: 6px;
    }

    .octap-composer-pill {
        min-width: 0;
        padding: 0 9px;
    }

    .octap-home-mode-menu,
    .octap-home-execution-menu,
    .octap-home-preference-menu {
        left: 14px;
        right: 14px;
        width: auto;
        max-width: calc(100vw - 28px);
        transform: none;
    }

    .octap-home-mode-menu {
        top: var(--home-mode-menu-top, calc(100% - 44px));
        bottom: auto;
    }

    .octap-home-execution-menu {
        top: var(--home-execution-menu-top, calc(100% - 44px));
        bottom: auto;
    }

    .octap-home-preference-menu {
        top: var(--home-preference-menu-top, calc(100% - 44px));
        bottom: auto;
    }

    .octap-composer-model-list .octap-model-dropdown {
        width: min(236px, calc(100vw - 28px));
    }

    .octap-home-menu-row {
        min-width: 0;
    }

    .octap-project-strip,
    .octap-library-grid {
        grid-template-columns: 1fr;
    }
}
