/* Economic Calendar Theme (v2) */

@import url('./variables.css');
@import url('./base.css');
@import url('./components.css');
@import url('./layout.css');

.calendar-shell {
  padding: clamp(2.5rem, 6vw, 4rem) var(--container-padding);
}

.calendar-shell__inner {
  width: min(1180px, 100%);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: clamp(1.75rem, 5vw, 3rem);
}

.calendar-hero {
  position: relative;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: clamp(1.5rem, 4vw, 2.5rem);
  border: 1px solid rgba(148, 163, 184, 0.18);
  border-radius: var(--radius-3xl, 2rem);
  padding: clamp(2rem, 5vw, 3rem);
  background-color: #060606;
  overflow: hidden;
}

.calendar-hero::after {
  content: '';
  position: absolute;
  inset: -25% 0 auto;
  opacity: 0.6;
  pointer-events: none;
}

.calendar-hero__content {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  color: rgba(226, 232, 240, 0.85);
}

.calendar-hero__eyebrow {
  font-size: var(--text-xs);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(148, 163, 184, 0.65);
}

.calendar-hero__title {
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: var(--font-semibold);
  color: #f8fafc;
  margin: 0;
}

.calendar-hero__subtitle {
  font-size: var(--text-base);
  line-height: 1.7;
  color: rgba(226, 232, 240, 0.72);
  margin: 0;
}

.calendar-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.calendar-stats {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: var(--space-sm);
}

.calendar-stat {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  padding: 0.85rem 1rem;
  border-radius: var(--radius-xl);
  
  border: 1px solid rgba(148, 163, 184, 0.18);
  color: rgba(226, 232, 240, 0.82);
}

.calendar-stat__label {
  font-size: var(--text-xs);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(148, 163, 184, 0.6);
}

.calendar-stat__value {
  font-size: clamp(1.4rem, 3vw, 1.9rem);
  font-weight: var(--font-semibold);
  color: #f8fafc;
}

@media (min-width: 640px) {
  .calendar-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.calendar-card {
  
  border: 1px solid rgba(148, 163, 184, 0.18);
  border-radius: var(--radius-3xl, 2rem);
  padding: clamp(1.5rem, 4vw, 2.25rem);
  display: flex;
  flex-direction: column;
  gap: clamp(1.5rem, 4vw, 2.25rem);
  background-color: #060606;
  overflow: hidden;
}

.calendar-controls {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.calendar-controls__row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  align-items: center;
  justify-content: space-between;
}

.calendar-date-control {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  padding: 0.75rem 1rem;
  border-radius: 0.95rem;
  border: 1px solid rgba(148, 163, 184, 0.2);

  color: rgba(226, 232, 240, 0.78);
}

.calendar-date-control label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.85rem;
  color: rgba(148, 163, 184, 0.7);
}

.calendar-date-control input[type="date"] {
  border: none;
  background: transparent;
  color: #f8fafc;
  font-size: 0.9rem;
  padding: 0.35rem 0.5rem;
}

.calendar-date-control input[type="date"]:focus {
  outline: none;
}

.calendar-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.calendar-btn,
.calendar-filter {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.55rem 1.15rem;
  border-radius: 0.85rem;
  border: 1px solid rgba(148, 163, 184, 0.2);
  background: rgba(148, 163, 184, 0.08);
  color: rgba(226, 232, 240, 0.78);
  font-size: 0.85rem;
  font-weight: 600;
  cursor: pointer;
  transition: background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);
}

.calendar-btn:hover,
.calendar-filter:hover {
  color: #f8fafc;
  background: rgba(148, 163, 184, 0.16);
  border-color: rgba(148, 163, 184, 0.28);
}

.calendar-btn.primary {
  background: rgba(99, 102, 241, 0.22);
  border-color: rgba(99, 102, 241, 0.35);
  color: #f8fafc;
}

.calendar-btn.primary:hover {
  background: rgba(99, 102, 241, 0.28);
  border-color: rgba(99, 102, 241, 0.45);
}

.calendar-btn.outline {
  background: transparent;
  border-color: rgba(148, 163, 184, 0.24);
}

.calendar-btn.outline:hover {
  background: rgba(148, 163, 184, 0.16);
  border-color: rgba(148, 163, 184, 0.32);
}

.calendar-filter.active {
  background: rgba(99, 102, 241, 0.2);
  border-color: rgba(99, 102, 241, 0.32);
  color: #f8fafc;
  box-shadow: 0 12px 28px rgba(12, 18, 31, 0.4);
}

.calendar-advanced {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  padding: 1.25rem;
  border-radius: var(--radius-xl);
  border: 1px solid rgba(148, 163, 184, 0.16);

}

.calendar-advanced__grid {
  display: grid;
  gap: var(--space-sm);
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.calendar-search,
.calendar-select {
  width: 100%;
  border-radius: 0.85rem;
  border: 1px solid rgba(148, 163, 184, 0.2);
  background: rgba(13, 17, 25, 0.75);
  color: rgba(226, 232, 240, 0.85);
  padding: 0.65rem 0.9rem;
  font-size: 0.9rem;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);
}

.calendar-search:focus,
.calendar-select:focus,
.calendar-date-input:focus {
  border-color: rgba(99, 102, 241, 0.45);
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.18);
  outline: none;
  
}

.calendar-date-range {
  display: none;
  flex-direction: column;
  gap: var(--space-sm);
  padding: 1rem;
  border-radius: var(--radius-xl);
  border: 1px dashed rgba(148, 163, 184, 0.24);
  background: rgba(13, 17, 25, 0.8);
}

.calendar-date-range.active {
  display: flex;
}

.calendar-date-inputs {
  display: grid;
  gap: var(--space-sm);
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.calendar-date-group {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  color: rgba(148, 163, 184, 0.7);
  font-size: 0.85rem;
}

.calendar-date-input {
  border-radius: 0.85rem;
  border: 1px solid rgba(148, 163, 184, 0.2);

  color: rgba(226, 232, 240, 0.85);
  padding: 0.65rem 0.9rem;
}

.calendar-date-actions {
  display: flex;
  gap: var(--space-sm);
  justify-content: flex-end;
}

.calendar-stats-row {
  display: grid;
  gap: var(--space-sm);
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.calendar-stats-card {

  border: 1px solid rgba(148, 163, 184, 0.16);
  border-radius: var(--radius-xl);
  padding: 1rem 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  color: rgba(226, 232, 240, 0.82);
}

.calendar-stats-card .label {
  font-size: 0.75rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(148, 163, 184, 0.6);
}

.calendar-stats-card .value {
  font-size: 1.4rem;
  font-weight: var(--font-semibold);
  color: #f8fafc;
}

.calendar-timezone {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.85rem;
  color: rgba(148, 163, 184, 0.72);
}

.calendar-loading {
  display: none;
  flex-direction: column;
  gap: 0.75rem;
  align-items: center;
  justify-content: center;
  padding: 2rem 0;
  color: rgba(148, 163, 184, 0.7);
}

.calendar-loading.active {
  display: flex;
}

.calendar-table-wrapper {
  border-radius: var(--radius-2xl);
  border: 1px solid rgba(148, 163, 184, 0.16);
  
  overflow: hidden;
  box-shadow: 0 0 0 1px rgba(148, 163, 184, 0.1);
}

.economic-table {
  width: 100%;
  border-collapse: collapse;
  color: rgba(226, 232, 240, 0.85);
  font-size: 0.9rem;
}

.economic-table thead {
  
}

.economic-table th {
  padding: 0.85rem 1rem;
  font-size: 0.75rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(148, 163, 184, 0.65);
  text-align: left;
  border-bottom: 1px solid rgba(148, 163, 184, 0.12);
}

.economic-table td {
  padding: 0.85rem 1rem;
  border-bottom: 1px solid rgba(148, 163, 184, 0.08);
}

.economic-table tbody tr:hover {
  background: rgba(148, 163, 184, 0.08);
}

.impact-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.35rem 0.75rem;
  border-radius: 0.85rem;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
}

.impact-low {
  background: rgba(148, 163, 184, 0.12);
  color: rgba(226, 232, 240, 0.75);
  border: 1px solid rgba(148, 163, 184, 0.2);
}

.impact-medium {
  background: rgba(59, 130, 246, 0.18);
  color: rgba(191, 219, 254, 0.95);
  border: 1px solid rgba(59, 130, 246, 0.32);
}

.impact-high {
  background: rgba(239, 68, 68, 0.18);
  color: rgba(254, 202, 202, 0.95);
  border: 1px solid rgba(239, 68, 68, 0.32);
}

.flag-icon {
  border-radius: 0.65rem;
  box-shadow: 0 4px 10px rgba(8, 11, 19, 0.35);
}

.calendar-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
  padding: 2.5rem;
  border-radius: var(--radius-2xl);
  border: 1px dashed rgba(148, 163, 184, 0.24);
  
  color: rgba(148, 163, 184, 0.72);
  text-align: center;
}

/* Month View */
.calendar-month-shell {
  padding: clamp(2.5rem, 6vw, 4rem) var(--container-padding);
}

.calendar-month-shell .calendar-shell__inner {
  gap: clamp(1.75rem, 4vw, 2.5rem);
}

.calendar-month-card {
  background-color: #060606;
  border: 1px solid rgba(148, 163, 184, 0.18);
  border-radius: var(--radius-3xl, 2rem);
  padding: clamp(1.75rem, 4vw, 2.5rem);
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
  overflow: hidden;
}

.calendar-month-controls {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  align-items: center;
  justify-content: space-between;
}

.month-nav {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
}

.month-label {
  font-size: 1.25rem;
  font-weight: var(--font-semibold);
  color: #f8fafc;
}

.calendar-month-grid {
  border-radius: var(--radius-2xl);
  border: 1px solid rgba(148, 163, 184, 0.16);
  
  overflow: hidden;
}

.calendar-scroll-wrapper {
  overflow-x: auto;
  scrollbar-width: thin;
  scrollbar-color: rgba(148, 163, 184, 0.24) transparent;
}

.calendar-scroll-wrapper::-webkit-scrollbar {
  height: 6px;
}

.calendar-scroll-wrapper::-webkit-scrollbar-thumb {
  background: rgba(148, 163, 184, 0.24);
  border-radius: 0.85rem;
}

.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(180px, 1fr));
  
}

.calendar-header {
  padding: 0.9rem 1rem;
  font-size: 0.8rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(148, 163, 184, 0.6);
  border-bottom: 1px solid rgba(148, 163, 184, 0.12);
}

.calendar-day {
  min-height: 160px;
  padding: 0.9rem 1rem;
  border-right: 1px solid rgba(148, 163, 184, 0.08);
  border-bottom: 1px solid rgba(148, 163, 184, 0.08);
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  color: rgba(226, 232, 240, 0.82);
}

.calendar-day.today {
  background: rgba(99, 102, 241, 0.16);
  border-color: rgba(99, 102, 241, 0.32);
}

.calendar-day .day-number {
  font-size: 1rem;
  font-weight: var(--font-semibold);
  color: #f8fafc;
}

.calendar-day .day-events {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}



.calendar-day .event-item {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.35rem 0.55rem;
  border-radius: 0.65rem;
  background: rgba(148, 163, 184, 0.12);
  border: 1px solid rgba(148, 163, 184, 0.2);
  font-size: 0.75rem;
  color: rgba(226, 232, 240, 0.82);
}

.calendar-day .event-item.high-impact {
  background: rgba(239, 68, 68, 0.18);
  border-color: rgba(239, 68, 68, 0.32);
  color: rgba(254, 202, 202, 0.95);
}

.calendar-day .event-flag {
  width: 16px;
  height: 12px;
  border-radius: 0.45rem;
  box-shadow: 0 4px 10px rgba(8, 11, 19, 0.35);
}

.calendar-day .more-events {
  font-size: 0.75rem;
  color: rgba(148, 163, 184, 0.7);
}

.calendar-day .event-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.35rem 0.65rem;
  border-radius: 0.75rem;
  background: rgba(148, 163, 184, 0.16);
  border: 1px solid rgba(148, 163, 184, 0.22);
  color: rgba(226, 232, 240, 0.82);
  font-size: 0.75rem;
}

.calendar-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: center;
  color: rgba(148, 163, 184, 0.72);
  font-size: 0.85rem;
}

.calendar-legend .legend-item {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.4rem 0.65rem;
  border-radius: 0.85rem;
  background: rgba(148, 163, 184, 0.08);
  border: 1px solid rgba(148, 163, 184, 0.16);
}

.calendar-legend .legend-color {
  width: 12px;
  height: 12px;
  border-radius: 50%;
}

.calendar-legend .legend-color.today {
  background: rgba(99, 102, 241, 0.85);
}

.calendar-legend .legend-color.high {
  background: rgba(239, 68, 68, 0.85);
}

.calendar-indicator {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.8rem;
  color: rgba(148, 163, 184, 0.68);
}

/* Modals */
.calendar-modal,
.calendar-export-modal {
  position: fixed;
  inset: 0;
  background: rgba(8, 12, 19, 0.78);
  backdrop-filter: blur(18px);
  display: none;
  align-items: center;
  justify-content: center;
  padding: clamp(1rem, 6vw, 2rem);
  z-index: var(--z-modal);
}

.calendar-modal.active,
.calendar-export-modal.active {
  display: flex;
}

.calendar-modal__content {
  width: min(520px, 100%);
  background: rgba(13, 17, 25, 0.94);
  border: 1px solid rgba(148, 163, 184, 0.18);
  border-radius: var(--radius-2xl);
  padding: clamp(1.75rem, 4vw, 2.5rem);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  color: rgba(226, 232, 240, 0.85);
  box-shadow: 0 36px 72px rgba(8, 11, 19, 0.48);
}

.calendar-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-sm);
}

.calendar-modal__title {
  margin: 0;
  font-size: 1.35rem;
  font-weight: var(--font-semibold);
  color: #f8fafc;
}

.calendar-modal__close {
  width: 2.35rem;
  height: 2.35rem;
  border-radius: 0.85rem;
  border: 1px solid rgba(148, 163, 184, 0.18);
  background: rgba(148, 163, 184, 0.08);
  color: rgba(226, 232, 240, 0.78);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);
}

.calendar-modal__close:hover {
  background: rgba(148, 163, 184, 0.16);
  border-color: rgba(148, 163, 184, 0.28);
  color: #f8fafc;
}

.calendar-modal__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  color: rgba(226, 232, 240, 0.78);
}

.calendar-export-options {
  display: grid;
  gap: var(--space-sm);
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}

.calendar-export-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  padding: 0.75rem 1rem;
  border-radius: 0.9rem;
  border: 1px solid rgba(148, 163, 184, 0.2);
  background: rgba(148, 163, 184, 0.08);
  color: rgba(226, 232, 240, 0.85);
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  transition: background var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);
}

.calendar-export-btn:hover {
  transform: translateY(-2px);
  background: rgba(148, 163, 184, 0.16);
  border-color: rgba(148, 163, 184, 0.26);
}

.calendar-shortcut-hint {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  padding: 0.65rem 1.1rem;
  border-radius: 0.85rem;
  border: 1px solid rgba(148, 163, 184, 0.2);
  background: rgba(10, 12, 20, 0.9);
  color: rgba(148, 163, 184, 0.72);
  font-size: 0.8rem;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

/* Responsive */
@media (max-width: 1024px) {
  .economic-table th,
  .economic-table td {
    padding: 0.75rem 0.75rem;
  }

  .calendar-grid {
    grid-template-columns: repeat(7, minmax(140px, 1fr));
  }
}

@media (max-width: 768px) {
  .calendar-hero {
    display: none;
  }

  .calendar-controls__row {
    flex-direction: column;
    align-items: stretch;
  }

  .calendar-actions,
  .calendar-date-control {
    width: 100%;
  }

  .calendar-advanced__grid {
    grid-template-columns: 1fr;
  }

  .calendar-stats-row,
  .calendar-stat {
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  }

  .calendar-grid {
    grid-template-columns: repeat(7, minmax(120px, 1fr));
  }
}

@media (max-width: 520px) {
  .calendar-card,
  .calendar-month-card,
  .calendar-hero {
    padding: 1.5rem;
  }

  .calendar-grid {
    grid-template-columns: repeat(7, minmax(100px, 1fr));
  }
}
