/* ============================================================
   AlgoVik — home.css
   P&L dashboard section styled to match strategy-pnl.html
   ============================================================ */

/* ── HERO (unchanged from V1.0) ── */
.hero {
  position: relative; min-height: 100vh;
  display: flex; flex-direction: column;
  justify-content: center; align-items: center;
  padding: 120px 6vw 80px; overflow: hidden; text-align: center;
}
#particle-canvas { position:absolute; top:0; left:0; width:100%; height:100%; z-index:0; display:block; }
.hero-grid {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(27,79,255,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(27,79,255,0.06) 1px, transparent 1px);
  background-size: 60px 60px; z-index:0;
}
.hero-content { position:relative; z-index:2; max-width:900px; display:flex; flex-direction:column; align-items:center; }
.hero-eyebrow {
  font-family: var(--font-mono); font-size:0.75rem; color:var(--cyan);
  letter-spacing:3px; text-transform:uppercase; margin-bottom:1.5rem;
  display:flex; align-items:center; gap:12px;
}
.hero-eyebrow::before { content:''; display:block; width:40px; height:1px; background:var(--cyan); }
.hero-h1 { font-family:var(--font-display); font-size:clamp(5rem,12vw,11rem); line-height:0.9; color:var(--ice); letter-spacing:2px; margin-bottom:1.5rem; }
.hero-h1 span { color:var(--cobalt); display:block; }
.hero-sub { font-size:clamp(1rem,2vw,1.2rem); color:var(--ice-dim); max-width:520px; margin-bottom:2.5rem; font-weight:300; line-height:1.7; }
.hero-btns { display:flex; gap:1rem; flex-wrap:wrap; justify-content:center; }
.scroll-ind { position:absolute; bottom:40px; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:8px; opacity:0.5; z-index:2; }
.scroll-ind span { font-family:var(--font-mono); font-size:0.7rem; letter-spacing:2px; color:var(--ice-dim); }
.scroll-arrow { width:20px; height:20px; border-right:1px solid var(--ice-dim); border-bottom:1px solid var(--ice-dim); transform:rotate(45deg); animation:scrollBounce 1.5s infinite; }
@keyframes scrollBounce { 0%,100%{transform:rotate(45deg) translateY(0)} 50%{transform:rotate(45deg) translateY(5px)} }


/* ═══════════════════════════════════════════════════════════
   P&L DASHBOARD — matches strategy-pnl.html exactly
   Design tokens:
     bg-0: #070b14  bg-card: #0f1729  bg-2: #111827  bg-3: #1a2236
     accent: #00d4a0   red: #ff4d6d   amber: #f59e0b
     border: rgba(255,255,255,0.07)   border-strong: rgba(255,255,255,0.13)
     text-0: #f0f4ff  text-1: #a8b4cc  text-2: #5a6a85
     radius-sm:8px  radius-md:12px  radius-lg:18px
═══════════════════════════════════════════════════════════ */

/* Override dashboard-specific tokens scoped inside pnl-section */
.pnl-section {
  --ds-bg-0:    #060A1A;
  --ds-bg-1:    #0D1435;
  --ds-bg-2:    #111827;
  --ds-bg-3:    #1a2236;
  --ds-card:    #0D1435;
  --ds-border:  rgba(255,255,255,0.07);
  --ds-border-s:rgba(255,255,255,0.13);
  --ds-accent:  #00d4a0;
  --ds-red:     #ff4d6d;
  --ds-amber:   #f59e0b;
  --ds-blue:    #4d9fff;
  --ds-purple:  #a78bfa;
  --ds-teal:    #22d3ee;
  --ds-t0:      #f0f4ff;
  --ds-t1:      #a8b4cc;
  --ds-t2:      #5a6a85;
  --ds-r-sm:    8px;
  --ds-r-md:    12px;
  --ds-r-lg:    18px;

  background: var(--ds-bg-0);
  padding: 72px 28px 80px;
  max-width: 100%;
}

/* inner wrapper to cap width like dashboard */
.pnl-inner {
  max-width: 1260px;
  margin: 0 auto;
}

/* Page hero area */
.pnl-hero { margin-bottom: 36px; }
.pnl-strategy-label {
  font-size: 11px; font-weight: 600; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--ds-accent); margin-bottom: 8px;
  font-family: var(--font-mono);
}
.pnl-strategy-title {
  font-family: var(--font-sans); font-size: 34px; font-weight: 800;
  color: var(--ds-t0); letter-spacing: -0.5px; line-height: 1.1;
}
.pnl-strategy-sub { font-size: 13px; color: var(--ds-t2); margin-top: 6px; }

/* Live badge — pill shape like dashboard */
.live-badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(0,212,160,0.1); border: 1px solid rgba(0,212,160,0.2);
  color: var(--ds-accent); font-size: 11px; font-weight: 600;
  letter-spacing: 0.8px; text-transform: uppercase;
  padding: 5px 12px; border-radius: 100px; margin-top: 14px;
  font-family: var(--font-mono);
}
.live-dot-green {
  width: 6px; height: 6px; background: var(--ds-accent);
  border-radius: 50%; animation: pulseLive 2s infinite;
}
@keyframes pulseLive { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.5;transform:scale(0.7)} }

/* Section title — matches .section-title in dashboard */
.pnl-section-label {
  font-family: var(--font-sans); font-size: 14px; font-weight: 700;
  color: var(--ds-t1); letter-spacing: 1px; text-transform: uppercase;
  margin-bottom: 14px;
  display: flex; align-items: center; gap: 8px;
}
.pnl-section-label::after { content:''; flex:1; height:1px; background:var(--ds-border); }

/* ── METRIC CARDS — exactly like .metrics-grid in dashboard ── */
.pnl-metrics-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 14px;
  margin-bottom: 28px;
}

.pnl-metric-card {
  background: var(--ds-card);
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-r-md);
  padding: 18px 20px;
  position: relative; overflow: hidden;
  transition: border-color 0.2s, transform 0.2s;
}
.pnl-metric-card::before {
  content:''; position:absolute; top:0; left:0; right:0;
  height: 2px; border-radius: 2px 2px 0 0;
}
.pnl-metric-card:hover { border-color: var(--ds-border-s); transform: translateY(-2px); }

/* Accent bar colors */
.pnl-metric-card.c-green::before  { background: var(--ds-accent); }
.pnl-metric-card.c-red::before    { background: var(--ds-red); }
.pnl-metric-card.c-gold::before   { background: var(--ds-amber); }
.pnl-metric-card.c-cobalt::before { background: var(--ds-blue); }
.pnl-metric-card.c-purple::before { background: var(--ds-purple); }
.pnl-metric-card.c-cyan::before   { background: var(--ds-teal); }

.pnl-metric-label {
  font-size: 11px; font-weight: 500; color: var(--ds-t2);
  letter-spacing: 0.6px; text-transform: uppercase; margin-bottom: 10px;
  font-family: var(--font-body);
}
.pnl-metric-value {
  font-family: var(--font-mono); font-size: 22px; font-weight: 500;
  line-height: 1; color: var(--ds-t0);
}
.pnl-metric-value.v-profit { color: var(--ds-accent); }
.pnl-metric-value.v-loss   { color: var(--ds-red); }
.pnl-metric-value.v-warn   { color: var(--ds-amber); }
.pnl-metric-value.v-cyan   { color: var(--ds-teal); }
.pnl-metric-value.v-cobalt { color: var(--ds-blue); }
.pnl-metric-value.v-purple { color: var(--ds-purple); }

.pnl-metric-sub { font-size: 11px; color: var(--ds-t2); margin-top: 6px; }

/* ── CALENDAR — matches .calendar-section in dashboard ── */
.pnl-calendar-wrap {
  background: var(--ds-card);
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-r-lg);
  padding: 24px; margin-bottom: 28px;
}
.cal-legend { display:flex; gap:16px; flex-wrap:wrap; margin-bottom:14px; }
.cal-legend-item {
  display:inline-flex; align-items:center; gap:6px;
  font-size: 11px; color: var(--ds-t2); font-family: var(--font-mono);
}
.cal-legend-dot { width:10px; height:10px; border-radius:3px; flex-shrink:0; }

.cal-nav { display:flex; align-items:center; gap:12px; }
.cal-arrow {
  width:32px; height:32px;
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-r-sm);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; color:var(--ds-t1); font-size:13px; flex-shrink:0;
  transition: border-color 0.2s, color 0.2s, background 0.2s;
  user-select:none;
}
.cal-arrow:hover { border-color:var(--ds-border-s); color:var(--ds-t0); background:var(--ds-bg-3); }
.cal-arrow.disabled { opacity:0.2; pointer-events:none; }

.calendar-scroll { overflow:hidden; flex:1; }
.calendar-track { display:flex; gap:26px; transition:transform 0.35s cubic-bezier(0.4,0,0.2,1); }
.calendar-track.centered { justify-content:center; }

.month-block { flex-shrink:0; width:135px; }
.month-name { font-family:var(--font-sans); font-size:12px; font-weight:700; color:var(--ds-t1); margin-bottom:8px; }
.weekday-row { display:grid; grid-template-columns:repeat(5,22px); gap:4px; margin-bottom:4px; }
.weekday-label { font-size:9px; font-weight:600; color:var(--ds-t2); text-align:center; letter-spacing:0.5px; }
.day-grid { display:grid; grid-template-columns:repeat(5,22px); gap:4px; }

.day-cell {
  width:22px; height:22px;
  border-radius: 5px;        /* matches dashboard */
  background: var(--ds-bg-3);
  cursor:default;
  transition: transform 0.15s, filter 0.15s;
}
.day-cell.has-trade { cursor:pointer; }
.day-cell.has-trade:hover { transform:scale(1.25); filter:brightness(1.3); }
.day-cell.blank { visibility:hidden; }
.day-cell.selected { outline:2px solid #fff; outline-offset:1px; }

/* exact colors from dashboard */
.day-cell.spread-profit-strong { background: #00d4a0; }
.day-cell.spread-profit-light  { background: #007a5c; }
.day-cell.spread-loss-light    { background: #8f2437; }
.day-cell.spread-loss-strong   { background: #ff4d6d; }
.day-cell.spread-open          { background: #3a4a6a; border:1px dashed rgba(255,255,255,0.3); }

.month-pnl-row { margin-top:8px; font-family:var(--font-mono); font-size:11px; font-weight:500; color:var(--ds-t2); }
.month-pnl-row.profit { color:var(--ds-accent); }
.month-pnl-row.loss   { color:var(--ds-red); }

/* ── SPREAD PANEL — matches .spread-section in dashboard ── */
.spread-panel {
  background: var(--ds-card);
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-r-lg);
  margin-bottom: 28px; overflow:hidden;
}
.spread-panel-header {
  padding:18px 24px; border-bottom:1px solid var(--ds-border);
  display:flex; align-items:center; justify-content:space-between;
}
.spread-panel-title { font-family:var(--font-sans); font-size:14px; font-weight:700; color:var(--ds-t0); }
.spread-count-badge {
  font-size:11px; background:var(--ds-bg-3);
  border:1px solid var(--ds-border);
  color:var(--ds-t1); padding:3px 10px;
  border-radius:100px; font-family:var(--font-mono);
}
.spread-empty { text-align:center; padding:40px; color:var(--ds-t2); font-size:13px; }
.spread-empty svg { display:block; margin:0 auto 12px; opacity:0.3; }
.spread-body { padding:20px 24px; }

/* spread card — matches .scard */
.scard {
  background: var(--ds-bg-2);
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-r-md);
  margin-bottom:16px; overflow:hidden;
}
.scard:last-child { margin-bottom:0; }
.scard-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 16px; border-bottom:1px solid var(--ds-border);
}
.scard-title { font-family:var(--font-sans); font-size:13px; font-weight:700; color:var(--ds-t0); }
.scard-dates { font-size:11px; color:var(--ds-t2); margin-top:2px; }
.scard-pnl { font-family:var(--font-mono); font-size:16px; font-weight:500; }
.scard-pnl.profit { color:var(--ds-accent); }
.scard-pnl.loss   { color:var(--ds-red); }
.scard-pnl-pct    { font-size:11px; color:var(--ds-t2); text-align:right; margin-top:2px; }

.leg-table { width:100%; border-collapse:collapse; font-size:12px; }
.leg-table th {
  text-align:left; font-size:10px; font-weight:600; color:var(--ds-t2);
  letter-spacing:1px; text-transform:uppercase; padding:8px 16px;
  background:var(--ds-bg-0); border-bottom:1px solid var(--ds-border);
}
.leg-table td { padding:9px 16px; color:var(--ds-t1); border-bottom:1px solid var(--ds-border); font-family:var(--font-mono); font-size:12px; }
.leg-table tr:last-child td { border-bottom:none; }
.leg-table tbody tr:hover { background:var(--ds-bg-3); }
.leg-label-badge {
  display:inline-block; font-size:10px; font-weight:600;
  padding:2px 8px; border-radius:100px; letter-spacing:0.5px;
  background:var(--ds-bg-3); color:var(--ds-t1); border:1px solid var(--ds-border);
}
.instr-name { color:var(--ds-t0); font-size:11px; }
.scard-footer {
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 16px; background:var(--ds-bg-0);
  border-top:1px solid var(--ds-border);
  font-family:var(--font-mono); font-size:12px; color:var(--ds-t2);
}

/* ── CHARTS — matches .charts-grid + .chart-card in dashboard ── */
.pnl-charts-grid {
  display:grid; grid-template-columns:3fr 2fr;
  gap:18px; margin-bottom:28px;
}
.chart-panel {
  background: var(--ds-card);
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-r-lg);
  padding:24px;
  transition: border-color 0.2s;
}
.chart-panel:hover { border-color:var(--ds-border-s); }
.chart-panel-title { font-family:var(--font-sans); font-size:14px; font-weight:700; color:var(--ds-t0); }
.chart-panel-sub   { font-size:11px; color:var(--ds-t2); margin-top:2px; margin-bottom:20px; }
.chart-canvas-wrap { position:relative; width:100%; height:220px; }

.pie-wrap { display:flex; align-items:center; gap:20px; height:220px; }
.pie-canvas-wrap { position:relative; width:160px; height:160px; flex-shrink:0; }
.pie-legend { flex:1; }
.legend-item { display:flex; align-items:center; gap:8px; font-size:11px; color:var(--ds-t1); margin-bottom:7px; font-family:var(--font-mono); }
.legend-dot { width:8px; height:8px; border-radius:2px; flex-shrink:0; }

/* ── HOME CONTACT FORM ── */
.form-section { padding:80px 4vw; background:var(--navy-dark); }
.form-card {
  background:var(--navy-mid); border:1px solid rgba(27,79,255,0.25);
  padding:3rem clamp(1.5rem,4vw,4rem); max-width:900px; margin:0 auto;
}
.form-title { font-family:var(--font-display); font-size:clamp(2rem,4vw,3.2rem); color:var(--ice); letter-spacing:2px; margin-bottom:0.5rem; }
.form-sub { font-size:0.9rem; color:var(--ice-dim); margin-bottom:2.5rem; max-width:560px; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-group.full { grid-column:1/-1; }
.form-group label { font-family:var(--font-mono); font-size:0.62rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--ice-dim); }
.form-group input, .form-group select, .form-group textarea {
  background:rgba(255,255,255,0.03); border:1px solid rgba(27,79,255,0.25);
  color:var(--ice); padding:12px 14px; font-family:var(--font-body); font-size:0.9rem;
  transition:border-color 0.2s; outline:none; width:100%;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  border-color:var(--cobalt); box-shadow:0 0 0 1px rgba(27,79,255,0.2);
}
.form-group input::placeholder, .form-group textarea::placeholder { color:rgba(232,240,255,0.18); }
.form-group select option { background:var(--navy-mid); color:var(--ice); }
.form-group textarea { resize:vertical; min-height:100px; }
.phone-wrap { display:flex; gap:0; width:100%; }
.phone-wrap select { width:90px; border-right:none; flex-shrink:0; }
.phone-wrap input  { flex:1; }
.form-note { font-size:0.72rem; color:rgba(232,240,255,0.25); text-align:center; margin-top:1rem; line-height:1.6; }
