/* ── /projects/new — "Neuer Quilt-Block"-Page ─────────────────────
 *
 * Four-card start-page. Hero on top, 4 option cards in a grid below,
 * dynamic form appearing under the selected card. Designed to feel
 * like a clean creative kickoff — the cards are the visual stars,
 * the forms are functional under them.
 */

.newblock-page {
    min-height: 100vh;
    background: var(--bg);
}

.newblock-main {
    max-width: 1100px;
    margin: 0 auto;
    padding: 2rem 1.5rem 5rem;
}

/* Hero */
.newblock-hero {
    text-align: center;
    margin: 1.5rem 0 3rem;
}
.newblock-hero-title {
    font-size: clamp(1.8rem, 3.2vw, 2.6rem);
    margin: 0 0 .6rem;
    color: var(--text);
    line-height: 1.15;
}
.newblock-hero-subtitle {
    font-size: 1.05rem;
    color: var(--text-soft, #6b6453);
    max-width: 560px;
    margin: 0 auto;
    line-height: 1.5;
}

/* Card grid */
.newblock-cards {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.25rem;
    margin: 0 0 2rem;
}
@media (max-width: 980px) {
    .newblock-cards { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px) {
    .newblock-cards { grid-template-columns: 1fr; }
}

.newblock-card {
    /* Reset button defaults */
    background: var(--surface, #fff);
    border: 2px solid var(--border, #e5dfd0);
    border-radius: 1rem;
    padding: 1.5rem 1.1rem 1.3rem;
    text-align: center;
    font: inherit;
    color: inherit;
    cursor: pointer;
    transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .9rem;
    min-height: 14rem;
}
.newblock-card:hover {
    transform: translateY(-2px);
    border-color: #b8845c;
    box-shadow: 0 6px 18px rgba(184, 132, 92, .12);
}
.newblock-card:focus-visible {
    outline: none;
    border-color: #b8845c;
    box-shadow: 0 0 0 3px rgba(184, 132, 92, .25);
}
.newblock-card.is-active {
    border-color: #b8845c;
    background: #fffaf3;
    box-shadow: 0 8px 22px rgba(184, 132, 92, .18);
}

.newblock-card-icon {
    width: 88px;
    height: 88px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    /* Background + colour set inline per-option (varies by card) */
}
.newblock-card-icon svg {
    width: 44px;
    height: 44px;
}

.newblock-card-title {
    font-size: 1.05rem;
    margin: 0;
    line-height: 1.25;
    color: var(--text);
}
.newblock-card-subtitle {
    font-size: .85rem;
    color: var(--text-soft, #6b6453);
    line-height: 1.4;
    margin: 0;
}

/* Form slot under the cards */
.newblock-form-slot {
    background: var(--surface, #fff);
    border: 1px solid var(--border, #e5dfd0);
    border-radius: 1.1rem;
    padding: 2rem 1.75rem;
    box-shadow: 0 4px 14px rgba(0, 0, 0, .04);
}

.newblock-form-title {
    margin: 0 0 .4rem;
    font-size: 1.35rem;
    color: var(--text);
}
.newblock-form-intro {
    margin: 0 0 1.5rem;
    color: var(--text-soft, #6b6453);
    line-height: 1.5;
}

.newblock-field {
    border: 0;
    padding: 0;
    margin: 0 0 1.2rem;
    display: block;
}
.newblock-label {
    display: block;
    font-weight: 600;
    font-size: .92rem;
    margin-bottom: .5rem;
    color: var(--text);
}
.newblock-field input[type="text"],
.newblock-field input[type="number"],
.newblock-field textarea {
    width: 100%;
    padding: .75rem .9rem;
    border: 1px solid var(--border, #d8d1c1);
    border-radius: .65rem;
    font: inherit;
    font-size: 1rem;
    background: #fff;
    color: var(--text);
    box-sizing: border-box;
    transition: border-color 120ms ease, box-shadow 120ms ease;
}
.newblock-field textarea {
    resize: vertical;
    min-height: 4.5rem;
    line-height: 1.45;
}
.newblock-field input:focus,
.newblock-field textarea:focus {
    outline: none;
    border-color: #b8845c;
    box-shadow: 0 0 0 3px rgba(184, 132, 92, .15);
}

/* Preset pill row (same look as the old modal so users feel at home) */
.newblock-preset-row {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin: 0 0 .8rem;
}
.newblock-preset {
    background: #fff;
    border: 1.5px solid var(--border, #d8d1c1);
    border-radius: 999px;
    padding: .45rem .95rem;
    font: inherit;
    font-size: .9rem;
    cursor: pointer;
    color: var(--text);
    transition: border-color 120ms ease, background 120ms ease;
}
.newblock-preset:hover { border-color: #b8845c; }
.newblock-preset.is-active {
    border-color: #b8845c;
    background: #fffaf3;
    font-weight: 600;
}

.newblock-size-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .9rem;
}
@media (max-width: 520px) {
    .newblock-size-row { grid-template-columns: 1fr; }
}
.newblock-size-input {
    display: flex;
    flex-direction: column;
    gap: .4rem;
    font-weight: 500;
    font-size: .9rem;
    color: var(--text);
}

.newblock-hint {
    margin: 0 0 1rem;
    color: var(--text-soft, #8a8270);
    font-size: .86rem;
    line-height: 1.5;
}

.newblock-error {
    color: #b32d20;
    font-size: .92rem;
    margin: 0 0 .8rem;
    min-height: 1.2rem;
}
.newblock-status-info {
    color: #4a4234;
    background: #ece6d5;
    padding: .6rem .8rem;
    border-radius: .55rem;
}
.newblock-status-success {
    color: #2c4413;
    background: #e0eed4;
    padding: .6rem .8rem;
    border-radius: .55rem;
}
.newblock-status-error {
    color: #6b2418;
    background: #f6dcd6;
    padding: .6rem .8rem;
    border-radius: .55rem;
}

.newblock-form-actions {
    display: flex;
    justify-content: flex-end;
    margin-top: 1.2rem;
}
@media (max-width: 520px) {
    .newblock-form-actions .btn { width: 100%; }
}

.btn.is-busy {
    opacity: .75;
    cursor: progress;
    animation: nb-pulse 1.4s ease-in-out infinite;
}
@keyframes nb-pulse {
    0%, 100% { transform: translateY(0); }
    50%      { transform: translateY(-1px); }
}
