/* KCG Law PLLC Portal Styles v3 */

/* ── Portal landing ──────────────────────────── */
.kcg-portal-wrap { max-width:760px; margin:0 auto; padding:40px 24px; font-family:Georgia,serif; color:#222; }
.kcg-logo-row { text-align:center; margin-bottom:28px; padding-bottom:20px; border-bottom:3px solid #1a3c6e; }
.kcg-firm-name { font-size:30px; font-weight:700; color:#1a3c6e; letter-spacing:2px; margin:0 0 6px; }
.kcg-portal-sub { font-size:15px; color:#666; margin:0; letter-spacing:1px; }
.kcg-portal-intro { font-size:15px; line-height:1.8; margin-bottom:32px; }
.kcg-agree-list { margin:12px 0; padding-left:22px; }
.kcg-agree-list li { margin-bottom:8px; line-height:1.7; }
.kcg-agree-list li.kcg-important { font-size:17px; font-weight:700; color:#c0392b; background:#fef9e7; padding:10px 14px; border-left:4px solid #c0392b; list-style:none; margin-left:-22px; border-radius:0 4px 4px 0; }
.kcg-portal-buttons { display:flex; flex-direction:column; gap:14px; margin-top:32px; }
.kcg-btn { display:block; text-align:center; padding:18px 28px; border-radius:5px; font-size:17px; font-weight:700; text-decoration:none; transition:all .2s; }
.kcg-btn-co { background:#1a3c6e; color:#fff; border:2px solid #1a3c6e; }
.kcg-btn-co:hover { background:#fff; color:#1a3c6e; }
.kcg-btn-fl { background:#c0392b; color:#fff; border:2px solid #c0392b; }
.kcg-btn-fl:hover { background:#fff; color:#c0392b; }

/* ── Form wrap ───────────────────────────────── */
.kcg-form-wrap { max-width:860px; margin:0 auto; padding:32px 24px; font-family:Arial,sans-serif; color:#222; }

/* Letterhead header — mirrors the official document letterhead */
.kcg-form-header { display:flex; justify-content:space-between; align-items:flex-start; gap:20px; padding:8px 0 26px; font-size:12.5px; line-height:1.55; color:#222; font-family:Georgia,'Times New Roman',serif; }
.kcg-form-header p { margin:0 0 10px; }
.kcg-form-header-left  { flex:1; text-align:left; }
.kcg-form-header-right { flex:1; text-align:right; }
.kcg-form-header-center { flex-shrink:0; text-align:center; }
.kcg-form-logo { width:92px; height:auto; display:block; margin:0 auto; }
.kcg-form-firm { font-size:14px; letter-spacing:.3px; }
.kcg-form-header-right a { color:#1a4ccc; text-decoration:underline; }
.kcg-portal-logo { width:110px; height:auto; display:block; margin:0 auto 14px; }

/* Form title */
.kcg-form-title { text-align:center; font-size:16px; font-weight:700; text-decoration:underline; margin:0 0 8px; color:#000; }
.kcg-form-subtitle { text-align:center; font-style:italic; color:#555; font-size:13px; margin:0 0 24px; }

/* Alerts */
.kcg-alert { padding:12px 18px; border-radius:5px; margin-bottom:18px; font-size:14px; font-weight:600; }
.kcg-alert-error { background:#fdecea; color:#c0392b; border:1px solid #f5b7b1; }
.kcg-alert-info  { background:#eaf4fb; color:#1a6a9e; border:1px solid #aed6f1; }

/* Sections */
.kcg-section { background:#fff; border:1px solid #dde3ea; border-radius:7px; padding:24px 28px; margin-bottom:22px; box-shadow:0 1px 5px rgba(0,0,0,.06); }
.kcg-section-title { font-size:15px; font-weight:700; color:#1a3c6e; margin:0 0 16px; padding-bottom:10px; border-bottom:1px solid #e0e6ed; }
.kcg-underline { text-decoration:underline; }

/* Grid */
.kcg-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:16px 22px; }
.kcg-field { display:flex; flex-direction:column; gap:5px; }
.kcg-field.full { grid-column:1/-1; }
.kcg-field label { font-size:13px; font-weight:600; color:#444; }
.kcg-field input, .kcg-field select { padding:10px 12px; border:1px solid #c8d0da; border-radius:4px; font-size:14px; color:#222; background:#fafbfc; transition:border-color .2s; }
.kcg-field input:focus { border-color:#1a3c6e; outline:none; background:#fff; box-shadow:0 0 0 3px rgba(26,60,110,.1); }
.req { color:#c0392b; }
.opt { color:#888; font-size:11px; font-weight:400; }

/* Agreement scroll */
.kcg-read-note { font-size:13px; color:#666; margin:0 0 10px; }
.kcg-agreement-scroll { max-height:400px; overflow-y:scroll; border:1px solid #c8d0da; border-radius:4px; padding:18px 22px; background:#fafbfc; font-size:13px; line-height:1.75; color:#333; margin-bottom:14px; }
.kcg-agreement-scroll h5 { font-size:13px; font-weight:700; color:#1a3c6e; margin:16px 0 6px; }
.kcg-agreement-scroll p, .kcg-agreement-scroll li { margin:0 0 10px; }
.kcg-agreement-scroll ol { padding-left:22px; margin:0 0 10px; }

/* Agreement checkbox */
.kcg-agree-check { display:flex; align-items:flex-start; gap:10px; font-size:14px; font-weight:600; cursor:pointer; color:#1a3c6e; }
.kcg-agree-check input { margin-top:3px; width:17px; height:17px; flex-shrink:0; cursor:pointer; }

/* Signature field hint */
.kcg-sig-hint { font-size:11px; color:#888; font-style:italic; margin-top:2px; }

/* Submit */
.kcg-submit-row { text-align:center; margin:8px 0; }
#kcg-submit { background:#1a3c6e; color:#fff; border:none; border-radius:5px; padding:16px 52px; font-size:17px; font-weight:700; cursor:pointer; letter-spacing:.4px; transition:background .2s; }
#kcg-submit:hover { background:#0f2546; }
#kcg-submit:disabled { background:#888; cursor:not-allowed; }

/* Success */
.kcg-success { background:#eafaf1; border:2px solid #27ae60; border-radius:8px; padding:36px 40px; text-align:center; margin-top:24px; }
.kcg-success h3 { font-size:24px; color:#1e8449; margin:0 0 14px; }
.kcg-success p { font-size:15px; color:#333; line-height:1.7; margin:0 0 10px; }
.kcg-success a { color:#1a3c6e; font-weight:600; }

@media (max-width:600px) {
    .kcg-grid-2 { grid-template-columns:1fr; }
    .kcg-field.full { grid-column:1; }
    .kcg-form-header { flex-direction:column; align-items:center; text-align:center; }
    .kcg-form-header-right { text-align:center; }
}

/* ── Signature pad ───────────────────────────── */
.kcg-sig-block { display:flex; flex-direction:column; gap:8px; }
.kcg-sig-block label { font-size:13px; font-weight:600; color:#444; }
.kcg-sig-canvas-wrap {
    border: 2px solid #1a3c6e;
    border-radius: 5px;
    background: #fff;
    overflow: hidden;
    cursor: crosshair;
}
.kcg-sig-canvas {
    display: block;
    width: 100%;
    height: 130px;
    touch-action: none;
}
.kcg-sig-clear {
    align-self: flex-start;
    background: none;
    border: 1px solid #bbb;
    border-radius: 4px;
    padding: 5px 14px;
    font-size: 13px;
    cursor: pointer;
    color: #666;
    transition: all .2s;
}
.kcg-sig-clear:hover { border-color:#c0392b; color:#c0392b; }

/* ── Submission confirmation page ─────────────── */
.kcg-confirm-wrap { max-width:720px; margin:0 auto; padding:48px 24px; font-family:Arial,sans-serif; color:#222; }
.kcg-confirm-card { background:#fff; border:1px solid #e0e6ed; border-radius:10px; padding:48px 44px; text-align:center; box-shadow:0 4px 18px rgba(26,60,110,.08); }
.kcg-confirm-icon { width:72px; height:72px; line-height:72px; margin:0 auto 22px; border-radius:50%; background:#27ae60; color:#fff; font-size:38px; font-weight:700; }
.kcg-confirm-card h2 { font-size:26px; color:#1a3c6e; margin:0 0 14px; font-family:Georgia,serif; }
.kcg-confirm-lead { font-size:16px; color:#333; margin:0 0 26px; line-height:1.7; }
.kcg-confirm-steps { background:#f6f9fc; border:1px solid #e0e6ed; border-radius:8px; padding:22px 28px; text-align:left; margin:0 0 24px; }
.kcg-confirm-steps h4 { font-size:15px; color:#1a3c6e; margin:0 0 12px; }
.kcg-confirm-steps ol { margin:0; padding-left:20px; }
.kcg-confirm-steps li { font-size:14px; line-height:1.8; color:#333; }
.kcg-confirm-note { font-size:14px; color:#8a5a00; background:#fff8e6; border:1px solid #f0d490; border-radius:6px; padding:12px 18px; margin:0 0 22px; line-height:1.6; }
.kcg-confirm-contact { font-size:14px; color:#555; margin:0 0 28px; }
.kcg-confirm-contact a { color:#1a3c6e; font-weight:600; }
.kcg-confirm-home { display:inline-block; background:#1a3c6e; color:#fff; border:2px solid #1a3c6e; max-width:280px; margin:0 auto; }
.kcg-confirm-home:hover { background:#fff; color:#1a3c6e; }
