/* =============================================
   CLEARDD — LIQUID GLASS DESIGN SYSTEM
   ============================================= */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

:root {
  /* Brand */
  --navy:        #080f1e;
  --navy-mid:    #0d1a30;
  --navy-light:  #162440;
  --gold:        #F59E0B;
  --gold-light:  #FCD34D;
  --gold-dim:    rgba(245,158,11,0.18);
  --blue:        #3B82F6;
  --blue-light:  #93C5FD;
  --green:       #10B981;
  --red:         #EF4444;
  --white:       #FFFFFF;

  /* Liquid Glass surfaces */
  --glass:            rgba(255,255,255,0.065);
  --glass-hover:      rgba(255,255,255,0.10);
  --glass-border:     rgba(255,255,255,0.10);
  --glass-border-top: rgba(255,255,255,0.20);
  --glass-gold:       rgba(245,158,11,0.18);
  --glass-blur:       blur(28px) saturate(180%);
  --glass-shadow:
    0 8px 32px rgba(0,0,0,0.45),
    0 2px 8px  rgba(0,0,0,0.25),
    inset 0 1px 0 rgba(255,255,255,0.14),
    inset 0 -1px 0 rgba(0,0,0,0.12);
  --glass-shadow-hover:
    0 20px 60px rgba(0,0,0,0.55),
    0 4px 16px  rgba(0,0,0,0.30),
    inset 0 1px 0 rgba(255,255,255,0.20);
  --glass-shadow-gold:
    0 12px 40px rgba(245,158,11,0.20),
    0 4px 16px  rgba(0,0,0,0.30),
    inset 0 1px 0 rgba(255,255,255,0.18);

  /* Text */
  --text-primary:   rgba(255,255,255,0.92);
  --text-secondary: rgba(255,255,255,0.55);
  --text-muted:     rgba(255,255,255,0.32);

  /* Layout */
  --font:        'Inter', system-ui, sans-serif;
  --radius-sm:   8px;
  --radius:      16px;
  --radius-lg:   22px;
  --radius-xl:   32px;
  --transition:  all 0.25s cubic-bezier(0.4, 0, 0.2, 1);

  /* Legacy compat */
  --gray-50:   rgba(255,255,255,0.04);
  --gray-100:  rgba(255,255,255,0.07);
  --gray-200:  rgba(255,255,255,0.10);
  --gray-400:  rgba(255,255,255,0.38);
  --gray-600:  rgba(255,255,255,0.55);
  --gray-800:  rgba(255,255,255,0.75);
  --shadow-sm: var(--glass-shadow);
  --shadow:    var(--glass-shadow-hover);
  --shadow-lg: var(--glass-shadow-hover);
}

/* ── Reset ─────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family: var(--font);
  background: var(--navy);
  color: var(--text-primary);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  overflow-x: hidden;
}

/* Animated background gradient */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 10% 10%, rgba(59,130,246,0.07) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 90% 80%, rgba(245,158,11,0.06) 0%, transparent 55%),
    radial-gradient(ellipse 50% 40% at 50% 50%, rgba(29,52,97,0.15) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}
body > * { position: relative; z-index: 1; }

/* ── Typography ──────────────────────────────── */
h1 { font-size:3rem;   font-weight:800; line-height:1.1; color:var(--text-primary); }
h2 { font-size:2rem;   font-weight:700; line-height:1.2; color:var(--text-primary); }
h3 { font-size:1.25rem; font-weight:600; color:var(--text-primary); }
h4 { font-size:1rem;   font-weight:600; color:var(--text-primary); }
p  { color: var(--text-secondary); }

/* ── Glass mixin (reused everywhere) ─────────── */
.glass {
  background: var(--glass);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border);
  border-top-color: var(--glass-border-top);
  box-shadow: var(--glass-shadow);
  border-radius: var(--radius);
}

/* ── Buttons ─────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  border-radius: var(--radius);
  font-weight: 600;
  font-size: 0.95rem;
  cursor: pointer;
  border: none;
  transition: var(--transition);
  text-decoration: none;
  position: relative;
  overflow: hidden;
}
.btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.12) 0%, transparent 60%);
  opacity: 0;
  transition: opacity 0.2s;
}
.btn:hover::before { opacity: 1; }

.btn-primary {
  background: linear-gradient(135deg, var(--gold) 0%, #d97706 100%);
  color: var(--navy);
  box-shadow: 0 4px 20px rgba(245,158,11,0.45), inset 0 1px 0 rgba(255,255,255,0.3);
}
.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(245,158,11,0.55), inset 0 1px 0 rgba(255,255,255,0.35);
}
.btn-outline {
  background: var(--glass);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border);
  border-top-color: var(--glass-border-top);
  color: var(--text-primary);
  box-shadow: var(--glass-shadow);
}
.btn-outline:hover {
  background: var(--glass-hover);
  box-shadow: var(--glass-shadow-hover);
  transform: translateY(-2px);
}
.btn-ghost {
  background: rgba(255,255,255,0.07);
  color: var(--text-primary);
  border: 1px solid rgba(255,255,255,0.10);
}
.btn-ghost:hover { background: rgba(255,255,255,0.12); }
.btn-lg { padding:16px 36px; font-size:1.05rem; border-radius:var(--radius-lg); }

/* ── Navbar ──────────────────────────────────── */
.navbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 200;
  padding: 0 48px;
  height: 66px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: rgba(8,15,30,0.60);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border-bottom: 1px solid var(--glass-border);
  box-shadow: 0 1px 0 rgba(255,255,255,0.04), 0 4px 24px rgba(0,0,0,0.3);
}
.navbar-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
}
.navbar-logo span {
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--white);
  letter-spacing: -0.5px;
}
.navbar-logo span em { color: var(--gold); font-style: normal; }
.navbar-links {
  display: flex;
  align-items: center;
  gap: 32px;
  list-style: none;
}
.navbar-links a {
  color: var(--text-secondary);
  text-decoration: none;
  font-size: 0.9rem;
  transition: var(--transition);
}
.navbar-links a:hover { color: var(--text-primary); }

/* ── Sidebar ─────────────────────────────────── */
.layout { min-height: 100vh; }

.sidebar {
  background: rgba(8,15,30,0.72);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border-right: 1px solid var(--glass-border);
  padding: 24px 0;
  position: fixed;
  top: 0; left: 0;
  width: 260px;
  height: 100vh;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  box-shadow: 4px 0 32px rgba(0,0,0,0.35);
}
.sidebar-logo {
  padding: 16px 24px 28px;
  display: flex;
  align-items: center;
  gap: 10px;
  border-bottom: 1px solid var(--glass-border);
  margin-bottom: 16px;
}
.sidebar-logo span { font-size:1.1rem; font-weight:800; color:var(--white); }
.sidebar-logo span em { color:var(--gold); font-style:normal; }
.sidebar-section { padding: 0 16px; margin-bottom: 8px; }
.sidebar-label {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: var(--text-muted);
  padding: 0 12px;
  margin-bottom: 6px;
}
.sidebar-link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: var(--radius-sm);
  color: var(--text-secondary);
  text-decoration: none;
  font-size: 0.88rem;
  font-weight: 500;
  transition: var(--transition);
  margin-bottom: 2px;
  border: 1px solid transparent;
}
.sidebar-link:hover {
  background: var(--glass);
  color: var(--text-primary);
  border-color: var(--glass-border);
}
.sidebar-link.active {
  background: var(--glass-gold);
  color: var(--gold);
  border-color: rgba(245,158,11,0.25);
  box-shadow: inset 0 1px 0 rgba(245,158,11,0.15), 0 2px 8px rgba(245,158,11,0.10);
}
.sidebar-link svg { width:18px; height:18px; flex-shrink:0; }
.sidebar-bottom {
  margin-top: auto;
  padding: 16px;
  border-top: 1px solid var(--glass-border);
}
.sidebar-user {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px;
  border-radius: var(--radius);
  cursor: pointer;
  transition: var(--transition);
  border: 1px solid transparent;
}
.sidebar-user:hover {
  background: var(--glass);
  border-color: var(--glass-border);
}
.avatar {
  width:36px; height:36px;
  border-radius:50%;
  background: linear-gradient(135deg, var(--gold), var(--blue));
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:0.85rem; color:var(--white);
  flex-shrink:0;
  box-shadow: 0 2px 8px rgba(245,158,11,0.35);
}
.sidebar-user-info { flex:1; overflow:hidden; }
.sidebar-user-name {
  font-size:0.85rem; font-weight:600; color:var(--text-primary);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.sidebar-user-role { font-size:0.75rem; color:var(--text-muted); }

/* ── Main Content ───────────────────────────── */
.main { margin-left:260px; padding:40px; min-height:100vh; }
.page-header { margin-bottom:32px; }
.page-title { font-size:1.75rem; font-weight:700; color:var(--text-primary); margin-bottom:4px; }
.page-subtitle { color:var(--text-secondary); font-size:0.95rem; }

/* ── Cards ───────────────────────────────────── */
.card {
  background: var(--glass);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border);
  border-top-color: var(--glass-border-top);
  border-radius: var(--radius);
  box-shadow: var(--glass-shadow);
  padding: 24px;
  transition: var(--transition);
}
.card:hover {
  background: var(--glass-hover);
  box-shadow: var(--glass-shadow-hover);
  transform: translateY(-2px);
}

/* Stat Cards */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 20px;
  margin-bottom: 32px;
}
.stat-card {
  background: var(--glass);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border);
  border-top-color: var(--glass-border-top);
  border-radius: var(--radius);
  padding: 24px;
  position: relative;
  overflow: hidden;
  transition: var(--transition);
  box-shadow: var(--glass-shadow);
}
.stat-card:hover {
  transform: translateY(-4px);
  background: var(--glass-hover);
  box-shadow: var(--glass-shadow-hover);
}
.stat-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  border-radius: var(--radius) var(--radius) 0 0;
}
.stat-card.gold::before  { background: linear-gradient(90deg, var(--gold), var(--gold-light)); box-shadow: 0 0 12px rgba(245,158,11,0.5); }
.stat-card.blue::before  { background: linear-gradient(90deg, var(--blue), var(--blue-light)); box-shadow: 0 0 12px rgba(59,130,246,0.5); }
.stat-card.green::before { background: linear-gradient(90deg, var(--green), #34D399); box-shadow: 0 0 12px rgba(16,185,129,0.5); }
.stat-card.navy::before  { background: linear-gradient(90deg, #3B82F6, #93C5FD); box-shadow: 0 0 12px rgba(59,130,246,0.4); }
.stat-icon {
  width:44px; height:44px;
  border-radius:var(--radius-sm);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:16px;
}
.stat-icon.gold  { background:rgba(245,158,11,0.15); color:var(--gold);  box-shadow:inset 0 1px 0 rgba(255,255,255,0.1); }
.stat-icon.blue  { background:rgba(59,130,246,0.15); color:var(--blue);  box-shadow:inset 0 1px 0 rgba(255,255,255,0.1); }
.stat-icon.green { background:rgba(16,185,129,0.15); color:var(--green); box-shadow:inset 0 1px 0 rgba(255,255,255,0.1); }
.stat-icon.navy  { background:rgba(59,130,246,0.12); color:var(--blue-light); }
.stat-value { font-size:2rem; font-weight:800; color:var(--text-primary); line-height:1; margin-bottom:6px; }
.stat-label { font-size:0.85rem; color:var(--text-secondary); font-weight:500; }
.stat-change {
  display:inline-flex; align-items:center; gap:4px;
  font-size:0.78rem; font-weight:600;
  margin-top:8px; padding:3px 10px;
  border-radius:20px;
}
.stat-change.up   { background:rgba(16,185,129,0.15);  color:var(--green); }
.stat-change.down { background:rgba(239,68,68,0.15);   color:var(--red); }

/* Deal Cards */
.deals-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.deal-card {
  background: var(--glass);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border);
  border-top-color: var(--glass-border-top);
  border-radius: var(--radius);
  padding: 24px;
  cursor: pointer;
  transition: var(--transition);
  position: relative;
  overflow: hidden;
  box-shadow: var(--glass-shadow);
}
.deal-card::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--radius);
  background: linear-gradient(135deg, rgba(255,255,255,0.05) 0%, transparent 50%);
  pointer-events: none;
}
.deal-card:hover {
  transform: translateY(-5px);
  background: var(--glass-hover);
  border-color: rgba(245,158,11,0.35);
  box-shadow: var(--glass-shadow-gold);
}
.deal-card:hover .deal-arrow { opacity:1; transform:translateX(0); }
.deal-status {
  display:inline-flex; align-items:center; gap:6px;
  padding:4px 12px; border-radius:20px;
  font-size:0.75rem; font-weight:600;
  margin-bottom:16px;
  border: 1px solid transparent;
}
.deal-status.complete   { background:rgba(16,185,129,0.12); color:var(--green); border-color:rgba(16,185,129,0.25); }
.deal-status.processing { background:rgba(59,130,246,0.12); color:var(--blue-light); border-color:rgba(59,130,246,0.25); }
.deal-status.review     { background:var(--glass-gold);     color:var(--gold); border-color:rgba(245,158,11,0.30); }
.deal-status-dot { width:6px; height:6px; border-radius:50%; background:currentColor; }
.deal-status.processing .deal-status-dot { animation:pulse 1.5s infinite; }
.deal-name { font-size:1.05rem; font-weight:700; color:var(--text-primary); margin-bottom:6px; }
.deal-meta { font-size:0.82rem; color:var(--text-muted); margin-bottom:20px; }
.deal-progress-label {
  display:flex; justify-content:space-between;
  font-size:0.8rem; font-weight:600; margin-bottom:6px;
}
.deal-progress-label span:first-child { color:var(--text-secondary); }
.deal-progress-label span:last-child  { color:var(--text-primary); }
.progress-bar { height:5px; background:rgba(255,255,255,0.08); border-radius:10px; overflow:hidden; }
.progress-fill {
  height:100%; border-radius:10px;
  background: linear-gradient(90deg, var(--gold), var(--gold-light));
  box-shadow: 0 0 8px rgba(245,158,11,0.5);
  transition: width 1s ease;
}
.progress-fill.blue  { background:linear-gradient(90deg,var(--blue),var(--blue-light)); box-shadow:0 0 8px rgba(59,130,246,0.5); }
.progress-fill.green { background:linear-gradient(90deg,var(--green),#34D399); box-shadow:0 0 8px rgba(16,185,129,0.5); }
.deal-arrow {
  position:absolute; top:24px; right:24px;
  opacity:0; transform:translateX(-8px);
  transition:var(--transition); color:var(--gold);
}

/* ── Upload Page ─────────────────────────────── */
.upload-zone {
  border: 2px dashed rgba(255,255,255,0.15);
  border-radius: var(--radius-lg);
  padding: 64px 40px;
  text-align: center;
  cursor: pointer;
  transition: var(--transition);
  background: var(--glass);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  position: relative;
  overflow: hidden;
  box-shadow: var(--glass-shadow);
}
.upload-zone::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 50% 0%, rgba(245,158,11,0.07), transparent 60%);
  opacity: 0;
  transition: var(--transition);
}
.upload-zone:hover {
  border-color: rgba(245,158,11,0.5);
  background: var(--glass-hover);
  box-shadow: var(--glass-shadow-gold);
}
.upload-zone:hover::before { opacity: 1; }
.upload-zone.dragging {
  border-color: var(--blue);
  background: rgba(59,130,246,0.08);
  transform: scale(1.01);
}
.upload-icon-wrap {
  width:88px; height:88px;
  border-radius:50%;
  background: rgba(255,255,255,0.06);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.14);
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 24px;
  animation: float 3s ease-in-out infinite;
  box-shadow: 0 8px 24px rgba(0,0,0,0.3), inset 0 1px 0 rgba(255,255,255,0.18);
}
.upload-title { font-size:1.4rem; font-weight:700; color:var(--text-primary); margin-bottom:8px; }
.upload-subtitle { font-size:0.9rem; color:var(--text-secondary); margin-bottom:24px; }
.upload-formats { display:flex; justify-content:center; gap:12px; flex-wrap:wrap; }
.format-badge {
  display:flex; align-items:center; gap:6px;
  padding:6px 14px; border-radius:20px;
  font-size:0.78rem; font-weight:600;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  color: var(--text-secondary);
}

/* Connect Options */
.connect-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:32px; }
.connect-card {
  background: var(--glass);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border);
  border-top-color: var(--glass-border-top);
  border-radius: var(--radius);
  padding: 20px;
  text-align: center;
  cursor: pointer;
  transition: var(--transition);
  box-shadow: var(--glass-shadow);
}
.connect-card:hover {
  border-color: rgba(59,130,246,0.4);
  box-shadow: 0 8px 32px rgba(59,130,246,0.15), var(--glass-shadow-hover);
  transform: translateY(-3px);
  background: var(--glass-hover);
}
.connect-logo {
  width:48px; height:48px;
  border-radius:var(--radius-sm);
  margin:0 auto 12px;
  display:flex; align-items:center; justify-content:center;
  font-weight:800; font-size:1rem;
}
.connect-name { font-size:0.9rem; font-weight:600; color:var(--text-primary); }
.connect-desc { font-size:0.78rem; color:var(--text-muted); margin-top:2px; }

/* ── Form inputs ─────────────────────────────── */
input, textarea, select {
  width: 100%;
  padding: 12px 16px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-family: var(--font);
  font-size: 0.92rem;
  transition: var(--transition);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
input::placeholder, textarea::placeholder { color: var(--text-muted); }
input:focus, textarea:focus, select:focus {
  outline: none;
  border-color: rgba(245,158,11,0.5);
  background: rgba(255,255,255,0.09);
  box-shadow: 0 0 0 3px rgba(245,158,11,0.12), inset 0 1px 0 rgba(255,255,255,0.08);
}
label { font-size:0.85rem; font-weight:600; color:var(--text-secondary); margin-bottom:6px; display:block; }

/* ── Processing Page ─────────────────────────── */
.processing-wrap {
  max-width: 620px;
  margin: 0 auto;
  text-align: center;
  padding: 60px 20px;
}
.processing-orb {
  width: 128px; height: 128px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(59,130,246,0.3), rgba(245,158,11,0.2));
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid rgba(255,255,255,0.18);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 40px;
  position: relative;
  animation: orb-breathe 4s ease-in-out infinite;
  box-shadow:
    0 0 40px rgba(59,130,246,0.25),
    0 0 80px rgba(245,158,11,0.10),
    inset 0 2px 0 rgba(255,255,255,0.22),
    inset 0 -2px 0 rgba(0,0,0,0.15);
}
.processing-orb::before, .processing-orb::after {
  content:''; position:absolute; border-radius:50%; border:1px solid;
  animation: ripple 2.4s ease-out infinite;
}
.processing-orb::before {
  width:170px; height:170px;
  border-color: rgba(59,130,246,0.25);
}
.processing-orb::after {
  width:210px; height:210px;
  border-color: rgba(245,158,11,0.15);
  animation-delay: 0.6s;
}
.processing-steps { text-align:left; margin-top:48px; }
.processing-step {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 20px;
  border-radius: var(--radius);
  margin-bottom: 8px;
  transition: var(--transition);
  background: var(--glass);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border);
  box-shadow: var(--glass-shadow);
}
.processing-step.done   { border-color:rgba(16,185,129,0.25); background:rgba(16,185,129,0.08); }
.processing-step.active { border-color:rgba(59,130,246,0.30); background:rgba(59,130,246,0.08); }
.processing-step.waiting { opacity:0.35; }
.step-icon {
  width:36px; height:36px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
}
.step-icon.done   { background:rgba(16,185,129,0.25); color:var(--green); border:1px solid rgba(16,185,129,0.35); box-shadow:0 0 12px rgba(16,185,129,0.25); }
.step-icon.active { background:rgba(59,130,246,0.25); color:var(--blue-light); border:1px solid rgba(59,130,246,0.35); animation:pulse 1.5s infinite; box-shadow:0 0 12px rgba(59,130,246,0.35); }
.step-icon.waiting { background:rgba(255,255,255,0.06); color:var(--text-muted); border:1px solid rgba(255,255,255,0.10); }
.step-text  { flex:1; }
.step-name  { font-size:0.9rem; font-weight:600; color:var(--text-primary); }
.step-desc  { font-size:0.8rem; color:var(--text-secondary); }
.step-time  { font-size:0.78rem; font-weight:600; color:var(--green); }

/* ── Results / KPI Strip ─────────────────────── */
.results-header {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:32px;
}
.anomaly-banner {
  background: rgba(239,68,68,0.09);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid rgba(239,68,68,0.22);
  border-top-color: rgba(239,68,68,0.35);
  border-radius: var(--radius);
  padding: 16px 24px;
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 24px;
  box-shadow: 0 4px 24px rgba(239,68,68,0.12), inset 0 1px 0 rgba(255,255,255,0.08);
}
.anomaly-icon {
  width:40px; height:40px; border-radius:50%;
  background:rgba(239,68,68,0.15); display:flex; align-items:center; justify-content:center;
  color:var(--red); flex-shrink:0;
  box-shadow: 0 0 16px rgba(239,68,68,0.25);
}
.anomaly-count { font-size:1.1rem; font-weight:700; color:var(--text-primary); }
.anomaly-sub   { font-size:0.85rem; color:var(--text-secondary); }

/* Financial Table */
.table-wrap {
  background: var(--glass);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border);
  border-top-color: var(--glass-border-top);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--glass-shadow);
}
.table-scroll { overflow-x:auto; }
.fin-table { width:100%; border-collapse:collapse; font-size:0.85rem; }
.fin-table th {
  background: rgba(8,15,30,0.6);
  color: var(--text-secondary);
  font-weight:600; font-size:0.72rem;
  text-transform:uppercase; letter-spacing:0.8px;
  padding:14px 16px; text-align:right; white-space:nowrap;
  border-bottom: 1px solid var(--glass-border);
}
.fin-table th:first-child { text-align:left; }
.fin-table td {
  padding:11px 16px; text-align:right;
  border-bottom:1px solid rgba(255,255,255,0.04);
  color:var(--text-primary); font-weight:500; white-space:nowrap;
}
.fin-table td:first-child { text-align:left; font-weight:600; }
.fin-table tr:hover td { background:rgba(255,255,255,0.03); }
.fin-table tr.section-header td {
  background:rgba(255,255,255,0.03);
  font-weight:700; font-size:0.72rem;
  text-transform:uppercase; letter-spacing:0.8px;
  color:var(--text-muted); padding:9px 16px;
}
.fin-table tr.total td {
  background: rgba(245,158,11,0.10);
  color: var(--gold-light);
  font-weight:700;
  border-top: 1px solid rgba(245,158,11,0.25);
  border-bottom:none;
}
.fin-table tr.subtotal td {
  background:rgba(255,255,255,0.03);
  font-weight:700; color:var(--text-primary);
  border-top:1px solid rgba(245,158,11,0.2);
}
.cell-anomaly { color:var(--red) !important; position:relative; }
.cell-anomaly::after { content:'⚠'; font-size:0.68rem; margin-left:4px; animation:pulse 1.5s infinite; }
.positive { color:var(--green) !important; }
.negative { color:var(--red) !important; }

/* Summary / KPI Cards */
.summary-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-bottom:24px; }
.summary-card {
  background: var(--glass);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border);
  border-top-color: var(--glass-border-top);
  border-radius: var(--radius);
  padding: 20px;
  text-align: center;
  box-shadow: var(--glass-shadow);
  transition: var(--transition);
}
.summary-card:hover { background:var(--glass-hover); transform:translateY(-2px); }
.summary-label {
  font-size:0.72rem; font-weight:700;
  text-transform:uppercase; letter-spacing:0.8px;
  color:var(--text-muted); margin-bottom:8px;
}
.summary-value { font-size:1.6rem; font-weight:800; color:var(--text-primary); }
.summary-value.gold  { color:var(--gold); text-shadow:0 0 20px rgba(245,158,11,0.4); }
.summary-value.green { color:var(--green); text-shadow:0 0 20px rgba(16,185,129,0.3); }
.summary-value.red   { color:var(--red); }

/* Anomaly Cards */
.anomaly-list  { display:flex; flex-direction:column; gap:10px; margin-top:16px; }
.anomaly-item {
  background: var(--glass);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border-radius: var(--radius);
  padding: 16px 20px;
  border: 1px solid var(--glass-border);
  border-left: 3px solid var(--red);
  display: flex;
  align-items: flex-start;
  gap: 16px;
  transition: var(--transition);
  box-shadow: var(--glass-shadow);
}
.anomaly-item:hover { background:var(--glass-hover); box-shadow:var(--glass-shadow-hover); }
.anomaly-item.warning { border-left-color:var(--gold); }
.anomaly-item-icon {
  width:32px; height:32px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; font-size:0.85rem;
}
.anomaly-item-icon.critical { background:rgba(239,68,68,0.15); color:var(--red); box-shadow:0 0 10px rgba(239,68,68,0.2); }
.anomaly-item-icon.warning  { background:rgba(245,158,11,0.15); color:var(--gold); box-shadow:0 0 10px rgba(245,158,11,0.2); }
.anomaly-title  { font-size:0.9rem; font-weight:600; color:var(--text-primary); margin-bottom:4px; }
.anomaly-desc   { font-size:0.82rem; color:var(--text-secondary); }
.anomaly-actions { display:flex; gap:8px; margin-top:8px; }
.anomaly-action {
  font-size:0.75rem; font-weight:600;
  padding:4px 12px; border-radius:20px;
  cursor:pointer; border:1px solid transparent; transition:var(--transition);
  background: var(--glass); backdrop-filter:blur(8px);
}
.anomaly-action.confirm { background:rgba(239,68,68,0.12); color:var(--red); border-color:rgba(239,68,68,0.25); }
.anomaly-action.explain { background:rgba(245,158,11,0.12); color:var(--gold); border-color:rgba(245,158,11,0.25); }
.anomaly-action.dismiss { background:rgba(255,255,255,0.06); color:var(--text-secondary); border-color:rgba(255,255,255,0.12); }
.anomaly-action:hover   { transform:translateY(-1px); filter:brightness(1.15); }

/* ── Report Page ─────────────────────────────── */
.report-preview {
  background: var(--glass);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border);
  border-top-color: var(--glass-border-top);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--glass-shadow-hover);
}
.report-header-bar {
  background: rgba(8,15,30,0.7);
  padding: 32px 40px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--glass-border);
}
.report-title   { color:var(--text-primary); font-size:1.4rem; font-weight:700; }
.report-subtitle { color:var(--text-secondary); font-size:0.85rem; margin-top:4px; }
.report-badge {
  background:linear-gradient(135deg,var(--gold),#d97706);
  color:var(--navy); font-weight:700; font-size:0.78rem;
  padding:6px 14px; border-radius:20px;
  box-shadow:0 4px 12px rgba(245,158,11,0.4);
}
.report-body { padding:40px; }
.download-btn-wrap { display:flex; gap:16px; justify-content:center; margin-top:40px; }

/* ── Landing Page ────────────────────────────── */
.hero {
  min-height: 100vh;
  background: linear-gradient(145deg, #060d1a 0%, #0a1628 50%, #091525 100%);
  display: flex;
  align-items: center;
  padding: 100px 80px 80px;
  position: relative;
  overflow: hidden;
}
.hero-bg-circle {
  position:absolute; border-radius:50%;
  filter:blur(90px); pointer-events:none;
}
.hero-bg-circle.c1 { width:600px; height:600px; background:rgba(59,130,246,0.08); top:-150px; right:-100px; }
.hero-bg-circle.c2 { width:400px; height:400px; background:rgba(245,158,11,0.07); bottom:-50px; left:30%; }
.hero-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:80px;
  align-items:center; max-width:1200px; margin:0 auto; width:100%;
}
.hero-eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(245,158,11,0.12);
  border:1px solid rgba(245,158,11,0.28);
  color:var(--gold); padding:6px 16px; border-radius:20px;
  font-size:0.82rem; font-weight:600; margin-bottom:24px; letter-spacing:0.5px;
  backdrop-filter:blur(8px);
}
.hero h1 { color:var(--white); font-size:3.5rem; margin-bottom:24px; line-height:1.1; }
.hero h1 em { color:var(--gold); font-style:normal; }
.hero p { color:rgba(255,255,255,0.6); font-size:1.1rem; line-height:1.7; margin-bottom:40px; }
.hero-actions { display:flex; gap:16px; align-items:center; }
.hero-stats {
  display:flex; gap:40px; margin-top:56px;
  padding-top:40px; border-top:1px solid rgba(255,255,255,0.07);
}
.hero-stat-value { font-size:2rem; font-weight:800; color:var(--white); }
.hero-stat-label { font-size:0.82rem; color:rgba(255,255,255,0.38); margin-top:2px; }

/* Features Section */
.features { padding:100px 80px; background:rgba(8,15,30,0.85); backdrop-filter:blur(40px); }
.section-eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  color:var(--gold); font-size:0.82rem; font-weight:700;
  text-transform:uppercase; letter-spacing:1.2px; margin-bottom:16px;
}
.section-title   { font-size:2.5rem; font-weight:800; color:var(--text-primary); margin-bottom:16px; line-height:1.2; }
.section-subtitle { font-size:1.05rem; color:var(--text-secondary); max-width:500px; margin-bottom:64px; }
.features-grid   { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.feature-card {
  padding: 32px;
  border-radius: var(--radius-lg);
  background: var(--glass);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border);
  border-top-color: var(--glass-border-top);
  transition: var(--transition);
  position: relative;
  overflow: hidden;
  box-shadow: var(--glass-shadow);
}
.feature-card::before {
  content:''; position:absolute;
  top:0; left:0; right:0; bottom:0;
  background:linear-gradient(135deg,rgba(255,255,255,0.04) 0%,transparent 55%);
  pointer-events:none;
}
.feature-card:hover {
  border-color:rgba(245,158,11,0.35);
  transform:translateY(-6px);
  box-shadow:var(--glass-shadow-gold);
  background:var(--glass-hover);
}
.feature-card:hover .feature-icon-wrap { transform:scale(1.08); }
.feature-icon-wrap {
  width:56px; height:56px; border-radius:var(--radius);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:24px; transition:var(--transition);
  background:rgba(255,255,255,0.07);
  border:1px solid rgba(255,255,255,0.12);
  backdrop-filter:blur(8px);
}
.feature-title { font-size:1.1rem; font-weight:700; color:var(--text-primary); margin-bottom:12px; }
.feature-desc  { font-size:0.9rem; color:var(--text-secondary); line-height:1.6; }

/* ── Login Page ──────────────────────────────── */
.login-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 100vh;
}
.login-left {
  background: linear-gradient(145deg, #060d1a 0%, #0d1a2e 100%);
  padding: 60px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  overflow: hidden;
}
.login-left::before {
  content:''; position:absolute;
  width:400px; height:400px; border-radius:50%;
  background:rgba(245,158,11,0.07); filter:blur(80px);
  bottom:-100px; left:-50px; pointer-events:none;
}
.login-right {
  background: rgba(255,255,255,0.03);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border-left: 1px solid var(--glass-border);
  padding: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.login-form-wrap {
  width: 100%;
  max-width: 380px;
}
.login-form-card {
  background: var(--glass);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border);
  border-top-color: var(--glass-border-top);
  border-radius: var(--radius-xl);
  padding: 40px;
  box-shadow: var(--glass-shadow);
}

/* ── Utility ─────────────────────────────────── */
.divider { height:1px; background:var(--glass-border); margin:24px 0; }
.section { margin-bottom:40px; }
.section-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:20px; }
.section-head h3 { color:var(--text-primary); }

/* Tabs */
.tabs { display:flex; gap:4px; margin-bottom:24px; padding:4px; background:var(--glass); backdrop-filter:var(--glass-blur); -webkit-backdrop-filter:var(--glass-blur); border-radius:var(--radius); border:1px solid var(--glass-border); display:inline-flex; }
.tab {
  padding:8px 20px; border-radius:10px;
  font-size:0.85rem; font-weight:600; cursor:pointer;
  color:var(--text-secondary); transition:var(--transition);
  border:1px solid transparent;
}
.tab:hover { color:var(--text-primary); background:rgba(255,255,255,0.06); }
.tab.active {
  background: var(--glass-hover);
  color:var(--text-primary);
  border-color:var(--glass-border);
  box-shadow:0 2px 8px rgba(0,0,0,0.25), inset 0 1px 0 rgba(255,255,255,0.12);
}

/* Badges / Pills */
.badge {
  display:inline-flex; align-items:center; gap:5px;
  padding:3px 10px; border-radius:20px;
  font-size:0.72rem; font-weight:700;
  backdrop-filter:blur(8px);
}
.badge-gold  { background:rgba(245,158,11,0.15); color:var(--gold);  border:1px solid rgba(245,158,11,0.28); }
.badge-green { background:rgba(16,185,129,0.12); color:var(--green); border:1px solid rgba(16,185,129,0.25); }
.badge-red   { background:rgba(239,68,68,0.12);  color:var(--red);   border:1px solid rgba(239,68,68,0.25); }
.badge-blue  { background:rgba(59,130,246,0.12); color:var(--blue-light); border:1px solid rgba(59,130,246,0.25); }

/* ── Animations ──────────────────────────────── */
@keyframes float {
  0%,100% { transform:translateY(0); }
  50%     { transform:translateY(-10px); }
}
@keyframes pulse {
  0%,100% { opacity:1; transform:scale(1); }
  50%     { opacity:0.65; transform:scale(0.94); }
}
@keyframes ripple {
  0%   { transform:scale(0.75); opacity:1; }
  100% { transform:scale(1.6); opacity:0; }
}
@keyframes orb-breathe {
  0%,100% { box-shadow:0 0 40px rgba(59,130,246,0.25),0 0 80px rgba(245,158,11,0.10),inset 0 2px 0 rgba(255,255,255,0.22); transform:scale(1); }
  50%     { box-shadow:0 0 60px rgba(59,130,246,0.35),0 0 120px rgba(245,158,11,0.15),inset 0 2px 0 rgba(255,255,255,0.28); transform:scale(1.04); }
}
@keyframes fadeInUp {
  from { opacity:0; transform:translateY(28px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes shimmer {
  0%   { background-position:-200% center; }
  100% { background-position:200% center; }
}
@keyframes glow-pulse {
  0%,100% { opacity:0.6; }
  50%     { opacity:1; }
}

.fade-in-up { animation:fadeInUp 0.55s cubic-bezier(0.4,0,0.2,1) forwards; }
.fade-in-up.delay-1 { animation-delay:0.08s; opacity:0; }
.fade-in-up.delay-2 { animation-delay:0.16s; opacity:0; }
.fade-in-up.delay-3 { animation-delay:0.24s; opacity:0; }
.fade-in-up.delay-4 { animation-delay:0.32s; opacity:0; }

.shimmer {
  background:linear-gradient(90deg,rgba(255,255,255,0.04) 25%,rgba(255,255,255,0.09) 50%,rgba(255,255,255,0.04) 75%);
  background-size:200% 100%;
  animation:shimmer 1.6s infinite;
}

/* Scrollbar */
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:rgba(255,255,255,0.12); border-radius:10px; }
::-webkit-scrollbar-thumb:hover { background:rgba(255,255,255,0.22); }

/* Run button */
.run-btn {
  display:inline-flex; align-items:center; gap:10px;
  background:linear-gradient(135deg,var(--gold),#d97706);
  color:var(--navy); font-weight:700; font-size:1rem;
  padding:14px 32px; border-radius:var(--radius-lg);
  border:none; cursor:pointer;
  box-shadow:0 4px 20px rgba(245,158,11,0.45),inset 0 1px 0 rgba(255,255,255,0.3);
  transition:var(--transition);
  text-decoration:none;
}
.run-btn:hover {
  transform:translateY(-3px);
  box-shadow:0 8px 32px rgba(245,158,11,0.55),inset 0 1px 0 rgba(255,255,255,0.35);
}

/* ======================================================
   TEMPLATE GLASS ENHANCEMENTS
   Applied on top of per-template inline style blocks —
   adds backdrop-filter/glass depth to card components.
   ====================================================== */

/* ── Dashboard ── */
.metrics-bar,
.deals-panel,
.activity-card,
.dash-new-btn { backdrop-filter: blur(20px) saturate(160%); -webkit-backdrop-filter: blur(20px) saturate(160%); }

.dash-new-btn {
  background: var(--gold) !important;
  color: var(--navy) !important;
  font-weight: 700;
}
.dash-new-btn:hover {
  background: var(--gold-light) !important;
  transform: translateY(-2px);
}

/* Dashboard table rows */
.deals-table tbody tr:hover td { background: rgba(255,255,255,0.04) !important; }
.deals-table thead th { background: rgba(255,255,255,0.03) !important; }

/* ── Upload ── */
.form-card {
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
}
.run-btn {
  background: linear-gradient(135deg, var(--gold), #d97706) !important;
  color: var(--navy) !important;
}

/* ── Processing ── */
.proc-card {
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
}
.proc-log {
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
}
.proc-footer { border-top: 1px solid rgba(255,255,255,0.06) !important; }
.proc-skip { color: rgba(255,255,255,0.45) !important; }
.proc-skip:hover { color: var(--gold) !important; }
.proc-cancel { color: rgba(255,255,255,0.2) !important; }
.proc-cancel:hover { color: var(--red) !important; }

/* Step indicators */
.proc-step.done .proc-step-indicator { background: rgba(16,185,129,0.18) !important; color: #34d399 !important; }
.proc-step.active .proc-step-indicator { background: var(--gold) !important; color: var(--navy) !important; }
.proc-step.wait .proc-step-indicator { background: rgba(255,255,255,0.06) !important; color: rgba(255,255,255,0.3) !important; }
.proc-step.done .proc-step-badge { background: rgba(16,185,129,0.15) !important; color: #34d399 !important; }
.proc-step.active .proc-step-badge { background: rgba(245,158,11,0.15) !important; color: var(--gold) !important; }
.proc-step.wait .proc-step-badge { background: rgba(255,255,255,0.05) !important; color: rgba(255,255,255,0.3) !important; }

.log-line .log-ts { color: rgba(255,255,255,0.2) !important; }
.log-line .log-ok { color: #34d399 !important; }
.log-line .log-run { color: #93c5fd !important; }
.log-cursor { background: rgba(255,255,255,0.5) !important; }

/* ── Results ── */
.kpi-strip,
.table-panel,
.r-card {
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
}
.pl-table thead th { background: rgba(255,255,255,0.03) !important; }
.pl-table tr:hover td { background: rgba(255,255,255,0.04) !important; }
.pl-table td:first-child { color: rgba(255,255,255,0.7) !important; }
.anomaly-banner {
  background: rgba(239,68,68,0.1) !important;
  border: 1px solid rgba(239,68,68,0.25) !important;
}
.anomaly-row:hover { background: rgba(255,255,255,0.03) !important; }
.a-btn.confirm { background: rgba(239,68,68,0.1) !important; border-color: rgba(239,68,68,0.25) !important; color: rgba(252,165,165,0.9) !important; }
.a-btn.ask { background: rgba(59,130,246,0.1) !important; border-color: rgba(59,130,246,0.25) !important; color: rgba(147,197,253,0.9) !important; }
.a-btn.dismiss { background: rgba(255,255,255,0.05) !important; border-color: rgba(255,255,255,0.1) !important; color: rgba(255,255,255,0.5) !important; }
.period-sel { background: rgba(255,255,255,0.07) !important; border: 1px solid rgba(255,255,255,0.12) !important; color: var(--text-primary) !important; }
.tab-btn { color: rgba(255,255,255,0.45) !important; }
.tab-btn:hover { color: var(--text-primary) !important; }
.tab-btn.active { color: var(--gold) !important; border-bottom-color: var(--gold) !important; }
.tab-row { border-bottom: 1px solid rgba(255,255,255,0.08) !important; }

/* ── Report page ── */
.action-bar {
  background: rgba(8,15,30,0.85) !important;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(255,255,255,0.08) !important;
}
.dl-btn.primary { background: var(--gold) !important; color: var(--navy) !important; border-color: var(--gold) !important; }
.dl-btn.primary:hover { background: var(--gold-light) !important; }
.dl-btn.secondary {
  background: rgba(255,255,255,0.07) !important;
  color: var(--text-primary) !important;
  border-color: rgba(255,255,255,0.12) !important;
}
.dl-btn.secondary:hover { background: rgba(255,255,255,0.12) !important; }

/* ── Login right panel glass ── */
.login-right {
  backdrop-filter: blur(28px) saturate(180%);
  -webkit-backdrop-filter: blur(28px) saturate(180%);
}
.sign-in-btn { background: var(--gold) !important; color: var(--navy) !important; }
.sign-in-btn:hover { background: var(--gold-light) !important; }

/* ── Status pills – keep on dark bg ── */
.status-pill.processing { background: rgba(59,130,246,0.15) !important; color: #93c5fd !important; }
.status-pill.review { background: rgba(245,158,11,0.15) !important; color: #fcd34d !important; }
.status-pill.complete { background: rgba(16,185,129,0.15) !important; color: #34d399 !important; }
.status-pill.queued { background: rgba(255,255,255,0.06) !important; color: rgba(255,255,255,0.45) !important; }
