@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;700&family=Cinzel:wght@400;700&family=Montserrat:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap');


/** index.css — JJZ CRM Luxury Design System (matches Pool Estimator) */
:root {
  font-size: 16px;
  line-height: 145%;
  text-rendering: optimizeLegibility;

  /* Luxury Design Tokens */
  --color-primary: #002B5B;
  --color-sand: #E1D9D1;
  --color-charcoal: #2D2D2D;
  --color-bg: #F5F3F0;
  --color-white: #FFFFFF;
  --color-gold: #C9A96E;
  --color-text-muted: #6B7280;
  --color-error: #f87171;
  --color-success: #10B981;
  --color-warning: #F59E0B;

  /* Fonts */
  --font-serif: 'Playfair Display', 'Cinzel', serif;
  --font-sans: 'Montserrat', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
body {
  margin: 0;
  background: var(--color-bg);
  color: var(--color-charcoal);
  font-family: var(--font-sans);
}
#root { min-height: 100vh; display: flex; flex-direction: column; }
/* ── Animations ─────────────────────────────────────────────────────── */
@keyframes fadeIn    { from { opacity: 0; } to { opacity: 1; } }
@keyframes fadeUp    { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
@keyframes pulse-glow {
  0%, 100% { box-shadow: 0 0 20px rgba(0,43,91,0.1), 0 0 60px rgba(0,43,91,0.05); }
  50%      { box-shadow: 0 0 30px rgba(0,43,91,0.2), 0 0 80px rgba(0,43,91,0.1); }
}
@keyframes shimmer {
  0%   { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}
@keyframes ripple {
  0%   { transform: scale(0.8); opacity: 0.7; }
  100% { transform: scale(2.5); opacity: 0; }
}
@keyframes spin {
  to { transform: rotate(360deg); }
}
.fade-in   { animation: fadeIn 0.6s ease-out forwards; }
.spinner   { display: inline-block; width: 18px; height: 18px; border: 2px solid rgba(0,43,91,0.2); border-top-color: var(--color-primary); border-radius: 50%; animation: spin 0.6s linear infinite; }
.fade-up   { animation: fadeUp 0.8s ease-out forwards; }
/* ── Typography ─────────────────────────────────────────────────────── */
h1, h2, h3 { font-family: var(--font-serif); font-weight: 700; color: var(--color-primary); margin-bottom: 0.5em; }
h1 { font-size: 2.5rem; letter-spacing: -0.05em; }
h2 { font-size: 1.5rem; letter-spacing: -0.02em; }
h3 { font-size: 1.15rem; }
/* ── Background Effects ─────────────────────────────────────────────── */
.luxury-bg {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background: var(--color-bg);
  background-image:
    radial-gradient(at 0% 0%, rgba(0,43,91,0.05) 0px, transparent 50%),
    radial-gradient(at 100% 100%, rgba(225,217,209,0.2) 0px, transparent 50%);
}
.grain-overlay {
  position: fixed; inset: 0; z-index: 1; opacity: 0.03; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.water-line {
  height: 1px; margin: 24px 0;
  background: linear-gradient(90deg, transparent, var(--color-primary), transparent);
  opacity: 0.2;
}
/* ── Cards ──────────────────────────────────────────────────────────── */
.luxury-card {
  background: var(--color-white);
  border: 1px solid var(--color-sand);
  border-radius: 4px; overflow: hidden;
  transition: all 0.4s ease;
  box-shadow: 0 4px 6px -1px rgba(0,0,0,0.05), 0 2px 4px -1px rgba(0,0,0,0.03);
}
.luxury-card:hover {
  border-color: var(--color-primary);
  box-shadow: 0 20px 25px -5px rgba(0,0,0,0.1), 0 10px 10px -5px rgba(0,0,0,0.04);
}
.quote-card {
  background: var(--color-white); border: 1px solid var(--color-sand); border-radius: 8px;
  animation: pulse-glow 4s ease-in-out infinite; position: relative; overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,43,91,0.06);
}
.quote-card::after {
  content: ''; position: absolute; top: 0; left: -100%; width: 100%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
  animation: shimmer 6s ease-in-out infinite; pointer-events: none;
}
.stat-box {
  background: var(--color-white); border: 1px solid var(--color-sand);
  border-radius: 4px; padding: 20px; text-align: center;
}
/* ── Inputs ─────────────────────────────────────────────────────────── */
.luxury-input {
  width: 100%; padding: 12px 16px; background: var(--color-white);
  border: 1px solid var(--color-sand); border-radius: 4px;
  color: var(--color-charcoal); font-family: var(--font-sans); font-size: 14px;
  outline: none; transition: all 0.25s ease;
}
.luxury-input:focus { border-color: var(--color-primary); box-shadow: 0 0 0 1px var(--color-primary); }
.luxury-input::placeholder { color: #9CA3AF; }
select.luxury-input {
  cursor: pointer; appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23002B5B' fill='none' stroke-width='1.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 12px center; padding-right: 32px;
}
/* ── Buttons ────────────────────────────────────────────────────────── */
.btn-primary {
  padding: 14px 32px; background: var(--color-primary); border: none; border-radius: 4px;
  color: var(--color-white); font-weight: 600; font-size: 13px; font-family: var(--font-sans);
  text-transform: uppercase; letter-spacing: 0.05em; cursor: pointer;
  transition: all 0.3s ease; position: relative; overflow: hidden;
}
.btn-primary:hover { background: #001F3F; transform: translateY(-2px); box-shadow: 0 10px 20px rgba(0,43,91,0.2); }
.btn-primary:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }
.btn-ghost {
  padding: 12px 24px; background: transparent; border: 1px solid var(--color-primary);
  border-radius: 4px; color: var(--color-primary); font-weight: 500; font-size: 13px;
  font-family: var(--font-sans); cursor: pointer; transition: all 0.25s ease;
}
.btn-ghost:hover { background: var(--color-primary); color: var(--color-white); }
/* ── Labels & Text ──────────────────────────────────────────────────── */
.label-text {
  display: block; font-size: 11px; font-weight: 700; color: var(--color-primary);
  text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 6px;
}
.section-label {
  font-size: 11px; font-weight: 700; color: var(--color-primary);
  text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 24px;
}
/* ── Status Badges ──────────────────────────────────────────────────── */
.badge {
  display: inline-block; padding: 3px 10px; border-radius: 3px;
  font-size: 11px; font-weight: 600; font-family: var(--font-sans);
  text-transform: uppercase; letter-spacing: 0.05em;
}
.badge--success { background: rgba(16,185,129,0.1); color: #059669; }
.badge--warning { background: rgba(245,158,11,0.1); color: #D97706; }
.badge--error   { background: rgba(248,113,113,0.1); color: #DC2626; }
.badge--neutral { background: rgba(107,114,128,0.1); color: #6B7280; }
.badge--primary { background: rgba(0,43,91,0.1); color: var(--color-primary); }
/* ── Tables ─────────────────────────────────────────────────────────── */
.luxury-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.luxury-table th {
  text-align: left; padding: 12px 16px; font-weight: 700; font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.08em; color: var(--color-primary);
  border-bottom: 2px solid var(--color-sand);
}
.luxury-table td {
  padding: 12px 16px; border-bottom: 1px solid rgba(225,217,209,0.5);
  color: var(--color-charcoal); vertical-align: middle;
}
.luxury-table tr:hover td { background: rgba(0,43,91,0.02); }
/* ── Sidebar Navigation ─────────────────────────────────────────────── */
.sidebar-nav {
  position: relative; width: 240px; min-height: 100vh;
  background: var(--color-primary); color: var(--color-white);
  display: flex; flex-direction: column; padding: 24px 0;
  font-family: var(--font-sans); box-shadow: 4px 0 20px rgba(0,0,0,0.1);
  transition: width 0.3s ease; z-index: 100;
}
.sidebar-nav--collapsed { width: 64px; }
.sidebar-brand {
  padding: 0 20px 24px; font-family: var(--font-serif); font-size: 20px;
  font-weight: 700; letter-spacing: 0.02em; border-bottom: 1px solid rgba(255,255,255,0.1);
  margin-bottom: 16px; cursor: pointer; white-space: nowrap; overflow: hidden;
}
.sidebar-item {
  display: flex; align-items: center; gap: 12px; padding: 10px 20px;
  font-size: 13px; font-weight: 500; cursor: pointer; transition: all 0.2s ease;
  border-left: 3px solid transparent; white-space: nowrap;
}
.sidebar-item:hover { background: rgba(255,255,255,0.08); }
.sidebar-item--active { background: rgba(255,255,255,0.12); border-left-color: var(--color-gold); color: var(--color-gold); }
.sidebar-icon { font-size: 18px; width: 24px; text-align: center; flex-shrink: 0; }
.sidebar-label { opacity: 1; transition: opacity 0.2s ease; }
.sidebar-nav--collapsed .sidebar-label { opacity: 0; width: 0; overflow: hidden; }
/* ── Modal ──────────────────────────────────────────────────────────── */
.modal-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(45,45,45,0.8); backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center; padding: 20px;
  animation: fadeUp 0.25s ease both;
}
.modal-content {
  background: var(--color-white); border-radius: 4px; max-width: 560px; width: 100%;
  box-shadow: 0 25px 50px -12px rgba(0,0,0,0.25); animation: fadeUp 0.3s ease both;
}
/* ── Misc ───────────────────────────────────────────────────────────── */
.mono { font-family: var(--font-mono); }
.serif { font-family: var(--font-serif); }
.text-muted { color: var(--color-text-muted); }
.text-gold  { color: var(--color-gold); }
/* ── Responsive — Mobile Breakpoints ────────────────────────────────── */
@media (max-width: 480px) {
  .login-card,
  .onboarding-shell > form {
    padding: 24px 20px !important;
  }
  .login-card h1,
  .onboarding-shell h1 {
    font-size: 22px !important;
  }

  /* Hide sidebar on mobile */
  .sidebar-nav { display: none; }
}
@media (max-width: 768px) {
  /* Stack grid layouts to single column */
  [style*="display: grid"] {
    grid-template-columns: 1fr !important;
  }
}
/* ── Forgot password link style ─────────────────────────────────────── */
.forgot-link:hover {
  text-decoration: underline !important;
  opacity: 0.85;
}
