/* fancy-text-generator (RT-FUN-088) — tool styles.
   Card system in /assets/css/share-card.css (loaded by the widget). */

.ft-tool { display: flex; flex-direction: column; gap: 16px; }

.ft-input {
    font: inherit;
    font-size: 1.15rem;
    width: 100%;
    padding: 14px 16px;
    border: 1.5px solid var(--border, #ebebeb);
    border-radius: 12px;
    background: var(--card-bg, #fff);
    color: var(--t1, #1a1814);
    resize: vertical;
    min-height: 56px;
}
.ft-input:focus-visible {
    outline: 3px solid var(--rt-accent, #e8622a);
    outline-offset: 1px;
    border-color: var(--rt-accent, #e8622a);
}

.ft-list { display: flex; flex-direction: column; gap: 8px; }
.ft-row {
    display: grid;
    grid-template-columns: 120px 1fr auto;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    border: 1px solid var(--border, #ebebeb);
    border-radius: 10px;
    background: var(--card-bg, #fff);
}
.ft-style-name { font-size: 0.78rem; font-weight: 600; color: var(--t2, #6b6760); }
.ft-out {
    font-size: 1.15rem;
    line-height: 1.5;
    color: var(--t1, #1a1814);
    overflow-wrap: anywhere;
    word-break: break-word;
}
.ft-copy {
    font: inherit;
    font-weight: 600;
    font-size: 0.82rem;
    padding: 7px 14px;
    border-radius: 999px;
    border: 1.5px solid var(--border, #ebebeb);
    background: var(--bg, #f7f6f3);
    color: var(--t1, #1a1814);
    cursor: pointer;
    white-space: nowrap;
}
.ft-copy:hover { border-color: var(--rt-accent, #e8622a); }
.ft-copy:focus-visible { outline: 3px solid var(--rt-accent, #e8622a); outline-offset: 2px; }

.ft-empty { color: var(--t2, #6b6760); text-align: center; padding: 30px 10px; }

@media (max-width: 560px) {
    .ft-row { grid-template-columns: 1fr auto; }
    .ft-style-name { grid-column: 1 / -1; }
}

/* Share-card block */
.ft-card-block { display: flex; flex-direction: column; gap: 12px; margin-top: 8px; }
.ft-card-controls { display: flex; flex-wrap: wrap; align-items: flex-end; gap: 12px; }
.ft-field { display: flex; flex-direction: column; gap: 6px; font-size: 0.85rem; font-weight: 600; color: var(--t2, #6b6760); }
.ft-field select {
    font: inherit; font-weight: 500; padding: 9px 12px;
    border: 1.5px solid var(--border, #ebebeb); border-radius: 8px;
    background: var(--card-bg, #fff); color: var(--t1, #1a1814); min-width: 180px;
}
.ft-note { font-size: 0.85rem; color: var(--t2, #6b6760); min-height: 1.1em; margin: 0; }
.ft-stage { background: #0c1827; border-radius: 16px; }

/* Card contents (in 1080×1350 coords) */
.ft-card { align-items: center; text-align: center; justify-content: center; }
.ft-card .sc-eyebrow { font-size: 28px; letter-spacing: 8px; }
.ft-card-text {
    font-size: 96px;
    line-height: 1.25;
    font-weight: 600;
    margin: 30px 0;
    max-width: 920px;
    overflow-wrap: anywhere;
    word-break: break-word;
}
.ft-card .sc-footer { width: 100%; }
