/* Studio page — bento grid + AI section + editions list. */

.hero-studio .hero-note {
    margin-top: 10px;
    color: var(--text-faint);
    font-size: 13px;
    font-style: italic;
}

/* ── Bento ───────────────────────────────────────────────────────── */
.bento {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 16px;
}
.bento-item {
    grid-column: span 12;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 28px 26px;
    transition: transform 0.25s var(--ease), border-color 0.25s var(--ease);
}
.bento-item:hover {
    border-color: rgba(88,166,255,0.3);
    transform: translateY(-2px);
}
.bento-6  { grid-column: span 6; }
.bento-12 { grid-column: span 12; }
.bento-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
}
.bento-header > .material-symbols-rounded {
    color: var(--accent);
    font-size: 26px;
}
.bento-item h3 {
    font-family: var(--font-display);
    font-size: 19px;
    font-weight: 600;
    margin: 0;
}
.bento-item p {
    color: var(--text-dim);
    font-size: 15px;
    line-height: 1.6;
    margin: 0 0 18px;
}
.bento-item p:last-child {
    margin-bottom: 0;
}
@media (max-width: 800px) {
    .bento-6, .bento-12 { grid-column: span 12; }
}

/* Bento showcase media (from legacy Ollie IDE / canda assets) */
.studio-media-wrap {
    position: relative;
    width: 100%;
    margin-top: 20px;
    border-radius: var(--radius-md);
    overflow: hidden;
    border: 1px solid var(--border);
    background: var(--bg-alt);
    box-shadow: var(--shadow-card);
    aspect-ratio: 16 / 11;
}
.section.dark .studio-media-wrap {
    border-color: var(--border);
}
.studio-media-content {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: left top;
}
.studio-media-wrap--video .studio-media-content {
    pointer-events: none;
}
.studio-media-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
    margin-top: 20px;
}
.studio-media-row .studio-media-wrap {
    margin-top: 0;
    aspect-ratio: 4 / 3;
}
@media (max-width: 800px) {
    .studio-media-row {
        grid-template-columns: 1fr;
    }
}

/* AI section: voice demo clip */
.studio-ai-demo {
    display: grid;
    grid-template-columns: 1fr 1.15fr;
    gap: 36px;
    align-items: center;
    margin-top: 48px;
    padding-top: 40px;
    border-top: 1px solid var(--border);
}
.studio-ai-demo-copy .section-label {
    margin-bottom: 10px;
}
.studio-ai-demo-title {
    font-family: var(--font-display);
    font-size: clamp(22px, 2.5vw, 28px);
    font-weight: 700;
    margin: 0 0 12px;
    letter-spacing: -0.02em;
}
.studio-ai-demo-body {
    margin: 0;
    color: var(--text-dim);
    font-size: 15px;
    line-height: 1.65;
}
.studio-ai-demo-video {
    aspect-ratio: 16 / 10;
    margin-top: 0;
    background: var(--bg-alt);
}
.studio-ai-demo-video .studio-media-content {
    pointer-events: auto;
    object-fit: contain;
    object-position: center;
}
@media (max-width: 900px) {
    .studio-ai-demo {
        grid-template-columns: 1fr;
    }
}

/* Ecosystem architecture */
.section-studio-ecosystem .studio-ecosystem-body {
    max-width: 720px;
    margin: 0 auto 28px;
    text-align: center;
    color: var(--text-dim);
    font-size: 15px;
    line-height: 1.65;
}
.studio-ecosystem-figure {
    max-width: 1000px;
    margin: 0 auto;
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid var(--border);
    background: var(--bg-card);
    box-shadow: var(--shadow-card);
}
.studio-ecosystem-figure img {
    display: block;
    width: 100%;
    height: auto;
}

/* ── Studio AI section ───────────────────────────────────────────── */
.section-studio-ai .ai-bullets {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
@media (max-width: 800px) {
    .section-studio-ai .ai-bullets { grid-template-columns: 1fr; }
}

/* ── Editions ────────────────────────────────────────────────────── */
.edition-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
}
.edition-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 26px 22px;
}
.edition-card h3 {
    font-family: var(--font-display);
    font-size: 22px;
    font-weight: 700;
    margin: 0 0 6px;
    letter-spacing: -0.01em;
}
.edition-tag {
    color: var(--accent);
    font-size: 13px;
    margin: 0 0 18px;
    font-family: var(--font-mono);
}
.edition-card ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
.edition-card li {
    padding: 8px 0;
    border-bottom: 1px solid var(--border);
    color: var(--text-dim);
    font-size: 14px;
    line-height: 1.5;
}
.edition-card li:last-child { border-bottom: 0; }
.edition-purchase-btn {
    margin-top: 18px;
    width: 100%;
    justify-content: center;
}
@media (max-width: 1000px) { .edition-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px)  { .edition-grid { grid-template-columns: 1fr; } }

/* ── Included card ──────────────────────────────────────────────── */
.section-included { background: var(--bg-alt); }
.included-card {
    max-width: 720px;
    margin: 0 auto;
    text-align: center;
    padding: 48px 32px;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background: var(--bg-card);
}
.included-card h2 {
    font-family: var(--font-display);
    font-size: clamp(24px, 3.4vw, 32px);
    margin: 0 0 12px;
    font-weight: 700;
}
.included-card p {
    color: var(--text-dim);
    margin: 0 0 22px;
    font-size: 15.5px;
}
