/* ============================================================
   SHARED WIDGET STYLES
   Newsletter signup, Lead magnet capture, Form utilities
   Uses the site's CSS variables (--accent, --bg, --text, etc.)
   ============================================================ */

/* Newsletter widget */
.newsletter-widget {
    display: flex; flex-direction: column; gap: 1rem;
    padding: 2rem; background: var(--bg-card); border: 1px solid var(--border);
    border-radius: 14px;
}
.newsletter-title {
    font-family: var(--font-display); font-size: 1.15rem; font-weight: 700;
    letter-spacing: -0.01em; margin-bottom: 0.3rem;
}
.newsletter-subtitle { font-size: 0.88rem; color: var(--text-muted); line-height: 1.6; }
.newsletter-form {
    display: flex; gap: 0.5rem; width: 100%;
}
.newsletter-input {
    flex: 1; padding: 0.75rem 1rem; border-radius: 8px;
    border: 1px solid var(--border); background: var(--bg-secondary); color: var(--text);
    font-family: var(--font-body); font-size: 0.9rem; transition: border-color 0.2s;
}
.newsletter-input:focus { outline: none; border-color: var(--accent); }
.newsletter-btn {
    padding: 0.75rem 1.2rem; border-radius: 8px; border: none;
    background: var(--accent); color: #0A0A0F; font-weight: 600; font-size: 0.9rem;
    cursor: pointer; transition: transform 0.15s, box-shadow 0.2s;
}
.newsletter-btn:hover:not(:disabled) { transform: translateY(-1px); box-shadow: 0 4px 16px var(--accent-glow); }
.newsletter-btn:disabled { opacity: 0.6; cursor: not-allowed; }
.newsletter-status { font-size: 0.82rem; min-height: 1.2em; }
.newsletter-status.success { color: var(--success, #4ADE80); }
.newsletter-status.error { color: var(--danger, #FF5A5A); }
@media (max-width: 520px) {
    .newsletter-form { flex-direction: column; }
}

/* Lead magnet widget */
.lead-magnet-widget {
    display: grid; grid-template-columns: 1.1fr 1fr; gap: 2.5rem;
    padding: 2.5rem; background: var(--bg-card); border: 1px solid var(--border);
    border-radius: 18px; align-items: center;
    background: linear-gradient(135deg, var(--bg-card) 0%, color-mix(in srgb, var(--accent) 8%, var(--bg-card)) 100%);
}
.lead-magnet-badge {
    display: inline-block; padding: 0.3rem 0.75rem;
    background: var(--accent); color: #0A0A0F; font-size: 0.7rem; font-weight: 700;
    letter-spacing: 0.08em; text-transform: uppercase; border-radius: 20px;
    margin-bottom: 1rem;
}
.lead-magnet-title {
    font-family: var(--font-display); font-size: clamp(1.4rem, 3vw, 1.9rem);
    font-weight: 800; letter-spacing: -0.02em; line-height: 1.2; margin-bottom: 0.8rem;
}
.lead-magnet-subtitle { font-size: 0.95rem; color: var(--text-muted); margin-bottom: 1.2rem; line-height: 1.65; }
.lead-magnet-bullets {
    list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.5rem;
}
.lead-magnet-bullets li {
    font-size: 0.88rem; color: var(--text); padding-left: 1.5rem; position: relative;
}
.lead-magnet-bullets li::before {
    content: '✓'; position: absolute; left: 0; top: 0; color: var(--accent); font-weight: 700;
}
.lead-magnet-form {
    display: flex; flex-direction: column; gap: 0.75rem;
    padding: 1.5rem; background: var(--bg); border: 1px solid var(--border); border-radius: 12px;
}
.lead-magnet-description { font-size: 0.85rem; color: var(--text-muted); margin-bottom: 0.3rem; }
.lead-magnet-input {
    padding: 0.75rem 1rem; border-radius: 8px;
    border: 1px solid var(--border); background: var(--bg-secondary); color: var(--text);
    font-family: var(--font-body); font-size: 0.9rem; width: 100%;
}
.lead-magnet-input:focus { outline: none; border-color: var(--accent); }
.lead-magnet-btn {
    padding: 0.85rem 1rem; border-radius: 8px; border: none;
    background: var(--accent); color: #0A0A0F; font-weight: 700; font-size: 0.92rem;
    cursor: pointer; margin-top: 0.4rem; transition: transform 0.15s, box-shadow 0.2s;
}
.lead-magnet-btn:hover:not(:disabled) { transform: translateY(-1px); box-shadow: 0 6px 20px var(--accent-glow); }
.lead-magnet-btn:disabled { opacity: 0.6; cursor: not-allowed; }
.lead-magnet-status { font-size: 0.83rem; min-height: 1.2em; line-height: 1.5; }
.lead-magnet-status.success { color: var(--success, #4ADE80); }
.lead-magnet-status.error { color: var(--danger, #FF5A5A); }
.lead-magnet-fineprint { font-size: 0.72rem; color: var(--text-muted); margin-top: 0.2rem; }
@media (max-width: 780px) {
    .lead-magnet-widget { grid-template-columns: 1fr; gap: 1.5rem; padding: 1.8rem; }
}

/* Contact form (used on contact.html) */
.contact-form {
    display: flex; flex-direction: column; gap: 1.1rem;
    padding: 2rem; background: var(--bg-card); border: 1px solid var(--border);
    border-radius: 16px;
}
.contact-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 680px) { .contact-form-row { grid-template-columns: 1fr; } }
.contact-form label { font-size: 0.82rem; font-weight: 600; color: var(--text); margin-bottom: 0.3rem; display: block; }
.contact-form input, .contact-form select, .contact-form textarea {
    width: 100%; padding: 0.75rem 1rem; border-radius: 8px;
    border: 1px solid var(--border); background: var(--bg-secondary); color: var(--text);
    font-family: var(--font-body); font-size: 0.92rem; transition: border-color 0.2s;
}
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus {
    outline: none; border-color: var(--accent);
}
.contact-form textarea { resize: vertical; min-height: 140px; line-height: 1.6; }
.contact-form-submit {
    padding: 0.95rem 1.5rem; border-radius: 10px; border: none;
    background: var(--accent); color: #0A0A0F; font-weight: 700; font-size: 0.95rem;
    cursor: pointer; transition: transform 0.15s, box-shadow 0.2s;
    display: inline-flex; align-items: center; gap: 0.5rem; justify-content: center;
    margin-top: 0.3rem;
}
.contact-form-submit:hover:not(:disabled) { transform: translateY(-1px); box-shadow: 0 8px 24px var(--accent-glow); }
.contact-form-submit:disabled { opacity: 0.6; cursor: not-allowed; }
.contact-form-status { font-size: 0.88rem; min-height: 1.5em; line-height: 1.6; padding: 0.5rem 0; }
.contact-form-status.success { color: var(--success, #4ADE80); }
.contact-form-status.error { color: var(--danger, #FF5A5A); }
