@import "tailwindcss";
@import "flatpickr/dist/flatpickr.css";

@font-face {
  font-family: "GeistMono";
  src: url("/assets/GeistMono-Regular-45ecc011.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
}

@font-face {
  font-family: "GeistMono";
  src: url("/assets/GeistMono-Bold-07d3312f.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "GeistMono";
  src: url("/assets/GeistMono-SemiBold-c2bd817c.ttf") format("truetype");
  font-weight: 600;
  font-style: normal;
}

@theme {
  --font-mono: "GeistMono", monospace;
}

@layer base {
  html {
    @apply font-mono;
  }
}

@layer components {
  .btn {
    @apply inline-flex items-center gap-2 rounded-md bg-slate-800 px-3 py-2 text-sm font-medium text-slate-300 hover:bg-slate-700 hover:text-white transition-colors;
  }
}

/* Flatpickr custom theme */
.flatpickr-calendar {
  font-family: "GeistMono", monospace;
  background: #0f172a;
  border: 1px solid #334155;
  border-radius: 0.75rem;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
  padding: 0;
  width: 280px;
  overflow: hidden;
}

.flatpickr-calendar.open {
  display: inline-block;
  opacity: 1;
  visibility: visible;
  z-index: 99999;
}

.flatpickr-calendar::before,
.flatpickr-calendar::after {
  display: none;
}

.flatpickr-months {
  padding: 12px 12px 4px;
}

.flatpickr-months .flatpickr-month {
  height: 32px;
}

.flatpickr-months .flatpickr-prev-month,
.flatpickr-months .flatpickr-next-month {
  padding: 4px 8px;
  fill: #94a3b8;
  border-radius: 0.375rem;
  transition: all 0.15s;
}

.flatpickr-months .flatpickr-prev-month:hover,
.flatpickr-months .flatpickr-next-month:hover {
  fill: #ffffff;
  background: #1e293b;
}

.flatpickr-months .flatpickr-prev-month svg,
.flatpickr-months .flatpickr-next-month svg {
  width: 12px;
  height: 12px;
}

.flatpickr-current-month {
  font-size: 0.8125rem;
  font-weight: 600;
  color: #f1f5f9;
  padding-top: 4px;
}

.flatpickr-current-month .cur-month {
  font-weight: 600;
}

.flatpickr-current-month input.cur-year {
  font-family: "GeistMono", monospace;
  font-size: 0.8125rem;
  font-weight: 600;
  color: #f1f5f9;
  background: transparent;
  border: none;
  padding: 0;
}

.flatpickr-weekdays {
  padding: 0 12px;
}

span.flatpickr-weekday {
  font-family: "GeistMono", monospace;
  font-size: 0.6875rem;
  font-weight: 600;
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.flatpickr-days {
  padding: 4px 12px 12px;
  width: 100% !important;
}

.flatpickr-days .dayContainer {
  width: 100%;
  min-width: 100%;
  max-width: 100%;
}

.flatpickr-day {
  font-family: "GeistMono", monospace;
  font-size: 0.8125rem;
  color: #cbd5e1;
  border: none;
  border-radius: 0.375rem;
  max-width: 36px;
  height: 36px;
  line-height: 36px;
  margin: 1px;
  transition: all 0.15s;
}

.flatpickr-day:hover {
  background: #1e293b;
  color: #ffffff;
  border: none;
}

.flatpickr-day.today {
  color: #ffffff;
  background: transparent;
  border: 1px solid #475569 !important;
}

.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange {
  background: #ffffff !important;
  color: #0f172a !important;
  border: none !important;
  font-weight: 600;
}

.flatpickr-day.selected:hover,
.flatpickr-day.startRange:hover,
.flatpickr-day.endRange:hover {
  background: #e2e8f0 !important;
  color: #0f172a !important;
}

.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay {
  color: #334155;
}

.flatpickr-day.prevMonthDay:hover,
.flatpickr-day.nextMonthDay:hover {
  background: #1e293b;
  color: #64748b;
}

.flatpickr-day.flatpickr-disabled {
  color: #1e293b;
}

/* Time picker */
.flatpickr-time {
  border: none !important;
  padding: 12px;
  max-height: none !important;
}

.flatpickr-time input,
.flatpickr-time .flatpickr-am-pm {
  font-family: "GeistMono", monospace;
  font-size: 1rem;
  font-weight: 600;
  color: #f1f5f9;
  background: #1e293b;
  border: 1px solid #334155;
  border-radius: 0.5rem;
  height: 44px;
  transition: all 0.15s;
}

.flatpickr-time input:hover,
.flatpickr-time input:focus,
.flatpickr-time .flatpickr-am-pm:hover,
.flatpickr-time .flatpickr-am-pm:focus {
  background: #334155;
  border-color: #475569;
}

.flatpickr-time .flatpickr-time-separator {
  color: #64748b;
  font-weight: 600;
  line-height: 44px;
}

.flatpickr-time .flatpickr-am-pm {
  font-size: 0.75rem;
  letter-spacing: 0.05em;
  width: 60px;
  cursor: pointer;
}

.numInputWrapper:hover {
  background: transparent;
}

.numInputWrapper span {
  border: none;
  opacity: 0;
  transition: opacity 0.15s;
}

.numInputWrapper span:hover {
  background: #1e293b;
}

.numInputWrapper span::after {
  border-color: #94a3b8 transparent transparent;
}

.numInputWrapper span.arrowUp::after {
  border-bottom-color: #94a3b8;
}

.numInputWrapper:hover span {
  opacity: 1;
}

input.flatpickr-input[readonly] {
  cursor: pointer;
}