:root {
  color-scheme: dark;
  --bg: #0b0b0f;
  --card: #15151c;
  --surface: #1c1c24;
  --surface-2: #20212b;
  --border: #2a2a35;
  --border-soft: rgba(255,255,255,.08);
  --gold: #d4af37;
  --gold-hover: #e5c158;
  --text: #fff;
  --muted: #a0a0b0;
  --green: #10b981;
  --red: #e5484d;
  --blue: #3b82f6;
  --shadow: 0 22px 70px rgba(0,0,0,.42);
}

* { box-sizing: border-box; }
html, body { min-height: 100%; }
body {
  margin: 0;
  background:
    radial-gradient(circle at 24% 12%, rgba(212,175,55,.08), transparent 28%),
    radial-gradient(circle at 78% 6%, rgba(59,130,246,.05), transparent 24%),
    var(--bg);
  color: var(--text);
  font-family: Inter, "Segoe UI", Arial, sans-serif;
  letter-spacing: 0;
}
button, input, select, textarea { font: inherit; }
select {
  color-scheme: dark;
  appearance: none;
  background-color: var(--surface);
  color: var(--text);
}
select option,
select optgroup {
  background: var(--surface-2);
  color: var(--text);
}
select option:checked,
select option:hover {
  background: rgba(212,175,55,.22);
  color: var(--text);
}
button { cursor: pointer; }
a { color: var(--gold); }
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--surface); border-radius: 6px; }

.shell { min-height: 100vh; display: grid; grid-template-rows: auto 1fr auto; }
.topbar {
  min-height: 80px;
  padding: 0 clamp(20px, 4vw, 64px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  background: rgba(11,11,15,.82);
  border-bottom: 1px solid var(--border-soft);
  backdrop-filter: blur(14px);
  position: sticky;
  top: 0;
  z-index: 20;
}
.brand, .brand-large {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  border: 0;
  background: transparent;
  color: var(--text);
  font-weight: 800;
  font-size: 20px;
}
.brand-mark {
  width: 36px;
  height: 36px;
  border-radius: 9px;
  display: inline-grid;
  place-items: center;
  background: linear-gradient(180deg, #efce58, var(--gold));
  color: #090909;
  font-weight: 900;
  box-shadow: 0 14px 34px rgba(212,175,55,.2);
}
.top-actions { display: flex; align-items: center; gap: 12px; }
.language-select {
  min-height: 42px;
  padding: 0 34px 0 14px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background:
    linear-gradient(45deg, transparent 50%, var(--muted) 50%) right 18px center / 6px 6px no-repeat,
    linear-gradient(135deg, var(--muted) 50%, transparent 50%) right 12px center / 6px 6px no-repeat,
    var(--surface);
  color: var(--text);
  font-weight: 700;
}
.security-pill, .status-pill, .eyebrow {
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 14px;
  border: 1px solid rgba(212,175,55,.24);
  border-radius: 999px;
  background: rgba(212,175,55,.08);
  color: var(--gold);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}
.eyebrow i {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--gold);
  animation: pulse 1.6s ease-in-out infinite;
}

.app { width: min(1230px, calc(100% - 48px)); margin: 0 auto; padding: 48px 0 70px; }
.footer {
  min-height: 68px;
  padding: 0 clamp(20px, 4vw, 64px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--muted);
  border-top: 1px solid var(--border-soft);
  font-size: 13px;
}
.footer-links { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.footer a { color: var(--muted); text-decoration: none; }
.footer a:hover { color: var(--gold); }

h1, h2, h3, h4, p { margin-top: 0; }
p { color: var(--muted); line-height: 1.6; }

.landing-view { margin: -10px auto 0; position: relative; }
.landing-view::before {
  content: "";
  position: absolute;
  inset: -60px calc(50% - 50vw) auto;
  height: 540px;
  background: radial-gradient(circle at 50% 0%, rgba(212,175,55,.15), rgba(11,11,15,0) 58%);
  pointer-events: none;
}
.gold { color: var(--gold); }
.landing-hero { position: relative; z-index: 1; max-width: 860px; margin: 0 auto 64px; text-align: center; }
.landing-hero h1 { margin: 22px 0; font-size: clamp(42px, 7vw, 76px); line-height: 1.06; letter-spacing: 0; }
.landing-hero h1 span {
  background: linear-gradient(135deg, #fff 0%, var(--gold) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.landing-hero p { max-width: 700px; margin: 0 auto 32px; font-size: 19px; }
.landing-actions, .landing-checks { display: flex; align-items: center; justify-content: center; gap: 16px; flex-wrap: wrap; }
.landing-checks { margin-top: 20px; color: var(--muted); font-size: 14px; }
.landing-checks i { color: var(--gold); }
.landing-cta, .landing-secondary {
  min-height: 52px;
  padding: 0 26px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border-radius: 14px;
  border: 1px solid rgba(212,175,55,.34);
  text-decoration: none;
  font-weight: 900;
}
.landing-cta { background: var(--gold); color: #0b0b0f; box-shadow: 0 0 22px rgba(212,175,55,.22); }
.landing-cta.small { min-height: 38px; padding: 0 18px; border-radius: 12px; font-size: 13px; }
.landing-secondary { color: var(--text); background: rgba(21,21,28,.72); border-color: var(--border); }
.dashboard-preview { position: relative; z-index: 1; max-width: 1000px; margin: 0 auto 90px; }
.preview-window {
  padding: 8px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 20px;
  background: rgba(21,21,28,.72);
  box-shadow: 0 24px 70px rgba(0,0,0,.42), 0 0 40px rgba(212,175,55,.12);
}
.window-bar {
  height: 44px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 16px;
  color: var(--muted);
  border-bottom: 1px solid var(--border-soft);
}
.window-bar span { width: 10px; height: 10px; border-radius: 50%; background: rgba(255,255,255,.2); }
.window-bar b { margin: 0 auto; font-size: 12px; font-weight: 800; }
.window-bar i { color: var(--gold); }
.preview-grid { padding: 22px; display: grid; grid-template-columns: minmax(230px, .45fr) 1fr; gap: 18px; background: #0b0b0f; border-radius: 0 0 14px 14px; }
.metric-column { display: grid; gap: 16px; }
.preview-card { padding: 22px; border: 1px solid var(--border-soft); border-radius: 14px; background: rgba(21,21,28,.92); }
.preview-card h3 { margin-bottom: 8px; font-size: 30px; }
.preview-card.risk { border-color: rgba(229,72,77,.24); }
.preview-card.risk h3 { color: var(--red); }
.chart-card { min-height: 260px; }
.chart-head { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 20px; }
.chart-head h3 { margin: 0; font-size: 16px; }
.chart-head span { padding: 7px 10px; border-radius: 8px; background: rgba(212,175,55,.18); color: var(--gold); font-size: 12px; font-weight: 900; }
.landing-chart {
  height: 185px;
  border-bottom: 1px solid rgba(255,255,255,.12);
  background:
    linear-gradient(to top, rgba(212,175,55,.18), rgba(212,175,55,0)),
    repeating-linear-gradient(to right, transparent 0 72px, rgba(255,255,255,.04) 73px),
    repeating-linear-gradient(to top, transparent 0 45px, rgba(255,255,255,.04) 46px);
  clip-path: polygon(0 70%, 12% 60%, 24% 56%, 36% 68%, 50% 46%, 62% 58%, 76% 36%, 100% 22%, 100% 100%, 0 100%);
  border-radius: 12px;
}
.landing-section { max-width: 980px; margin: 0 auto 90px; text-align: center; }
.landing-section h2, .landing-security h2 { font-size: clamp(30px, 4vw, 42px); margin-bottom: 12px; }
.landing-feature-grid { margin-top: 42px; display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 18px; text-align: left; }
.landing-feature-grid .feature { min-height: 190px; padding: 24px; border: 1px solid var(--border-soft); border-radius: 14px; background: rgba(21,21,28,.72); }
.landing-security {
  margin: 0 auto;
  padding: 48px;
  display: grid;
  grid-template-columns: minmax(0,1fr) 260px;
  align-items: center;
  gap: 28px;
  border: 1px solid var(--border-soft);
  border-radius: 22px;
  background: rgba(21,21,28,.72);
}
.security-orbit { position: relative; width: 210px; height: 210px; margin-left: auto; border-radius: 50%; border: 1px solid rgba(212,175,55,.22); }
.security-orbit i { position: absolute; inset: 40px; border-radius: 50%; border: 1px solid rgba(212,175,55,.25); }
.security-orbit i:nth-child(2) { inset: 72px; background: rgba(212,175,55,.08); }
.security-orbit i:nth-child(3) { inset: 94px; background: var(--gold); box-shadow: 0 0 28px rgba(212,175,55,.42); }
.hero { max-width: 760px; margin: 0 auto 48px; text-align: center; }
.hero h1 { margin: 20px 0 18px; font-size: clamp(40px, 6vw, 62px); line-height: 1.04; }
.hero p { font-size: 18px; }
.page-title { margin: 0 0 10px; font-size: clamp(32px, 4vw, 46px); line-height: 1.08; }
.page-sub { margin-bottom: 28px; }

.ux-card {
  border: 1px solid var(--border);
  border-radius: 16px;
  background: rgba(21,21,28,.86);
  box-shadow: var(--shadow);
}
.package-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 24px; max-width: 1024px; margin: 0 auto; }
.package-card {
  min-height: 315px;
  padding: 32px;
  position: relative;
  overflow: hidden;
  color: inherit;
  text-align: left;
  display: flex;
  flex-direction: column;
  transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease;
}
.package-card:hover { transform: translateY(-4px); border-color: rgba(212,175,55,.52); box-shadow: 0 0 30px rgba(212,175,55,.18); }
.package-card.disabled {
  cursor: not-allowed;
  opacity: .46;
  filter: grayscale(.25);
}
.package-card.disabled:hover {
  transform: none;
  border-color: var(--border);
  box-shadow: none;
}
.card-corner { position: absolute; right: -58px; top: -58px; width: 150px; height: 150px; background: rgba(212,175,55,.06); border-radius: 0 0 0 100%; transition: transform .3s ease; }
.package-card:hover .card-corner { transform: scale(1.6); }
.package-card.disabled:hover .card-corner { transform: none; }
.package-head, .package-foot { display: flex; align-items: flex-start; justify-content: space-between; gap: 18px; position: relative; z-index: 1; }
.package-foot { margin-top: auto; padding-top: 22px; border-top: 1px solid var(--border-soft); color: var(--muted); font-size: 13px; }
.package-foot i { color: var(--gold); }
.package-time { display: grid; justify-items: end; gap: 8px; color: var(--muted); font-size: 12px; }
.difficulty-bars { display: inline-flex; align-items: center; justify-content: flex-end; gap: 4px; }
.package-time b { display: inline-block; width: 6px; height: 18px; border-radius: 3px; background: var(--gold); }
.package-time b.dim { background: var(--surface); }
.icon-box {
  width: 56px;
  height: 56px;
  border-radius: 13px;
  display: inline-grid;
  place-items: center;
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--gold);
  font-size: 22px;
}
.icon-box.small { width: 42px; height: 42px; font-size: 17px; }
.icon-box.muted { color: var(--muted); }
.package-card h3 { margin: 26px 0 10px; font-size: 25px; }

.two-col, .encryption-layout { display: grid; grid-template-columns: minmax(0, 1fr) minmax(330px, .62fr); gap: 32px; align-items: start; }
.form-card, .side-card { padding: 30px; }
.tall { min-height: 590px; }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px 22px; }
.field { display: grid; gap: 8px; color: var(--muted); font-size: 13px; font-weight: 700; margin-bottom: 18px; }
.input-wrap {
  min-height: 52px;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 14px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--surface);
  color: var(--muted);
  transition: border-color .16s ease, box-shadow .16s ease;
}
.input-wrap:focus-within { border-color: var(--gold); box-shadow: 0 0 15px rgba(212,175,55,.16); }
.input-wrap input, .input-wrap select {
  width: 100%;
  min-width: 0;
  min-height: 48px;
  border: 0;
  outline: 0;
  color: var(--text);
  background: transparent;
}
.input-wrap select {
  padding-right: 28px;
  background:
    linear-gradient(45deg, transparent 50%, var(--muted) 50%) right 12px center / 6px 6px no-repeat,
    linear-gradient(135deg, var(--muted) 50%, transparent 50%) right 6px center / 6px 6px no-repeat;
}
.inline-action, .eye-button {
  border: 0;
  border-radius: 8px;
  background: rgba(212,175,55,.1);
  color: var(--gold);
  white-space: nowrap;
  padding: 8px 10px;
  font-size: 12px;
  font-weight: 800;
}
.validation-line { margin: -8px 0 18px; color: var(--green); font-size: 12px; }
.validation-line.bad { color: var(--red); }
.side-title { display: flex; gap: 14px; margin-bottom: 22px; }
.side-title h3 { margin-bottom: 3px; }
.side-title p { margin: 0; font-size: 13px; }
.mini-insight {
  display: flex;
  gap: 14px;
  padding: 17px;
  margin-top: 16px;
  border: 1px solid var(--border-soft);
  border-radius: 13px;
  background: rgba(255,255,255,.025);
}
.mini-insight span { width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center; background: rgba(59,130,246,.1); color: #60a5fa; flex: 0 0 auto; }
.mini-insight h4 { margin-bottom: 5px; }
.mini-insight p { margin: 0; font-size: 14px; }
.trust-line { margin-top: 26px; padding-top: 22px; border-top: 1px solid var(--border-soft); text-align: center; color: var(--muted); font-size: 12px; }

.signup-split {
  width: 100vw;
  margin: -48px calc(50% - 50vw) -70px;
  min-height: calc(100vh - 148px);
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.signup-visual {
  min-height: 100%;
  padding: clamp(34px, 5vw, 72px);
  display: grid;
  align-content: center;
  gap: 48px;
  border-right: 1px solid var(--border-soft);
  background:
    radial-gradient(circle at 0 0, rgba(212,175,55,.08), transparent 42%),
    linear-gradient(145deg, #101012, #0b0b0f);
}
.signup-visual h1 { max-width: 520px; font-size: clamp(40px, 5vw, 58px); line-height: 1.12; }
.signup-visual > div p { max-width: 560px; font-size: 18px; }
.feature { display: flex; gap: 16px; margin-top: 25px; }
.feature span { width: 36px; height: 36px; display: grid; place-items: center; border-radius: 50%; background: var(--surface); color: var(--gold); }
.feature h3 { margin-bottom: 6px; font-size: 16px; }
.feature p { margin: 0; font-size: 14px; }
.signup-note { display: grid; gap: 12px; padding-top: 28px; border-top: 1px solid var(--border-soft); color: var(--muted); font-size: 14px; }
.signup-form { padding: 34px clamp(28px, 6vw, 90px); display: grid; place-items: center; align-content: center; position: relative; z-index: 3; }
.signup-card { width: min(100%, 470px); position: relative; z-index: 4; }
.signup-card h2 { font-size: 32px; margin-bottom: 8px; }
.social {
  width: 100%;
  min-height: 56px;
  margin-top: 13px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--surface);
  color: var(--text);
  font-weight: 800;
}
.divider { margin: 28px 0 20px; display: flex; align-items: center; gap: 16px; color: var(--muted); font-size: 12px; text-transform: uppercase; }
.divider::before, .divider::after { content: ""; height: 1px; flex: 1; background: var(--border); }
.password-meter { display: grid; grid-template-columns: repeat(4, 1fr); gap: 7px; margin: -8px 0 6px; }
.password-meter span { height: 5px; border-radius: 999px; background: var(--surface); }
.password-meter .bad { background: var(--red); }
.password-meter .fair { background: #fb923c; }
.password-meter .good { background: #60a5fa; }
.password-meter .strong { background: var(--green); }
.strength-label { font-size: 12px; margin-bottom: 16px; }
.auth-help { margin: 10px 0 4px; color: var(--muted); font-size: 13px; text-align: center; line-height: 1.4; clear: both; }
.auth-help a { color: var(--gold); text-decoration: none; font-weight: 800; }
.check-row { display: flex; align-items: center; gap: 8px; color: var(--muted); line-height: 1.35; font-size: 12px; white-space: nowrap; }
.check-row a { white-space: nowrap; }
.check-row input { width: 17px; height: 17px; flex: 0 0 auto; accent-color: var(--gold); }

.invite-layout { max-width: 1010px; margin: 0 auto; display: grid; grid-template-columns: minmax(0, 1fr) 400px; gap: 26px; }
.invite-main, .invite-side { display: grid; align-content: start; gap: 24px; }
.invite-card { padding: 32px; }
.invite-company { display: flex; align-items: center; gap: 16px; margin-bottom: 32px; }
.invite-company h2 { margin: 0 0 4px; }
.invite-card h1 { font-size: 32px; line-height: 1.14; }
.invite-card h1 span { color: var(--gold); }
.invite-meta { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; padding-top: 24px; margin-top: 24px; border-top: 1px solid var(--border); }
.invite-meta small { color: var(--muted); display: block; margin-bottom: 8px; }
.danger { color: var(--red); }
.permissions { padding: 25px; }
.section-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 18px; margin-bottom: 18px; }
.section-head button { border: 0; background: transparent; color: var(--gold); }
.permission-row {
  padding: 17px;
  margin-top: 14px;
  border: 1px solid var(--border);
  border-radius: 13px;
  background: var(--surface);
}
.permission-row > div:first-child { display: flex; align-items: center; gap: 13px; margin-bottom: 14px; }
.perm-icon { width: 34px; height: 34px; display: grid; place-items: center; border-radius: 7px; background: rgba(212,175,55,.1); color: var(--gold); }
.permission-row h4 { margin: 0 0 4px; }
.permission-row p { margin: 0; font-size: 12px; }
.segmented { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.segmented button {
  min-height: 34px;
  border: 1px solid var(--border);
  border-radius: 7px;
  background: transparent;
  color: var(--muted);
}
.segmented button.selected { border-color: var(--gold); background: rgba(212,175,55,.12); color: var(--gold); }
.action-card, .log-card { padding: 24px; }
.wide-action, .action-card .primary-button { width: 100%; margin-top: 12px; justify-content: center; }
.trust-list { display: grid; gap: 10px; margin-top: 24px; padding-top: 18px; border-top: 1px solid var(--border); color: var(--muted); font-size: 12px; }
.log-card h4 { color: var(--muted); text-transform: uppercase; font-size: 12px; letter-spacing: .08em; }
.log-card b { display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: var(--gold); margin-right: 8px; }
.log-card .muted-dot { background: var(--muted); }

.encryption-layout { gap: 36px; }
.radio-stack { display: grid; gap: 16px; margin-top: 34px; }
.key-option {
  display: flex;
  gap: 18px;
  padding: 24px;
  border: 2px solid transparent;
  border-radius: 16px;
  background: rgba(28,28,36,.6);
  cursor: pointer;
}
.key-option input { display: none; }
.key-option.selected { border-color: var(--gold); background: var(--card); box-shadow: 0 0 18px rgba(212,175,55,.14); }
.key-option small { display: inline-block; margin: 10px 6px 0 0; padding: 5px 8px; border-radius: 5px; background: var(--surface); color: var(--muted); }
.vault-card { padding: 32px; }
.vault-head, .strength-row { display: flex; justify-content: space-between; gap: 18px; align-items: center; }
.key-display {
  margin: 22px 0;
  padding: 24px 18px;
  border-radius: 13px;
  background: #08090d;
  border: 1px solid var(--border);
  text-align: center;
  font-family: Consolas, monospace;
  font-size: 18px;
  letter-spacing: .12em;
  filter: blur(4px);
  transition: filter .18s ease;
}
.key-display:hover { filter: blur(0); }
.key-display small { display: block; margin-top: 16px; color: var(--muted); font-family: Inter, sans-serif; font-size: 12px; letter-spacing: 0; }
.crypto-bars { display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px; margin: 8px 0 28px; }
.crypto-bars span { height: 8px; border-radius: 99px; background: var(--gold); }
.warning { display: flex; gap: 16px; padding: 20px; border: 1px solid rgba(229,72,77,.36); border-radius: 13px; background: rgba(229,72,77,.08); color: var(--red); }
.warning p { margin: 0; }
.backup-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin: 24px 0; }
.backup-grid button { min-height: 92px; border: 1px solid var(--border); border-radius: 13px; background: rgba(255,255,255,.02); color: var(--text); font-weight: 800; }

.upload-shell, .dashboard-shell { width: 100vw; margin: -48px calc(50% - 50vw) -70px; display: grid; grid-template-columns: 240px minmax(0, 1fr); min-height: calc(100vh - 148px); }
.upload-shell { grid-template-columns: minmax(0, 1fr); }
.upload-sidebar, .dash-sidebar { background: var(--card); border-right: 1px solid var(--border); padding: 28px 18px; }
.upload-sidebar nav, .dash-sidebar nav { display: grid; gap: 13px; margin-top: 44px; color: var(--muted); }
.upload-sidebar b, .dash-sidebar b { color: var(--gold); padding: 12px 14px; border-radius: 10px; background: var(--surface); }
.dash-sidebar small { margin-top: 24px; text-transform: uppercase; font-weight: 800; }
.upload-main, .dash-main { padding: 34px 40px; overflow: auto; }
.upload-main { max-width: 1240px; width: 100%; margin: 0 auto; }
.upload-main header, .dash-main header { display: flex; justify-content: space-between; gap: 18px; margin-bottom: 30px; }
.upload-main header h1, .dash-main header h1 { margin: 0 0 6px; font-size: 31px; }
.upload-grid { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(330px, .9fr); gap: 32px; }
.upload-card, .parsing-preview, .insight-snapshot { padding: 28px; margin-bottom: 28px; }
.upload-card h2, .parsing-preview h2 { font-size: 18px; }
.drop-area {
  min-height: 300px;
  display: grid;
  place-items: center;
  align-content: center;
  text-align: center;
  padding: 30px;
  border: 2px dashed var(--border);
  border-radius: 14px;
  background: rgba(28,28,36,.5);
}
.drop-area.drag-active { border-color: var(--gold); background: rgba(212,175,55,.06); }
.cloud { width: 64px; height: 64px; border-radius: 50%; display: grid; place-items: center; background: var(--card); color: var(--gold); font-size: 25px; }
.upload-controls { display: grid; grid-template-columns: minmax(260px, 1fr) auto; align-items: end; gap: 12px; margin-top: 20px; }
.upload-mode-card { margin: 18px 0 20px; padding: 16px; border-radius: 12px; border: 1px solid rgba(212,175,55,.25); background: rgba(212,175,55,.06); }
.upload-mode-card span, .sample-download span, .drop-area small { display: block; color: var(--muted); font-size: 12px; }
.upload-mode-card strong { display: block; margin: 8px 0; color: var(--text); }
.upload-mode-card p { margin: 0 0 10px; color: var(--muted); }
.upload-mode-card small { color: var(--gold); }
.sample-download { display: grid; gap: 5px; grid-column: 1 / -1; }
.upload-controls .field { margin: 0; }
.template-downloads { display: flex; gap: 8px; flex-wrap: nowrap; align-items: end; justify-content: flex-end; }
.template-downloads .ghost-button { min-height: 40px; padding-inline: 12px; font-size: 13px; text-decoration: none; white-space: nowrap; }
.upload-controls > .check-row { grid-column: 1 / -1; justify-self: start; margin-top: 2px; }
.file-list { margin-top: 22px; display: grid; gap: 10px; }
.file-list h3 { margin: 0 0 2px; font-size: 13px; color: var(--muted); text-transform: uppercase; letter-spacing: .08em; }
.file-list.empty { padding: 16px; color: var(--muted); border: 1px solid var(--border); border-radius: 12px; background: transparent; }
.file-row { padding: 14px 16px; display: grid; grid-template-columns: minmax(0, 1fr) 88px minmax(145px, auto) 34px; gap: 12px; align-items: center; border: 1px solid rgba(212,175,55,.24); border-radius: 12px; background: rgba(212,175,55,.06); }
.file-row strong { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.file-row span, .file-row em { color: var(--muted); font-style: normal; font-size: 12px; }
.icon-button { width: 34px; height: 34px; display: grid; place-items: center; border-radius: 9px; border: 1px solid var(--border); background: var(--surface); color: var(--muted); }
.analysis-status { margin-top: 14px; padding: 12px 14px; display: flex; justify-content: space-between; gap: 12px; border-radius: 10px; color: var(--muted); background: var(--surface); border: 1px solid var(--border); }
.analysis-status.active { border-color: rgba(212,175,55,.3); color: var(--text); }
.upload-progress-card { margin-top: 16px; padding: 14px; border-radius: 12px; border: 1px solid rgba(212,175,55,.28); background: rgba(212,175,55,.06); display: grid; gap: 10px; }
.upload-progress-head, .upload-progress-meta { display: flex; justify-content: space-between; gap: 14px; align-items: center; }
.upload-progress-head span { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-weight: 700; }
.upload-progress-head b { color: var(--gold); }
.upload-progress-label { display: flex; justify-content: space-between; gap: 12px; color: var(--muted); font-size: 12px; }
.upload-progress-label b { color: var(--text); }
.upload-progress-track { height: 9px; border-radius: 999px; background: rgba(255,255,255,.08); overflow: hidden; }
.upload-progress-track i { display: block; height: 100%; border-radius: inherit; background: var(--gold); transition: width .2s ease; }
.upload-progress-track.secondary i { background: var(--blue); }
.upload-progress-meta { color: var(--muted); font-size: 12px; }
.upload-actions { margin-top: 18px; display: flex; justify-content: flex-end; gap: 12px; }
.mapping-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.scan-doc { min-height: 230px; padding: 30px; border-radius: 12px; background: var(--surface); border: 1px solid var(--border); display: grid; align-content: center; gap: 16px; color: var(--gold); position: relative; overflow: hidden; }
.scan-doc::before { content: ""; position: absolute; left: 0; right: 0; height: 2px; background: var(--gold); animation: scan 3s ease-in-out infinite; }
.scan-doc b { justify-self: end; }
.entity-list { display: grid; gap: 12px; }
.entity-list article { padding: 15px; border-radius: 10px; background: var(--surface); border: 1px solid var(--border); }
.entity-list small, .entity-list span { color: var(--muted); font-size: 12px; }
.kpi-pair { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.kpi-pair article { padding: 16px; border-radius: 12px; background: var(--surface); }
.kpi-pair b { display: block; margin: 8px 0; font-size: 27px; }
.kpi-pair em { color: var(--green); font-style: normal; font-size: 12px; }
.mini-chart, .chart-line { min-height: 160px; margin-top: 18px; border-radius: 12px; background: linear-gradient(160deg, transparent 45%, rgba(212,175,55,.18) 45% 56%, transparent 56%), var(--surface); border: 1px solid var(--border); }
.ai-comment { margin-top: 18px; padding: 16px; border: 1px solid rgba(212,175,55,.28); border-radius: 12px; background: rgba(212,175,55,.06); }
.success { color: var(--green); }

.processing-screen { width: 100vw; margin: -48px calc(50% - 50vw) -70px; min-height: calc(100vh - 148px); padding: 0 42px 42px; }
.process-header { height: 70px; display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid var(--border); }
.process-grid { max-width: 1440px; margin: 34px auto 0; display: grid; grid-template-columns: 300px minmax(0, 1fr) 300px; gap: 30px; }
.pipeline { padding: 26px; display: grid; gap: 24px; }
.pipeline div { padding-left: 17px; border-left: 2px solid var(--border); color: var(--muted); }
.pipeline div.done, .pipeline div.active { border-color: var(--gold); color: var(--text); }
.pipeline div.active b { color: var(--gold); }
.pipeline span { display: block; margin-top: 6px; font-size: 12px; color: var(--muted); }
.pipeline footer { margin-top: 20px; padding-top: 20px; border-top: 1px solid var(--border); display: flex; justify-content: space-between; color: var(--muted); font-size: 12px; }
.process-title { text-align: center; margin-bottom: 28px; }
.process-title h1 { font-size: 40px; }
.process-title span { color: var(--gold); }
.ai-core-visual { min-height: 360px; display: grid; place-items: center; border: 1px solid rgba(212,175,55,.34); border-radius: 16px; background-image: linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px); background-size: 20px 20px; }
.brain-core { width: 96px; height: 96px; border-radius: 50%; display: grid; place-items: center; border: 2px solid var(--gold); color: var(--gold); font-size: 36px; box-shadow: 0 0 70px rgba(212,175,55,.5); animation: float 4s ease-in-out infinite; }
.live-feed { margin-top: 24px; padding: 22px; min-height: 180px; font-family: Consolas, monospace; }
.live-feed h3 { font-family: Inter, sans-serif; color: var(--muted); text-transform: uppercase; font-size: 12px; letter-spacing: .12em; }
.gold { color: var(--gold); }
.process-side { display: grid; gap: 22px; align-content: start; }
.process-side .ux-card { padding: 22px; }
.wave { min-height: 120px; display: grid; place-items: center; border-radius: 10px; background: var(--surface); color: var(--gold); font-size: 28px; }
.risk { border-color: rgba(229,72,77,.32); background: rgba(229,72,77,.06); }

.dashboard-shell { grid-template-columns: 255px minmax(0, 1fr); }
.dash-main header input { width: 260px; height: 42px; border-radius: 999px; border: 1px solid var(--border); background: var(--surface); color: var(--text); padding: 0 16px; }
.welcome-banner { padding: 32px; border: 1px solid var(--border); border-radius: 16px; background: linear-gradient(135deg, var(--surface), var(--card)); position: relative; }
.welcome-banner h2 { margin-top: 16px; font-size: 30px; }
.welcome-banner .primary-button { position: absolute; right: 32px; top: 50%; transform: translateY(-50%); }
.dash-kpis { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 22px; margin: 28px 0; }
.dash-kpi { padding: 22px; }
.dash-kpi div { display: flex; justify-content: space-between; gap: 12px; color: var(--muted); font-size: 14px; }
.dash-kpi div b { color: var(--gold); font-size: 12px; }
.dash-kpi h3 { font-size: 28px; margin: 22px 0 8px; }
.dash-kpi p { margin: 0; font-size: 13px; }
.dash-bottom { display: grid; grid-template-columns: minmax(0, 2fr) minmax(300px, 1fr); gap: 24px; }
.cash-chart, .cfo { padding: 26px; }
.cash-chart .chart-line { min-height: 330px; }
.cfo h3 { margin-top: 24px; font-size: 15px; }

.actions { display: flex; justify-content: space-between; gap: 14px; margin-top: 28px; }
.toast-actions { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; margin-top: 26px; }
.primary-button, .ghost-button, .danger-button {
  min-height: 46px;
  padding: 0 20px;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid var(--border);
  color: var(--text);
  background: rgba(255,255,255,.035);
  font-weight: 800;
}
.primary-button { border-color: var(--gold); color: #0b0b0f; background: var(--gold); box-shadow: 0 0 15px rgba(212,175,55,.15); }
.primary-button:hover { background: var(--gold-hover); }
.primary-button:disabled, .ghost-button:disabled { opacity: .45; cursor: not-allowed; box-shadow: none; }
.danger-button { border-color: rgba(229,72,77,.35); color: var(--red); background: rgba(229,72,77,.12); }
.alert { position: relative; z-index: 100; margin-bottom: 20px; padding: 14px 16px; border: 1px solid rgba(229,72,77,.34); border-radius: 12px; background: rgba(229,72,77,.1); color: #ffb4b4; box-shadow: 0 18px 42px rgba(0,0,0,.32); }
.loading-view { min-height: 55vh; display: grid; place-items: center; align-content: center; text-align: center; }
.spinner { width: 48px; height: 48px; border-radius: 50%; border: 3px solid rgba(255,255,255,.12); border-top-color: var(--gold); animation: spin .8s linear infinite; }

@keyframes pulse { 50% { opacity: .45; } }
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes scan { 0% { top: -10%; } 100% { top: 110%; } }
@keyframes float { 50% { transform: translateY(-12px); } }

@media (max-width: 1100px) {
  .package-grid, .two-col, .encryption-layout, .upload-grid, .dash-bottom, .invite-layout, .process-grid { grid-template-columns: 1fr; }
  .signup-split, .upload-shell, .dashboard-shell { grid-template-columns: 1fr; }
  .preview-grid, .landing-security { grid-template-columns: 1fr; }
  .landing-feature-grid { grid-template-columns: 1fr; }
  .security-orbit { margin: 0 auto; }
  .upload-sidebar, .dash-sidebar { display: none; }
  .welcome-banner .primary-button { position: static; transform: none; margin-top: 18px; }
  .dash-kpis { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 700px) {
  .app { width: calc(100% - 28px); padding-top: 30px; }
  .topbar, .footer { align-items: flex-start; flex-direction: column; padding-block: 16px; }
  .top-actions { width: 100%; justify-content: space-between; }
  .security-pill { display: none; }
  .form-grid, .backup-grid, .mapping-grid, .kpi-pair, .dash-kpis, .upload-controls, .invite-meta { grid-template-columns: 1fr; }
  .check-row { white-space: normal; }
  .signup-form, .upload-main, .dash-main, .processing-screen { padding-inline: 18px; }
  .actions { flex-direction: column; }
  .actions button { justify-content: center; }
}
