/* Economic Calendar — Design System V2 */

/* ── FILTERS BAR ── */
.ecal-filters-bar {
    background:var(--bg-2,#fff);border-bottom:1px solid #e2e8f0;padding:18px 0;
    position:relative;margin-top:0;box-shadow:0 4px 12px rgba(10,31,68,0.06);
    border-radius:18px 18px 0 0;max-width:1280px;margin:0 auto;
}
.ecal-filters-inner {
    display:flex;justify-content:space-between;align-items:center;gap:20px;
    flex-wrap:wrap;padding:0 24px;
}
.ecal-filters-main {display:flex;gap:20px;align-items:center;flex-wrap:wrap}
.ecal-impact-filter,.ecal-currency-filter {display:flex;gap:8px;align-items:center}
.ecal-filter-lbl {font-size:12px;color:#475569;font-weight:700;white-space:nowrap}
.ecal-impact-chip {
    width:36px;height:36px;border-radius:8px;background:#eef1f8;border:1.5px solid #e2e8f0;
    cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;font-size:14px;
}
.ecal-impact-chip.active.high {background:#fee2e2;border-color:#dc2626}
.ecal-impact-chip.active.med {background:#fef3c7;border-color:#f59e0b}
.ecal-impact-chip.active.low {background:#f3f4f6;border-color:#94a3b8}
.ecal-impact-chip:not(.active) {opacity:.4}
.ecal-currency-chips {display:flex;gap:4px;flex-wrap:wrap}
.ecal-cur-chip {
    padding:6px 12px;border:1.5px solid #e2e8f0;border-radius:8px;background:#eef1f8;
    font-family:inherit;font-size:12px;font-weight:800;color:#475569;cursor:pointer;transition:all .2s;
}
.ecal-cur-chip.active {background:var(--navy,#0a1f44);color:#fff;border-color:var(--navy,#0a1f44)}
.ecal-cur-chip:not(.active) {opacity:.5}
.ecal-filter-actions {display:flex;gap:8px}
.ecal-filter-btn {
    padding:8px 16px;border:1px solid #e2e8f0;border-radius:8px;background:var(--bg-2,#fff);
    font-family:inherit;font-size:12px;font-weight:700;color:#475569;cursor:pointer;transition:all .2s;
}
.ecal-filter-btn:hover {background:#eef1f8;border-color:#cbd5e1}
@media(max-width:720px){
    .ecal-filters-inner{flex-direction:column;align-items:stretch}
    .ecal-filters-main{flex-direction:column;gap:12px}
    .ecal-currency-chips{flex-wrap:wrap}
}

/* ── HERO ── */
.ecal-hero {
    background:
        radial-gradient(ellipse at 80% 20%, rgba(26,188,156,0.22), transparent 45%),
        radial-gradient(ellipse at 10% 90%, rgba(240,183,63,0.15), transparent 50%),
        linear-gradient(135deg, #051431 0%, var(--navy,#0a1f44) 50%, #112858 100%);
    color: #fff;
    padding: 70px 0 90px;
    position: relative;
    overflow: hidden;
    border-radius: 0 0 24px 24px;
    margin-bottom: 0;
}
.ecal-hero::before {
    content:'';position:absolute;inset:0;
    background-image:linear-gradient(rgba(255,255,255,0.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.03) 1px,transparent 1px);
    background-size:60px 60px;
    mask-image:radial-gradient(ellipse at center,black 30%,transparent 80%);
    -webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 80%);
    pointer-events:none;
}
.ecal-hero-inner {
    max-width:1280px;margin:0 auto;padding:0 20px;
    display:grid;grid-template-columns:1.2fr 1fr;gap:50px;align-items:center;
    position:relative;margin-bottom:50px;
}
.ecal-hero-content .ecal-h1 {font-size:42px;line-height:1.22;font-weight:800;margin-bottom:18px;letter-spacing:-0.5px}
.ecal-accent {background:linear-gradient(135deg,var(--gold,#f0b73f),#f5c869);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ecal-lead {font-size:17px;opacity:.88;line-height:1.85;margin-bottom:26px;max-width:600px}
.ecal-hero-badges {display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}
.ecal-hero-badge {background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.18);padding:8px 14px;border-radius:999px;font-size:13px;display:flex;align-items:center;gap:6px;backdrop-filter:blur(8px)}
.ecal-live-badge {background:rgba(22,163,74,0.15);border-color:rgba(22,163,74,0.4);color:#4ade80}
.ecal-dot {width:6px;height:6px;border-radius:50%;background:#22c55e;box-shadow:0 0 10px #22c55e;animation:ecalPulse 2s ease-in-out infinite}
@keyframes ecalPulse{0%,100%{opacity:1}50%{opacity:.4}}

/* Next Event Card */
.ecal-next-event {background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.15);border-radius:18px;padding:28px;backdrop-filter:blur(14px);position:relative;overflow:hidden}
.ecal-next-event::before {content:'';position:absolute;top:0;right:0;width:140px;height:140px;background:radial-gradient(circle,rgba(240,183,63,0.2),transparent);pointer-events:none}
.ecal-ne-label {font-size:12px;color:#f5c869;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px;display:flex;align-items:center;gap:8px;font-weight:800}
.ecal-ne-label::before {content:'';width:8px;height:8px;border-radius:50%;background:var(--gold,#f0b73f);box-shadow:0 0 10px var(--gold,#f0b73f);animation:ecalPulse 2s infinite}
.ecal-next-event h3 {font-size:22px;margin-bottom:6px;font-weight:800;line-height:1.4}
.ecal-ne-country {display:flex;align-items:center;gap:8px;font-size:14px;opacity:.85;margin-bottom:18px}
.ecal-ne-forecast {display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding-top:16px;border-top:1px dashed rgba(255,255,255,0.15)}
.ecal-ne-fc {text-align:center}
.ecal-ne-fc-k {font-size:11px;opacity:.7;margin-bottom:4px}
.ecal-ne-fc-v {font-size:16px;font-weight:800;color:#fff;direction:ltr}

/* Hero Stats */
.ecal-hero-stats {position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:18px;max-width:1280px;margin:0 auto;padding:0 20px}
.ecal-hero-stat {background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.12);border-radius:12px;padding:18px 20px;backdrop-filter:blur(10px);position:relative;overflow:hidden;border-right:4px solid var(--teal,#1abc9c)}
.ecal-stat-red {border-right-color:#dc2626}
.ecal-stat-gold {border-right-color:var(--gold,#f0b73f)}
.ecal-stat-violet {border-right-color:#a855f7}
.ecal-stat-num {font-size:32px;font-weight:800;line-height:1;margin-bottom:6px}
.ecal-stat-lbl {font-size:13px;opacity:.85;line-height:1.5}

/* ── CALENDAR TABLE ── */
.ecal-calendar-section {background:var(--bg-2,#fff);padding:0 0 50px}
.ecal-calendar-wrap {max-width:1280px;margin:0 auto;padding:0 20px;overflow:hidden}
.ecal-calendar-header {display:grid;grid-template-columns:90px 60px 3fr 80px 1fr 1fr 1fr;background:var(--navy,#0a1f44);color:#fff;padding:16px 24px;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:0.5px;gap:14px;border-radius:12px 12px 0 0;margin-top:20px}
.ecal-date-divider {background:linear-gradient(90deg,#eef1f8,transparent);padding:14px 24px;font-size:14px;font-weight:800;color:var(--navy,#0a1f44);border-bottom:1px solid #e2e8f0;border-top:1px solid #e2e8f0;display:flex;align-items:center;gap:12px}
.ecal-day-badge {background:var(--teal,#1abc9c);color:#fff;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:800;text-transform:uppercase}
.ecal-tomorrow .ecal-day-badge {background:var(--gold,#f0b73f);color:var(--navy,#0a1f44)}
.ecal-day-count {color:#94a3b8;font-size:12px;font-weight:700;margin-right:auto}

.ecal-row {display:grid;grid-template-columns:90px 60px 3fr 80px 1fr 1fr 1fr;padding:16px 24px;font-size:14px;border-bottom:1px solid #e2e8f0;align-items:center;gap:14px;transition:all .2s;position:relative}
.ecal-row:hover {background:#eef1f8}
.ecal-high-impact {border-right:3px solid #dc2626}
.ecal-med-impact {border-right:3px solid #f59e0b}
.ecal-low-impact {border-right:3px solid #94a3b8}
.ecal-released {background:linear-gradient(90deg,rgba(26,188,156,0.04),transparent)}

.ecal-cell-time {font-weight:800;color:var(--navy,#0a1f44);direction:ltr;font-variant-numeric:tabular-nums;font-size:15px}
.ecal-cell-country {font-size:20px;display:flex;align-items:center;gap:4px}
.ecal-cell-event {color:var(--text,#0f172a);font-weight:700}
.ecal-cell-impact {display:flex}
.ecal-impact-bulls {display:flex;gap:2px}
.ecal-bull {width:10px;height:14px;background:#e2e8f0;border-radius:1px;opacity:.3}
.ecal-bull-active {opacity:1}
.ecal-high-impact .ecal-bull-active {background:#dc2626}
.ecal-med-impact .ecal-bull-active {background:#f59e0b}
.ecal-low-impact .ecal-bull-active {background:#94a3b8}
.ecal-val {text-align:center;font-weight:800;font-size:14px;color:var(--text,#0f172a);direction:ltr;font-variant-numeric:tabular-nums}
.ecal-val-prev {color:#94a3b8;font-weight:700}
.ecal-val-forecast {color:#475569}
.ecal-val-actual {color:var(--teal,#1abc9c)}
.ecal-val-waiting {color:#94a3b8;font-weight:700}

/* ── SECTIONS ── */
.ecal-section {padding:70px 0;max-width:1280px;margin:0 auto}
.ecal-section-head {text-align:center;margin-bottom:50px;padding:0 20px}
.ecal-eyebrow {display:inline-block;background:linear-gradient(135deg,rgba(26,188,156,0.1),rgba(240,183,63,0.1));color:#0e8b7a;padding:6px 16px;border-radius:999px;font-size:13px;font-weight:700;margin-bottom:14px;border:1px solid rgba(26,188,156,0.2)}
.ecal-section-head h2 {font-size:34px;color:var(--navy,#0a1f44);font-weight:800;margin-bottom:12px;letter-spacing:-0.5px}
.ecal-section-head p {color:#475569;font-size:16px;max-width:640px;margin:0 auto}

/* ── SUMMARY CARDS ── */
.ecal-summary-grid {display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:0 20px}
.ecal-summary-card {background:var(--bg-2,#fff);border-radius:18px;padding:28px;box-shadow:0 1px 3px rgba(10,31,68,0.06);border:1px solid #e2e8f0;position:relative;overflow:hidden;transition:all .3s}
.ecal-summary-card:hover {transform:translateY(-5px);box-shadow:0 12px 36px rgba(10,31,68,0.12)}
.ecal-card-red {--card-accent:#dc2626}
.ecal-card-gold {--card-accent:#f0b73f}
.ecal-card-teal {--card-accent:#1abc9c}
.ecal-summary-card::before {content:'';position:absolute;top:0;right:0;width:100px;height:100px;background:radial-gradient(circle,var(--card-accent),transparent);opacity:.12;pointer-events:none}
.ecal-summary-head {display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:18px}
.ecal-summary-icon {width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;background:var(--card-accent);box-shadow:0 4px 12px rgba(0,0,0,0.1)}
.ecal-card-gold .ecal-summary-icon {color:var(--navy,#0a1f44)}
.ecal-summary-count {background:#eef1f8;color:var(--text,#0f172a);padding:4px 12px;border-radius:999px;font-size:12px;font-weight:800}
.ecal-summary-card h3 {font-size:18px;color:var(--navy,#0a1f44);font-weight:800;margin-bottom:6px}
.ecal-summary-sub {font-size:13px;color:#475569;margin-bottom:18px}
.ecal-summary-list {list-style:none;display:grid;gap:10px;padding:0;margin:0}
.ecal-summary-list li {display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:var(--bg,#f5f7fb);border-radius:10px;font-size:13px;border:1px solid #e2e8f0}
.ecal-ev-name {display:flex;align-items:center;gap:8px;color:var(--text,#0f172a);font-weight:700}
.ecal-ev-flag {font-size:15px}
.ecal-ev-time {color:#94a3b8;font-size:11px;font-weight:700;direction:ltr}

/* ── HOW TO READ ── */
.ecal-how-steps {display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:0 20px}
.ecal-how-step {background:var(--bg-2,#fff);border-radius:18px;padding:28px;border:1px solid #e2e8f0;position:relative;transition:all .3s}
.ecal-how-step:hover {transform:translateY(-5px);box-shadow:0 12px 36px rgba(10,31,68,0.12);border-color:var(--teal,#1abc9c)}
.ecal-step-num {position:absolute;top:-18px;right:24px;width:44px;height:44px;border-radius:12px;color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;box-shadow:0 4px 12px rgba(26,188,156,0.3)}
.ecal-step-1 {background:linear-gradient(135deg,#1abc9c,#0e8b7a)}
.ecal-step-2 {background:linear-gradient(135deg,#f0b73f,#c89320);color:var(--navy,#0a1f44)}
.ecal-step-3 {background:linear-gradient(135deg,#1a3a7e,#0a1f44)}
.ecal-step-4 {background:linear-gradient(135deg,#dc2626,#b91c1c)}
.ecal-step-icon {font-size:32px;margin-bottom:14px;margin-top:8px}
.ecal-how-step h4 {font-size:17px;color:var(--navy,#0a1f44);font-weight:800;margin-bottom:8px}
.ecal-how-step p {font-size:13px;color:#475569;line-height:1.7;margin:0}

/* ── BROKER CTA ── */
.ecal-broker-cta {background:linear-gradient(135deg,var(--navy,#0a1f44) 0%,#1a3a7e 100%);color:#fff;padding:70px 20px;position:relative;overflow:hidden;border-radius:24px;margin:30px auto;max-width:1280px}
.ecal-broker-cta::before {content:'';position:absolute;top:0;right:0;bottom:0;width:50%;background:radial-gradient(circle at right,rgba(240,183,63,0.15),transparent 70%)}
.ecal-cta-grid {display:grid;grid-template-columns:1.3fr 1fr;gap:50px;align-items:center;position:relative;max-width:1240px;margin:0 auto}
.ecal-cta-grid h2 {font-size:32px;margin-bottom:14px;line-height:1.3;letter-spacing:-0.5px}
.ecal-cta-accent {color:#f5c869}
.ecal-cta-grid > div:first-child > p {opacity:.88;font-size:16px;margin-bottom:24px;line-height:1.85}
.ecal-cta-features {display:flex;flex-wrap:wrap;gap:12px;margin-bottom:28px}
.ecal-cta-feature {display:flex;align-items:center;gap:8px;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);padding:8px 14px;border-radius:999px;font-size:13px}
.ecal-cta-feature::before {content:'✓';color:#2dd4bf;font-weight:800}
.ecal-cta-buttons {display:flex;gap:14px;flex-wrap:wrap}
.ecal-btn-primary,.ecal-btn-secondary {padding:14px 26px;border-radius:12px;font-family:inherit;font-size:15px;font-weight:800;text-decoration:none;transition:all .25s;display:inline-flex;align-items:center;gap:8px}
.ecal-btn-primary {background:linear-gradient(135deg,#f0b73f,#c89320);color:var(--navy,#0a1f44);box-shadow:0 8px 20px rgba(240,183,63,0.3)}
.ecal-btn-primary:hover {transform:translateY(-2px);box-shadow:0 12px 28px rgba(240,183,63,0.4);color:var(--navy,#0a1f44)}
.ecal-btn-secondary {background:rgba(255,255,255,0.1);color:#fff;border:1.5px solid rgba(255,255,255,0.25)}
.ecal-btn-secondary:hover {background:rgba(255,255,255,0.18);color:#fff}

.ecal-news-preview {background:var(--bg-2,#fff);color:var(--text,#0f172a);border-radius:18px;padding:26px;box-shadow:0 24px 60px rgba(10,31,68,0.18)}
.ecal-news-label {font-size:11px;color:#dc2626;font-weight:800;text-transform:uppercase;letter-spacing:1px;display:flex;align-items:center;gap:8px;margin-bottom:12px}
.ecal-news-label::before {content:'';width:8px;height:8px;border-radius:50%;background:#dc2626;animation:ecalPulse 1.5s infinite}
.ecal-news-preview h4 {font-size:17px;color:var(--navy,#0a1f44);margin-bottom:16px;line-height:1.5}
.ecal-mini-row {display:flex;justify-content:space-between;padding:8px 0;font-size:13px;border-top:1px dashed #e2e8f0}
.ecal-mini-k {color:#475569}
.ecal-mini-v {font-weight:800;color:var(--navy,#0a1f44);direction:ltr}

/* ── RELATED TOOLS ── */
.ecal-tools-grid {display:grid;grid-template-columns:repeat(3,1fr);gap:20px;padding:0 20px}
.ecal-tool-card {background:var(--bg,#f5f7fb);border:1.5px solid #e2e8f0;border-radius:12px;padding:24px;text-decoration:none;color:inherit;transition:all .25s;display:flex;align-items:center;gap:18px}
.ecal-tool-card:hover {border-color:var(--teal,#1abc9c);background:var(--bg-2,#fff);box-shadow:0 4px 12px rgba(10,31,68,0.08);transform:translateY(-3px);color:inherit}
.ecal-tool-icon {width:54px;height:54px;background:linear-gradient(135deg,var(--teal,#1abc9c),#0e8b7a);border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;flex-shrink:0}
.ecal-tool-card:nth-child(2) .ecal-tool-icon {background:linear-gradient(135deg,#f0b73f,#c89320);color:var(--navy,#0a1f44)}
.ecal-tool-card:nth-child(3) .ecal-tool-icon {background:linear-gradient(135deg,#1a3a7e,#0a1f44)}
.ecal-tool-card:nth-child(4) .ecal-tool-icon {background:linear-gradient(135deg,#dc2626,#b91c1c)}
.ecal-tool-card:nth-child(5) .ecal-tool-icon {background:linear-gradient(135deg,#0e8b7a,#1a3a7e)}
.ecal-tool-card:nth-child(6) .ecal-tool-icon {background:linear-gradient(135deg,#c89320,#f0b73f);color:var(--navy,#0a1f44)}
.ecal-tool-card h4 {font-size:16px;color:var(--navy,#0a1f44);font-weight:800;margin-bottom:4px}
.ecal-tool-card p {font-size:13px;color:#475569;margin:0}

/* ── RESPONSIVE ── */
@media(max-width:980px){
    .ecal-hero-inner{grid-template-columns:1fr;gap:40px}
    .ecal-hero-content .ecal-h1{font-size:32px}
    .ecal-hero-stats{grid-template-columns:repeat(2,1fr)}
    .ecal-summary-grid,.ecal-how-steps{grid-template-columns:1fr 1fr}
    .ecal-cta-grid,.ecal-tools-grid{grid-template-columns:1fr}
    .ecal-tools-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:720px){
    .ecal-calendar-wrap{overflow-x:auto}
    .ecal-calendar-header,.ecal-row{grid-template-columns:70px 44px 200px 60px 80px 80px 80px;min-width:720px}
    .ecal-summary-grid,.ecal-how-steps,.ecal-tools-grid{grid-template-columns:1fr}
    .ecal-section-head h2{font-size:26px}
    .ecal-section{padding:50px 0}
    .ecal-hero{padding:40px 0 70px}
    .ecal-hero-content .ecal-h1{font-size:26px}
    .ecal-hero-stats{grid-template-columns:1fr 1fr}
    .ecal-cta-grid h2{font-size:24px}
}
@media(max-width:480px){
    .ecal-hero-stats{grid-template-columns:1fr}
}

/* CV-038: extracted from inline styles in tools/economic-calendar.blade.php */
.ecal-cell-impact--center { justify-content: center; }
.ecal-section--bg { background: var(--bg, #f5f7fb); }
.ecal-section--bg-card { background: var(--bg-2, #fff); }
