/* Federal Apostille Partner Portal — front-end styles. Self-contained, scoped to .fapp-portal. */
.fapp-portal { --navy:#0b1f3a; --orange:#e67e22; --line:#e3e8ef; --muted:#6b7280; --good:#0f7b46; --danger:#c0392b;
	max-width:880px; margin:0 auto; color:#1f2937; font-size:16px; line-height:1.5; }
.fapp-portal *, .fapp-portal *::before, .fapp-portal *::after { box-sizing:border-box; }
.fapp-loading { padding:40px; text-align:center; color:var(--muted); }

.fapp-card { background:#fff; border:1px solid var(--line); border-radius:12px; padding:24px; margin:0 0 18px;
	box-shadow:0 1px 3px rgba(16,24,40,.05); }
.fapp-card h2 { margin:0 0 8px; font-size:20px; color:var(--navy); }
.fapp-card h3 { margin:18px 0 8px; font-size:15px; color:var(--navy); }

.fapp-input { width:100%; padding:11px 12px; border:1px solid #cbd5e1; border-radius:8px; font-size:15px; background:#fff; }
.fapp-input:focus { outline:none; border-color:var(--orange); box-shadow:0 0 0 3px rgba(230,126,34,.15); }
.fapp-portal label { display:block; font-size:13px; font-weight:600; color:#374151; margin-bottom:12px; }
.fapp-portal label .fapp-input, .fapp-portal label select, .fapp-portal label textarea { margin-top:5px; font-weight:400; }
.fapp-grid { display:grid; grid-template-columns:1fr 1fr; gap:0 16px; }
@media (max-width:560px){ .fapp-grid { grid-template-columns:1fr; } }

.fapp-btn { display:inline-block; padding:11px 18px; border:0; border-radius:8px; font-size:15px; font-weight:600; cursor:pointer; }
.fapp-btn-primary { background:var(--orange); color:#fff; }
.fapp-btn-primary:hover { background:#d56f12; }
.fapp-btn-secondary { background:#eef2f7; color:var(--navy); }
.fapp-btn-ghost { background:transparent; color:var(--muted); }
.fapp-btn-block { display:block; width:100%; margin-top:10px; }
.fapp-btn:disabled { opacity:.5; cursor:not-allowed; }
.fapp-link-danger { background:none; border:0; color:var(--danger); cursor:pointer; font-size:13px; }

.fapp-unlock { max-width:520px; margin:32px auto; text-align:center; }
.fapp-unlock-form, .fapp-track-form { display:flex; gap:10px; flex-wrap:wrap; justify-content:center; margin:16px 0; }
.fapp-unlock-form .fapp-input, .fapp-track-form .fapp-input { flex:1 1 240px; text-align:center; letter-spacing:.5px; }
.fapp-code { text-transform:uppercase; }
.fapp-muted { color:var(--muted); font-size:13px; }
.fapp-good { color:var(--good); font-size:13px; }

.fapp-partner-bar { display:flex; justify-content:space-between; align-items:center; gap:12px;
	background:var(--navy); color:#fff; padding:12px 18px; border-radius:10px; margin-bottom:14px; flex-wrap:wrap; }
.fapp-partner-bar .fapp-muted { color:#c7d2e3; }
.fapp-referral { font-size:14px; }

.fapp-steps { display:flex; list-style:none; padding:0; margin:0 0 16px; counter-reset:s; gap:8px; }
.fapp-steps li { flex:1; text-align:center; font-size:13px; color:var(--muted); padding:8px 4px; border-bottom:3px solid var(--line); counter-increment:s; }
.fapp-steps li::before { content:counter(s); display:inline-block; width:20px; height:20px; line-height:20px; border-radius:50%;
	background:var(--line); color:#fff; margin-right:6px; font-weight:700; }
.fapp-steps li.is-active { color:var(--navy); border-color:var(--orange); font-weight:700; }
.fapp-steps li.is-active::before { background:var(--orange); }
.fapp-steps li.is-done::before { background:var(--good); content:"✓"; }

.fapp-cart-item { display:flex; justify-content:space-between; align-items:center; gap:12px; padding:12px 0; border-bottom:1px solid var(--line); }
.fapp-summary, .fapp-table { width:100%; border-collapse:collapse; margin-top:12px; font-size:14px; }
.fapp-summary td { padding:6px 0; }
.fapp-summary td:last-child { text-align:right; }
.fapp-summary-total td { border-top:1px solid var(--line); padding-top:10px; font-weight:700; font-size:16px; color:var(--navy); }
.fapp-table th, .fapp-table td { text-align:left; padding:8px; border-bottom:1px solid var(--line); }

.fapp-actions { display:flex; justify-content:space-between; gap:10px; margin-top:18px; }
.fapp-file-wrap input[type=file] { display:block; margin-top:6px; font-weight:400; }

.fapp-review-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
@media (max-width:640px){ .fapp-review-grid { grid-template-columns:1fr; } }
.fapp-doclist, .fapp-track-list { padding-left:18px; }
.fapp-square-card { border:1px solid #cbd5e1; border-radius:8px; padding:6px; margin:14px 0 6px; min-height:48px; }
.fapp-secure { text-align:center; margin-top:8px; }

.fapp-flash { padding:11px 14px; border-radius:8px; margin-bottom:12px; font-size:14px; }
.fapp-flash-error { background:#fdecea; color:var(--danger); border:1px solid #f5c6cb; }
.fapp-flash-success { background:#e7f6ee; color:var(--good); border:1px solid #b7e4c7; }

.fapp-pill { display:inline-block; background:#eef2f7; color:var(--navy); padding:3px 10px; border-radius:999px; font-size:12px; font-weight:600; }
.fapp-pill-lg { font-size:14px; padding:6px 14px; background:var(--orange); color:#fff; }

.fapp-confirm { text-align:center; }
.fapp-check { width:54px; height:54px; line-height:54px; margin:0 auto 10px; border-radius:50%; background:var(--good); color:#fff; font-size:28px; }
.fapp-mailin { text-align:left; background:#fff7ec; border:1px solid #f0c987; border-radius:10px; padding:16px; margin:16px 0; }

.fapp-track-head { display:flex; justify-content:space-between; align-items:center; margin:14px 0; }
.fapp-track-list { list-style:none; padding:0; }
.fapp-track-step { display:flex; gap:12px; padding:0 0 16px; position:relative; }
.fapp-track-dot { width:12px; height:12px; border-radius:50%; background:var(--orange); margin-top:5px; flex:0 0 auto; }
.fapp-track-step:not(:last-child)::after { content:""; position:absolute; left:5px; top:16px; bottom:0; width:2px; background:var(--line); }

/* ---- Unified hub: topbar + tabs ---- */
.fapp-shell { }
.fapp-topbar { display:flex; justify-content:space-between; align-items:center; gap:12px; flex-wrap:wrap;
	background:var(--navy); color:#fff; padding:12px 18px; border-radius:12px 12px 0 0; }
.fapp-topbar-id .fapp-muted { color:#c7d2e3; }
.fapp-topbar-right { display:flex; align-items:center; gap:14px; }
.fapp-topbar-right .fapp-referral { font-size:14px; }
.fapp-link { background:none; border:0; color:inherit; cursor:pointer; font-size:14px; text-decoration:underline; padding:0; }
.fapp-tabs { display:flex; gap:0; background:#0e2647; border-radius:0; overflow:hidden; }
.fapp-tab { flex:1; background:#0e2647; color:#c7d2e3; border:0; padding:14px 10px; font-size:15px; font-weight:600; cursor:pointer; border-bottom:3px solid transparent; }
.fapp-tab:hover { color:#fff; }
.fapp-tab.is-active { background:#fff; color:var(--navy); border-bottom-color:var(--orange); }
#fapp-body { background:transparent; padding-top:18px; }

.fapp-estimate-bar { display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap;
	background:#fff7ec; border:1px solid #f0c987; color:#7a4a12; padding:10px 16px; border-radius:8px; margin-bottom:14px; font-size:14px; }

.fapp-actions-center { justify-content:center; flex-wrap:wrap; }

/* ---- Orders tab ---- */
.fapp-orders-head { display:flex; justify-content:space-between; align-items:baseline; gap:12px; flex-wrap:wrap; }
.fapp-referral-box { background:#e7f6ee; color:#0f7b46; padding:6px 12px; border-radius:999px; font-size:14px; }
.fapp-order-row { border:1px solid var(--line); border-radius:10px; padding:0; margin-bottom:10px; overflow:hidden; }
.fapp-order-main { display:flex; align-items:center; gap:12px; padding:14px 16px; }
.fapp-order-num { flex:1; min-width:0; }
.fapp-order-main .fapp-pill { white-space:nowrap; }
.fapp-track-toggle { color:var(--orange); white-space:nowrap; }
.fapp-order-track { padding:6px 16px 14px; border-top:1px dashed var(--line); background:#fafbfc; }

/* ---- Translation add-on + misc ---- */
.fapp-addon { background:#f7f9fc; border:1px solid var(--line); border-radius:10px; padding:14px 16px; margin:4px 0 14px; }
.fapp-tag { display:inline-block; background:#eef2f7; color:var(--navy); padding:1px 8px; border-radius:6px; font-size:12px; font-weight:600; }
.fapp-cart-item .fapp-tag { margin-left:2px; }
.fapp-pay-error { background:#fdecea; color:var(--danger); border:1px solid #f5c6cb; border-radius:8px; padding:12px 14px; margin:12px 0; font-size:14px; }
.fapp-pay-error .fapp-muted { color:#9b5c57; }

/* ---- Document requirements / disclosures ---- */
.fapp-disc { background:#fff; border:1px solid var(--line); border-radius:10px; padding:12px 16px; margin:0 0 14px; }
.fapp-disc > summary { cursor:pointer; font-weight:600; color:var(--navy); list-style:none; }
.fapp-disc > summary::-webkit-details-marker { display:none; }
.fapp-disc[open] > summary { margin-bottom:10px; border-bottom:1px solid var(--line); padding-bottom:8px; }
.fapp-disc-table { width:100%; border-collapse:collapse; font-size:13px; }
.fapp-disc-table th, .fapp-disc-table td { text-align:left; padding:7px 8px; border-bottom:1px solid var(--line); vertical-align:top; }
.fapp-disc-table th { color:var(--muted); font-weight:600; }
.fapp-req { background:#f0f6fc; border-left:4px solid var(--navy); border-radius:6px; padding:10px 14px; margin:0 0 14px; font-size:13.5px; }
.fapp-tag-mail { background:#fff0e6; color:#a8551a; }
.fapp-tag-up { background:#e7f6ee; color:#0f7b46; }
