/* ComplyRUO merchant portal (app.complyruo.com)
 * Same design system as the marketing site (landing/assets/css/styles.css): identical tokens,
 * self-hosted Poppins ExtraLight, glass surfaces, accent #1EC8A2, the same reveal easing. This
 * file adds only the app-specific recipes (forms, stepper, scorecard, copy fields, integration
 * shots) the marketing page does not have.
 */

@font-face{ font-family:"Poppins"; font-style:normal; font-weight:200; font-display:swap;
  src:url("../fonts/poppins-extralight.ttf") format("truetype"); }

:root{
  --bg:#000; --text:#F4F6F7; --muted:#A6B0B6; --faint:#727C83;
  --accent:#1EC8A2; --on-accent:#03130F;
  --line:rgba(255,255,255,0.12); --line-2:rgba(255,255,255,0.18);
  --warn:#E8B339; --danger:#E5644D;
  --font:"Poppins",system-ui,-apple-system,"Segoe UI",sans-serif;
  --font-mono:ui-monospace,SFMono-Regular,"SF Mono",Menlo,Consolas,monospace;
  --ease:cubic-bezier(.16,1,.3,1);
}
*{ box-sizing:border-box; }
html,body{ margin:0; background:var(--bg); }
body{ overflow-x:hidden; font-family:var(--font); color:var(--text); -webkit-font-smoothing:antialiased;
  background:radial-gradient(120% 60% at 50% -10%, rgba(30,200,162,0.07), transparent 60%), #000; min-height:100vh; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3{ letter-spacing:-0.03em; font-weight:600; margin:0; }
::selection{ background:rgba(30,200,162,0.3); }

/* ── App bar (clean fixed header, app-flavored sibling of the landing nav) ────────────── */
.app-nav{ position:fixed; top:0; left:0; right:0; z-index:70; height:62px; display:flex; align-items:center;
  justify-content:space-between; padding:0 22px; background:rgba(10,13,14,0.72);
  backdrop-filter:blur(14px) saturate(115%); -webkit-backdrop-filter:blur(14px) saturate(115%);
  border-bottom:1px solid var(--line); }
.brand{ display:inline-flex; align-items:center; gap:10px; font-weight:600; font-size:19px; letter-spacing:-0.02em; }
.brand .ruo{ color:var(--accent); }
.brand svg{ width:25px; height:25px; }
.app-nav-right{ display:flex; align-items:center; gap:14px; }
.app-nav-email{ font-size:13.5px; color:var(--muted); }
@media (max-width:560px){ .app-nav-email{ display:none; } .app-nav{ padding:0 14px; } }

/* ── Layout ───────────────────────────────────────────────────────────────────────────── */
.app-main{ max-width:1040px; margin:0 auto; padding:104px 24px 96px; }
.app-main.narrow{ max-width:560px; }
.eyebrow{ display:inline-block; font-size:13px; font-weight:500; letter-spacing:0.04em; color:var(--accent); text-transform:uppercase; }
.page-title{ margin:14px 0 0; font-size:clamp(30px,4.4vw,46px); line-height:1.06; }
.page-sub{ margin:16px 0 0; font-size:clamp(16px,1.4vw,18px); color:var(--muted); max-width:60ch; line-height:1.6; }
.row{ display:flex; gap:14px; flex-wrap:wrap; align-items:center; }
.spacer{ height:clamp(28px,4vw,44px); }
.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
@media (max-width:760px){ .grid-2{ grid-template-columns:1fr; } }

/* ── Glass cards ──────────────────────────────────────────────────────────────────────── */
.card{ background:rgba(18,21,22,0.6); border:1px solid var(--line); border-radius:18px; padding:26px 28px;
  backdrop-filter:blur(18px) saturate(125%); -webkit-backdrop-filter:blur(18px) saturate(125%); }
.card + .card{ margin-top:18px; }
.card h2{ font-size:21px; } .card h3{ font-size:17px; }
.card p{ color:var(--muted); line-height:1.6; }
.card-lead{ color:var(--text) !important; }

/* ── Buttons (same names + feel as the landing page) ──────────────────────────────────── */
.btn{ display:inline-flex; align-items:center; gap:8px; font-family:inherit; font-weight:600; font-size:15px; line-height:1;
  padding:15px 26px; border-radius:999px; border:1px solid transparent; cursor:pointer;
  transition:transform .25s var(--ease), background .2s, border-color .2s, color .2s, opacity .2s; }
.btn:active{ transform:translateY(1px); }
.btn[disabled]{ opacity:.45; cursor:not-allowed; }
.btn-white{ background:#fff; color:#0A0D0C; } .btn-white:hover:not([disabled]){ background:#E9EDEF; }
.btn-accent{ background:var(--accent); color:var(--on-accent); } .btn-accent:hover:not([disabled]){ filter:brightness(1.07); }
.btn-ghost{ background:rgba(255,255,255,0.06); color:var(--text); border-color:var(--line-2); }
.btn-ghost:hover:not([disabled]){ border-color:rgba(255,255,255,0.4); }
.btn-sm{ padding:10px 16px; font-size:13.5px; }
.btn-link{ background:none; border:0; color:var(--accent); cursor:pointer; font:inherit; font-size:14px; padding:0; }
.btn-block{ width:100%; justify-content:center; }

/* ── Forms ────────────────────────────────────────────────────────────────────────────── */
.field{ margin-top:18px; } .field:first-child{ margin-top:0; }
.field label{ display:block; font-size:14px; color:var(--text); margin-bottom:8px; }
.field input, .field select{ width:100%; font-family:inherit; font-size:15px; color:var(--text); padding:14px 16px; border-radius:12px;
  background:rgba(255,255,255,0.04); border:1px solid var(--line-2); transition:border-color .2s, background .2s; }
.field input::placeholder{ color:var(--faint); }
.field input:focus, .field select:focus{ outline:none; border-color:var(--accent); background:rgba(255,255,255,0.06); }
.field select{ -webkit-appearance:none; appearance:none; cursor:pointer;
  background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);
  background-position:calc(100% - 20px) center, calc(100% - 15px) center; background-size:5px 5px, 5px 5px; background-repeat:no-repeat; padding-right:40px; }
.field select option{ background:#0c1413; color:var(--text); }
.field .hint{ margin-top:7px; font-size:12.5px; color:var(--faint); }
.checkrow{ display:flex; gap:11px; align-items:flex-start; margin-top:18px; font-size:13.5px; color:var(--muted); line-height:1.5; }
.checkrow input{ width:18px; height:18px; margin-top:1px; accent-color:var(--accent); flex:none; }
.form-error{ margin-top:16px; font-size:13.5px; color:var(--danger); min-height:18px; }
.form-error:empty{ margin:0; min-height:0; }

/* ── Stepper ──────────────────────────────────────────────────────────────────────────── */
.stepper{ list-style:none; margin:0; padding:0; }
.step{ display:flex; gap:16px; padding:0 0 26px; position:relative; }
.step:not(:last-child)::before{ content:""; position:absolute; left:17px; top:36px; bottom:0; width:2px; background:var(--line); }
.step.done:not(:last-child)::before{ background:rgba(30,200,162,0.45); }
.step-num{ flex:none; width:36px; height:36px; border-radius:50%; display:grid; place-items:center; font-size:14px; font-weight:600;
  background:rgba(255,255,255,0.05); border:1px solid var(--line-2); color:var(--muted); }
.step.current .step-num{ border-color:var(--accent); color:var(--accent); box-shadow:0 0 0 4px rgba(30,200,162,0.12); }
.step.done .step-num{ background:var(--accent); border-color:var(--accent); color:var(--on-accent); }
.step-body{ padding-top:6px; flex:1; min-width:0; }
.step-body h3{ font-size:16px; font-weight:600; }
.step.done .step-body h3,.step:not(.current):not(.done) .step-body h3{ color:var(--muted); font-weight:500; }
.step-detail{ margin-top:14px; }
.step.collapsed .step-detail{ display:none; }
.tick{ color:var(--accent); font-size:13px; }

/* ── Status / score ───────────────────────────────────────────────────────────────────── */
.scorecard{ display:flex; align-items:center; gap:26px; flex-wrap:wrap; }
.score-num{ font-size:64px; font-weight:200; line-height:1; }
.score-meta{ display:flex; flex-direction:column; gap:8px; }
.pill{ display:inline-flex; align-items:center; gap:7px; padding:6px 13px; border-radius:999px; font-size:13px; font-weight:500; width:max-content; }
.pill .dot{ width:7px; height:7px; border-radius:50%; }
.band-low_risk{ background:rgba(30,200,162,0.12); color:var(--accent); }
.band-low_risk .dot{ background:var(--accent); box-shadow:0 0 8px var(--accent); }
.band-at_risk{ background:rgba(232,179,57,0.12); color:var(--warn); } .band-at_risk .dot{ background:var(--warn); }
.band-action_needed{ background:rgba(229,100,77,0.12); color:var(--danger); } .band-action_needed .dot{ background:var(--danger); }
.stale-flag{ font-size:12.5px; color:var(--warn); }
.findings{ list-style:none; margin:18px 0 0; padding:0; }
.findings li{ padding:13px 0; border-top:1px solid var(--line); display:flex; gap:12px; align-items:flex-start; font-size:14px; }
.findings li:first-child{ border-top:0; }
.sev{ flex:none; font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.04em; padding:3px 8px; border-radius:6px; }
.sev-high{ background:rgba(229,100,77,0.14); color:var(--danger); }
.sev-medium{ background:rgba(232,179,57,0.14); color:var(--warn); }
.sev-low{ background:rgba(255,255,255,0.08); color:var(--muted); }

/* ── Copy field (account key, secrets) ────────────────────────────────────────────────── */
.keybox{ display:flex; align-items:center; gap:10px; margin-top:14px; padding:12px 12px 12px 16px; border-radius:12px;
  background:rgba(0,0,0,0.35); border:1px solid var(--line-2); }
.keybox code{ font-family:var(--font-mono); font-size:14px; color:var(--accent); overflow:auto; white-space:nowrap; flex:1; }
.keynote{ margin-top:10px; font-size:12.5px; color:var(--warn); }

/* ── Fee disclosure ───────────────────────────────────────────────────────────────────── */
.feebar{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; padding:20px 22px; border-radius:16px;
  background:rgba(30,200,162,0.06); border:1px solid rgba(30,200,162,0.22); }
.feebar .free{ font-size:22px; font-weight:600; }
.feebar .free .accent{ color:var(--accent); }
.feebar .terms{ font-size:13.5px; color:var(--muted); line-height:1.55; }

/* ── Integration guide (video + screenshots) ─────────────────────────────────────────── */
.videoframe{ position:relative; border-radius:16px; overflow:hidden; border:1px solid var(--line-2); aspect-ratio:16/9; background:#06080800; }
.videoframe iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.videoframe .poster{ position:absolute; inset:0; display:grid; place-items:center; text-align:center; gap:14px;
  background:linear-gradient(160deg,#0c1413,#070a0a); color:var(--muted); }
.videoframe .play{ width:64px; height:64px; border-radius:50%; display:grid; place-items:center; margin:0 auto;
  background:rgba(30,200,162,0.16); border:1px solid rgba(30,200,162,0.4); }
.videoframe .play svg{ width:22px; height:22px; fill:var(--accent); margin-left:3px; }
.shots{ display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:18px; }
@media (max-width:680px){ .shots{ grid-template-columns:1fr; } }
.shot{ border-radius:14px; overflow:hidden; border:1px solid var(--line); background:#0A0C0C; }
.shot img{ display:block; width:100%; height:auto; }
.shot .cap{ padding:11px 14px; font-size:12.5px; color:var(--muted); border-top:1px solid var(--line); }
.guide-ol{ margin:6px 0 0; padding-left:20px; color:var(--muted); line-height:1.7; font-size:14.5px; }
.guide-ol code{ font-family:var(--font-mono); font-size:13px; color:var(--text); background:rgba(255,255,255,0.06); padding:1px 6px; border-radius:5px; }

/* ── Banner / toast ───────────────────────────────────────────────────────────────────── */
.banner{ padding:14px 18px; border-radius:12px; font-size:14px; line-height:1.5; }
.banner-info{ background:rgba(30,200,162,0.08); border:1px solid rgba(30,200,162,0.22); color:var(--text); }
.banner-warn{ background:rgba(232,179,57,0.08); border:1px solid rgba(232,179,57,0.25); color:var(--text); }
.toast{ position:fixed; left:50%; bottom:28px; transform:translateX(-50%) translateY(20px); opacity:0;
  background:rgba(18,21,22,0.92); border:1px solid var(--line-2); color:var(--text); padding:12px 20px; border-radius:999px;
  font-size:14px; z-index:90; pointer-events:none; transition:opacity .3s var(--ease), transform .3s var(--ease);
  backdrop-filter:blur(12px); }
.toast.show{ opacity:1; transform:translateX(-50%) translateY(0); }

/* ── Auth split ───────────────────────────────────────────────────────────────────────── */
.auth-tabs{ display:flex; gap:8px; margin-bottom:22px; }
.auth-tabs button{ flex:1; padding:11px; border-radius:999px; border:1px solid var(--line); background:transparent; color:var(--muted);
  font:inherit; font-size:14px; cursor:pointer; transition:all .2s; }
.auth-tabs button.on{ background:rgba(255,255,255,0.08); border-color:var(--line-2); color:var(--text); }

.muted{ color:var(--muted); } .center{ text-align:center; } .mt{ margin-top:16px; } .mt-lg{ margin-top:26px; }
/* Utility classes (so the SPA needs no inline style attributes — keeps CSP style-src tight). */
.pad-lg{ padding:80px 0; } .pad-md{ padding:60px 0; }
.fz-12{ font-size:12px; } .fz-13{ font-size:13px; } .fz-125{ font-size:12.5px; } .fz-135{ font-size:13.5px; }
.mt-3{ margin-top:3px; }
.row-split{ justify-content:space-between; align-items:flex-start; }
.loading{ display:inline-block; width:18px; height:18px; border:2px solid rgba(255,255,255,0.25); border-top-color:var(--text);
  border-radius:50%; animation:spin .7s linear infinite; vertical-align:middle; }
@keyframes spin{ to{ transform:rotate(360deg); } }

.rev{ opacity:0; transform:translateY(20px); transition:opacity .6s var(--ease), transform .6s var(--ease); }
.rev.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){
  .rev{ opacity:1 !important; transform:none !important; transition:none !important; }
  .loading,.toast{ animation:none !important; transition:none !important; }
}
