.ct-wrap { display: flex; justify-content: center; padding: 32px 16px 48px; }
.ct-card { max-width: 600px; width: 100%; padding: 36px 36px 32px; }
.ct-ico {
    width: 56px; height: 56px; border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    margin: 0 auto 18px;
}
.ct-ico svg { width: 24px; height: 24px; }
.ct-ico-success { background: var(--color-green-bg); color: var(--color-green-text); }
.ct-card:has(.ct-ico) { text-align: center; }
.ct-title { font-size: var(--text-h4); font-weight: var(--fw-semibold); letter-spacing: -0.02em; color: var(--color-text-primary); margin: 0 0 8px; line-height: 1.2; }
.ct-sub { font-size: var(--text-md); color: var(--color-text-secondary); line-height: 1.55; margin: 0 0 24px; }
.ct-error {
    display: flex; align-items: flex-start; gap: 8px;
    padding: 12px 14px; margin: 0 0 18px;
    background: var(--color-red-bg); color: var(--color-red-text);
    border-radius: var(--radius-sm); font-size: var(--text-base); line-height: 1.5;
}
.ct-error svg { width: 16px; height: 16px; flex-shrink: 0; margin-top: 2px; }
.ct-form { display: flex; flex-direction: column; gap: 14px; }
.ct-form .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.ct-form .form-group { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.ct-form .form-label { font-size: var(--text-base); font-weight: var(--fw-medium); color: var(--color-text-primary); }
.ct-form .form-input,
.ct-form .form-select {
    height: 40px; padding: 0 12px;
    border: 0.5px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-surface);
    font-size: var(--text-md); font-family: inherit;
    color: var(--color-text-primary);
}
.ct-form .form-input:focus,
.ct-form .form-select:focus,
.ct-form textarea.form-input:focus {
    outline: none; border-color: var(--color-accent);
    box-shadow: 0 0 0 3px var(--color-accent-light);
}
.ct-form .ct-message-area { height: auto; min-height: 180px; padding: 12px; line-height: 1.55; resize: vertical; }
.ct-captcha { display: flex; flex-direction: column; align-items: center; gap: 10px; }
.ct-captcha .g-recaptcha,
.ct-captcha .h-captcha { display: inline-block; }
.ct-captcha img { border-radius: var(--radius-sm); border: 0.5px solid var(--color-border); }
.ct-captcha input[type="text"] {
    height: 40px; padding: 0 12px; max-width: 220px;
    border: 0.5px solid var(--color-border); border-radius: var(--radius-sm);
    background: var(--color-surface); font-size: var(--text-md); font-family: inherit;
    color: var(--color-text-primary);
}
.ct-captcha input[type="text"]:focus { outline: none; border-color: var(--color-accent); box-shadow: 0 0 0 3px var(--color-accent-light); }
.ct-submit { width: 100%; height: 44px; font-size: var(--text-md); font-weight: var(--fw-medium); margin-top: 6px; }
@media (max-width: 600px) {
    .ct-card { padding: 28px 24px 24px; }
    .ct-form .form-row { grid-template-columns: 1fr; }
    .ct-title { font-size: var(--text-3xl); }
}
