/* Email Therapist Tool (ett) — reusable email-builder component.
   Mirrors the cwt design language but lives under .ett-* so it can be embedded
   anywhere without bleeding into surrounding pages. */

.ett-root {
    --ett-purple:      #776ac8;
    --ett-purple-dark: #5c55da;
    --ett-green:       #52d1a2;
    --ett-green-dark:  #3db88a;
    --ett-text-main:   #1a1a2e;
    --ett-text-body:   #4a4a5e;
    --ett-text-muted:  #9a97b5;
    --ett-border:      #ece9ff;
    --ett-section:     #f7f6ff;
    --ett-white:       #ffffff;

    color: var(--ett-text-main);
    box-sizing: border-box;
}

.ett-root *,
.ett-root *::before,
.ett-root *::after {
    box-sizing: border-box;
}

.ett-root {
    display: block;
    max-width: 520px;
    margin: 0 auto;
}

.ett-card {
    background: var(--ett-white);
    border-radius: 20px;
    border: 1px solid var(--ett-border);
    box-shadow: 0 8px 40px rgba(119,106,200,0.10), 0 2px 8px rgba(119,106,200,0.04);
    overflow: hidden;
}

/* Intro step ─ shown first. Hides the segment progress bar so it does not
   distract from the placeholder preview + single CTA. */
.ett-segs.ett-hidden { display: none; }

.ett-intro-preview {
    background: #fbfaff;
    border: 1.5px dashed var(--ett-border);
    border-radius: 14px;
    padding: 18px 18px;
    margin-bottom: 18px;
    font-size: 0.9rem;
    color: var(--ett-text-body);
    line-height: 1.55;
    white-space: pre-wrap;
    word-break: break-word;
    position: relative;
}
.ett-intro-preview .ett-placeholder {
    display: inline-block;
    background: rgba(119,106,200,0.12);
    color: var(--ett-purple);
    border-radius: 4px;
    padding: 0 4px;
    font-weight: 700;
}

/* Progress segments at top of card */
.ett-segs { display: flex; gap: 5px; padding: 12px 16px 0; width: 100%; }
.ett-seg { flex: 1; height: 4px; border-radius: 2px; background: #ece9ff; transition: background 0.4s ease; }
.ett-seg.done   { background: var(--ett-purple); }
.ett-seg.active { background: rgba(119,106,200,0.35); }

.ett-body { padding: 28px 26px; }
@media (max-width: 480px) { .ett-body { padding: 22px 18px; } }

.ett-step { display: none; }
.ett-step.active { display: block; animation: ett-fadein 0.25s ease; }
@keyframes ett-fadein {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* Back button (top of non-initial steps) */
.ett-back-btn {
    background: none; border: none; cursor: pointer;
    font-size: 0.82rem; font-weight: 700;
    color: var(--ett-text-muted);
    display: inline-flex; align-items: center; gap: 5px;
    padding: 0; margin-bottom: 18px;
    transition: color 0.15s;
}
.ett-back-btn:hover { color: var(--ett-purple); }

/* Headings */
.ett-eyebrow {
    font-size: 0.7rem; font-weight: 800; letter-spacing: 0.1em;
    color: var(--ett-purple); margin-bottom: 10px;
}
.ett-h2 {
    font-size: 1.2rem; font-weight: 900; color: var(--ett-text-main);
    margin: 0 0 6px;
}
.ett-sub {
    font-size: 0.92rem; color: var(--ett-text-body); line-height: 1.55;
    margin: 0 0 18px;
}

/* Form labels and inputs */
.ett-label {
    display: block; font-size: 0.8rem; font-weight: 700;
    color: var(--ett-text-body); margin-bottom: 7px;
}
.ett-input {
    width: 100%; padding: 12px 14px;
    border: 1.5px solid var(--ett-border); border-radius: 12px;
    font-size: 0.93rem; color: var(--ett-text-main); background: white;
    transition: border-color 0.18s, box-shadow 0.18s;
    margin-bottom: 16px;
    font-family: inherit;
    -webkit-appearance: none; appearance: none;
}
.ett-input:focus {
    outline: none; border-color: var(--ett-purple);
    box-shadow: 0 0 0 3px rgba(119,106,200,0.12);
}

/* Chip groups */
.ett-chips {
    display: flex; flex-wrap: wrap; gap: 6px;
    margin-bottom: 18px;
}
.ett-chip {
    display: inline-flex; align-items: center;
    padding: 8px 14px; border-radius: 100px;
    background: white; border: 1.5px solid var(--ett-border);
    font-size: 0.85rem; font-weight: 700;
    color: var(--ett-text-body); cursor: pointer;
    transition: all 0.14s;
    font-family: inherit;
}
.ett-chip:hover { border-color: var(--ett-purple); color: var(--ett-purple); }
.ett-chip.selected {
    background: linear-gradient(135deg, #f0edff, #e8f9f5);
    border-color: var(--ett-purple);
    color: var(--ett-purple);
}

/* Buttons */
.ett-btn {
    width: 100%; padding: 14px 22px; border-radius: 14px;
    font-size: 0.96rem; font-weight: 800; border: none; cursor: pointer;
    transition: transform 0.15s, box-shadow 0.15s, background 0.15s, opacity 0.2s;
    text-align: center; display: block; text-decoration: none;
    font-family: inherit;
}
.ett-btn:active { transform: scale(0.985); }
.ett-btn:disabled { opacity: 0.4; cursor: not-allowed; transform: none !important; box-shadow: none !important; }

.ett-btn-primary {
    background: var(--ett-purple); color: white;
    box-shadow: 0 6px 20px rgba(119,106,200,0.3);
}
.ett-btn-primary:hover:not(:disabled) {
    background: var(--ett-purple-dark);
    box-shadow: 0 10px 28px rgba(119,106,200,0.4);
    transform: translateY(-1px);
    color: white;
}
.ett-btn-green {
    background: var(--ett-green); color: white;
    box-shadow: 0 6px 20px rgba(82,209,162,0.35);
}
.ett-btn-green:hover:not(:disabled) {
    background: var(--ett-green-dark);
    box-shadow: 0 10px 28px rgba(82,209,162,0.45);
    transform: translateY(-1px);
    color: white;
}
.ett-btn-outline {
    background: transparent; color: var(--ett-purple);
    border: 1.5px solid #ddd8f8; box-shadow: none;
}
.ett-btn-outline:hover:not(:disabled) {
    border-color: var(--ett-purple);
    box-shadow: 0 4px 14px rgba(119,106,200,0.15);
}

.ett-btn-row { display: flex; gap: 10px; }
.ett-btn-row .ett-btn { flex: 1; }

/* Preview card on step 3 */
.ett-preview {
    background: linear-gradient(135deg, #f7f6ff 0%, #f0fbf7 100%);
    border: 1px solid var(--ett-border);
    border-radius: 14px;
    padding: 18px 18px;
    margin-bottom: 16px;
    font-size: 0.92rem;
    color: var(--ett-text-main);
    line-height: 1.55;
    white-space: pre-wrap;
    word-break: break-word;
}
.ett-preview-subject {
    font-size: 0.78rem; font-weight: 700; color: var(--ett-text-muted);
    margin-bottom: 4px;
}
.ett-preview-subject-val {
    font-size: 0.95rem; font-weight: 800; color: var(--ett-text-main);
    margin-bottom: 12px; padding-bottom: 12px;
    border-bottom: 1px dashed var(--ett-border);
}

/* Copied toast */
.ett-toast {
    display: inline-block;
    margin-top: 10px;
    font-size: 0.82rem; font-weight: 700; color: var(--ett-green-dark);
    opacity: 0;
    transition: opacity 0.25s ease;
}
.ett-toast.show { opacity: 1; }

/* Edit-step link list under preview */
.ett-edit-links {
    display: flex; flex-wrap: wrap; gap: 14px;
    margin-top: 14px; justify-content: center;
}
.ett-edit-link {
    background: none; border: none; cursor: pointer;
    color: var(--ett-purple); font-weight: 700;
    font-size: 0.85rem; padding: 0;
    text-decoration: underline;
    font-family: inherit;
}
.ett-edit-link:hover { color: var(--ett-purple-dark); }

.ett-note {
    font-size: 0.78rem; color: var(--ett-text-muted);
    text-align: center; margin-top: 12px;
}

.ett-field-err {
    font-size: 0.78rem; color: #c33;
    margin-top: -10px; margin-bottom: 14px;
    display: none;
}
.ett-field-err.show { display: block; }
