/* ==========================================
   ELITE TERMINAL v192 | CALENDAR STYLES
   File: ui/static/calendar.css
   ========================================== */

/* --- 1. ШАПКА КАЛЕНДАРЯ --- */
.month-navigation,
.cal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--hdr-gap-tight);
  margin-bottom: 12px;
  background: var(--bg-panel);
  border: var(--hdr-border-w) solid var(--border);
  border-radius: var(--hdr-radius);
  padding: var(--hdr-pad-page);
}

.month-nav-btn,
.cal-nav-btn {
  width: var(--hdr-control-icon-lg);
  height: var(--hdr-control-icon-lg);
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--bg-input);
  color: var(--text-main);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform .08s ease, border-color .15s ease;
  font-weight: 700;
}

.month-nav-btn:hover {
  border-color: rgba(252, 213, 53, 0.45);
  color: var(--accent);
  transform: translateY(-1px);
}

.current-month,
#current-month {
  font-weight: 700;
  letter-spacing: .5px;
  color: var(--text-main);
  font-size: 15px;
  user-select: none;
  text-transform: uppercase;
  flex: 1;
  text-align: center;
  font-family: var(--font-ui);
}

/* --- 2. ДНИ НЕДЕЛИ --- */
.weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 8px;
  margin-bottom: 8px;
}

.weekdays > div {
  text-align: center;
  color: var(--text-sub);
  font-size: 11px;
  font-weight: 700;
  opacity: .9;
  text-transform: uppercase;
}

/* --- 3. СЕТКА --- */
#cal-grid,
.cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 8px;
  padding-bottom: 20px;
}

/* БАЗОВЫЙ СТИЛЬ ЯЧЕЙКИ */
.cal-day {
  position: relative;
  height: 80px;
  border-radius: 14px;
  background: var(--bg-input);
  border: 1px solid var(--border) !important;
  cursor: pointer;
  overflow: hidden;

  -webkit-font-smoothing: subpixel-antialiased;
  -moz-osx-font-smoothing: grayscale;
  backface-visibility: hidden;
  transform: translateZ(0);
  will-change: transform, box-shadow;

  transition: transform .15s ease-out, border-color .15s ease, box-shadow .2s ease, background-color .15s ease;

  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 8px;
  z-index: 1;
}

/* ПРИ НАВЕДЕНИИ */
.cal-day:hover {
  transform: translateY(-5px);
  border-color: var(--accent) !important;
  background-color: var(--bg-panel) !important;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.5);
  z-index: 100 !important;
}

/* ПУСТАЯ ЯЧЕЙКА */
.cal-day.empty {
  background: transparent;
  border: 1px dashed var(--border) !important;
  cursor: default;
  opacity: 0.4;
  z-index: 0;
}
.cal-day.empty:hover {
  transform: none;
  border-color: var(--border) !important;
  background: transparent;
  box-shadow: none;
  z-index: 0;
}

.cal-date-num {
  font-weight: 700;
  font-size: 13px;
  color: var(--text-sub);
  pointer-events: none;
}

.cal-pnl-val {
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 11px;
  align-self: flex-end;
  pointer-events: none;
}

/* --- СЧЕТЧИК СДЕЛОК --- */
.cal-count-badge {
  position: absolute;
  top: 8px;
  right: 8px;
  font-size: 10px;
  font-weight: 600;
  color: var(--text-sub);
  background: rgba(128, 128, 128, 0.15);
  padding: 2px 6px;
  border-radius: 6px;
  border: 1px solid rgba(128, 128, 128, 0.2);
  pointer-events: none;
}

.cal-day.loss-day .cal-count-badge {
  background: rgba(0, 0, 0, 0.2);
  color: #fff;
  border-color: rgba(255,255,255,0.3);
}

/* --- 4. ЭФФЕКТЫ --- */

/* ПРОФИТ */
.cal-day.profit-glow {
  border-color: rgba(35, 134, 54, 0.6) !important;
  background: rgba(35, 134, 54, 0.1);
}
.cal-day.profit-glow:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 30px rgba(35, 134, 54, 0.3);
  border-color: #2ea44f !important;
  background: linear-gradient(0deg, rgba(35, 134, 54, 0.15), rgba(35, 134, 54, 0.15)), var(--bg-panel) !important;
  z-index: 100 !important;
}

/* УБЫТОК */
.cal-day.loss-day {
  border-color: #ff3333 !important;
  background: rgba(255, 50, 50, 0.1) !important;
}
.cal-day.loss-day:hover {
  transform: translateY(-5px);
  border-color: #ff0000 !important;
  background: linear-gradient(0deg, rgba(255, 50, 50, 0.15), rgba(255, 50, 50, 0.15)), var(--bg-panel) !important;
  box-shadow: 0 10px 30px rgba(255, 0, 0, 0.3) !important;
  z-index: 100 !important;
}

/* СЕГОДНЯ */
.cal-day.is-today {
  border: 2px solid var(--accent) !important;
  box-shadow: 0 0 15px rgba(252,213,53,.2);
  z-index: 5;
}
.cal-day.is-today:hover {
  z-index: 100 !important;
  background-color: var(--bg-panel) !important;
}
.cal-day.is-today .cal-date-num { color: var(--accent); }

@media (max-width: 1400px) {
  .cal-day { height: 70px; }
}

/* --- CALENDAR CLICK FIX --- */
#cal-grid { position: relative; z-index: 5; pointer-events: auto; }
#cal-grid .cal-day { pointer-events: auto; }
#cal-grid .cal-day.has-trades { pointer-events: auto; }

/* =========================================================
   ✅ DAY MODAL (calendar day trades) — UI polish + layering
   ========================================================= */

/* wrapper always covers screen */
#modal-day {
  position: fixed !important;
  inset: 0 !important;
  z-index: 90000 !important; /* ниже основных модалок (edit/note/img/range) */
}

/* overlay */
#modal-day .modal-overlay {
  position: fixed !important;
  inset: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: var(--overlay-bg) !important;
  -webkit-backdrop-filter: blur(var(--overlay-blur));
  backdrop-filter: blur(var(--overlay-blur));
  z-index: 90000 !important;
  pointer-events: auto !important;
}

/* modal box */
#modal-day .modal-box {
  background: var(--bg-panel) !important;
  border: 1px solid var(--border) !important;
  border-radius: 18px !important;
  padding: 18px 18px 16px !important;

  width: min(560px, 92vw) !important;
  max-width: 92vw !important;

  box-shadow: 0 22px 70px rgba(0,0,0,0.55) !important;
  pointer-events: auto !important;

  display: flex;
  flex-direction: column;
}

/* ✅ Делаем отдельную скролл-зону внутри, чтобы нижняя кнопка не "съезжала" */
#modal-day .modal-box {
  max-height: 85vh;
  overflow: hidden;            /* скролл будет в .day-trades-list */
}

/* список сделок — скроллится, а футер всегда виден */
#modal-day .day-trades-list{
  margin-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  overflow-y: auto;
  flex: 1 1 auto;
  min-height: 0;               /* ✅ must-have для flex+overflow */
  padding: 4px 2px 2px 0;      /* top padding keeps hover glow/border from being clipped */
  scroll-padding-top: 4px;
}

/* футер: кнопка всегда кликабельна и не уменьшается */
#modal-day .day-modal-footer{
  flex: 0 0 auto;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
  background: var(--bg-panel);
}

/* ✅ красивые карточки сделок */
#modal-day .trade-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;

  padding: 12px 14px;
  border-radius: 14px;

  background: var(--bg-input);
  border: 1px solid var(--border);
  cursor: pointer;

  transition: transform .12s ease, border-color .15s ease, box-shadow .18s ease, background .15s ease;
}

/* layout inside "day modal" list: 3 columns (symbol | side | PnL) */
#modal-day .trade-card{
  display: grid;
  grid-template-columns: minmax(0, 1fr) 88px 110px;
  align-items: center;
  gap: 12px;
}

/* symbol column */
#modal-day .trade-card .trade-sym{
  font-family: var(--font-num);
  font-size: 13px;
  letter-spacing: 0.2px;
  color: var(--text-main);

  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* side column (neutral) */
#modal-day .trade-card .trade-side-tag{
  justify-self: center;
  text-align: center;

  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.2px;
  color: var(--text-sub);
  padding: 2px 8px;
  border: 1px solid var(--border);
  border-radius: 999px;
  line-height: 16px;
  opacity: 0.95;

  /* when empty -> invisible but keeps column alignment */
}
#modal-day .trade-card .trade-side-tag:empty{
  border-color: transparent;
  padding: 0;
  height: 0;
}

/* PnL column */
#modal-day .trade-card .trade-pnl{
  justify-self: end;
  font-family: var(--font-num);
  font-weight: 800;
  font-size: 13px;
  white-space: nowrap;
}

/* hover/active */
#modal-day .trade-card:hover {
  border-color: rgba(252, 213, 53, 0.35) !important;
  box-shadow: 0 14px 36px rgba(0,0,0,0.35);
  transform: translateY(-1px);
  background: linear-gradient(0deg, rgba(252,213,53,0.06), rgba(252,213,53,0.06)), var(--bg-input);
}
#modal-day .trade-card:active {
  transform: scale(0.99);
}

/* ✅ в светлой теме карточки должны быть контрастнее */
[data-theme="light"] #modal-day .trade-card {
  background: #ffffff;
  border: 1px solid rgba(0,0,0,0.10);
  box-shadow: 0 6px 16px rgba(0,0,0,0.06);
}
[data-theme="light"] #modal-day .trade-card:hover {
  box-shadow: 0 10px 24px rgba(0,0,0,0.10);
  border-color: rgba(252, 213, 53, 0.55) !important;
}

/* кнопка закрытия — аккуратнее */
#modal-day .btn-close-day,
#modal-day [data-close-day],
#modal-day .btn.btn-accent {
  width: 100%;                 /* ✅ удобнее, когда сделок много */
  border-radius: 14px;
  height: 44px;
  flex: 0 0 auto;
  pointer-events: auto !important;
  touch-action: manipulation;
}

/* ==========================================
   TABLET CALENDAR POLISH
   ========================================== */
@media (min-width: 768px) and (max-width: 1366px) and (hover: none) and (pointer: coarse){
  .month-navigation,
  .cal-header{
    padding: 12px;
    margin-bottom: 10px;
    border-radius: 14px;
  }

  .weekdays{
    gap: 6px;
    margin-bottom: 6px;
  }

  #cal-grid,
  .cal-grid{
    gap: 6px;
    padding-bottom: 6px;
  }

  .cal-day{
    height: 72px;
    border-radius: 12px;
    padding: 7px;
  }

  .cal-date-num{
    font-size: 12px;
  }

  .cal-count-badge{
    top: 6px;
    right: 6px;
    padding: 2px 5px;
  }

  .cal-pnl-val{
    font-size: 10px;
    line-height: 1.2;
  }
}

@media (min-width: 768px) and (max-width: 1024px) and (hover: none) and (pointer: coarse){
  .cal-day{
    height: 68px;
  }
}


/* Tablet/touch calendar: disable hover-lift effect, days open directly on tap */
@media (min-width: 768px) and (max-width: 1366px) and (hover: none) and (pointer: coarse){
  .cal-day,
  .cal-day.profit-glow,
  .cal-day.loss-day,
  .cal-day.is-today,
  .month-nav-btn{
    transition: border-color .15s ease, background-color .15s ease, box-shadow .18s ease;
  }

  .cal-day:hover,
  .cal-day.profit-glow:hover,
  .cal-day.loss-day:hover,
  .cal-day.is-today:hover,
  .month-nav-btn:hover{
    transform: none !important;
    box-shadow: none !important;
  }

  .cal-day:hover{
    border-color: var(--border) !important;
    background-color: var(--bg-input) !important;
    z-index: 1 !important;
  }

  .cal-day.profit-glow:hover,
  .cal-day.loss-day:hover,
  .cal-day.is-today:hover{
    z-index: 1 !important;
  }

  .cal-day.empty:hover{
    transform: none !important;
    box-shadow: none !important;
    z-index: 0 !important;
  }
}


/* ==========================================
   MOBILE PORTRAIT | analytics calendar compact mode
   - tighter spacing
   - no unit in day cells (handled in JS)
   ========================================== */
@media (max-width: 767px) and (orientation: portrait) and (hover:none) and (pointer:coarse){
  #view-analytics .cal-day,
  #view-analytics .cal-day.profit-glow,
  #view-analytics .cal-day.loss-day,
  #view-analytics .cal-day.is-today,
  #view-analytics .month-nav-btn,
  #view-analytics .cal-nav-btn{
    transition: border-color .15s ease, background-color .15s ease, box-shadow .18s ease !important;
  }

  #view-analytics .cal-day:hover,
  #view-analytics .cal-day.profit-glow:hover,
  #view-analytics .cal-day.loss-day:hover,
  #view-analytics .cal-day.is-today:hover,
  #view-analytics .month-nav-btn:hover,
  #view-analytics .cal-nav-btn:hover{
    transform: none !important;
    box-shadow: none !important;
  }

  #view-analytics .cal-day:hover{
    border-color: var(--border) !important;
    background-color: var(--bg-input) !important;
    z-index: 1 !important;
  }

  #view-analytics .cal-day.profit-glow:hover{
    border-color: rgba(35, 134, 54, 0.6) !important;
    background: rgba(35, 134, 54, 0.1) !important;
    z-index: 1 !important;
  }

  #view-analytics .cal-day.loss-day:hover{
    border-color: #ff3333 !important;
    background: rgba(255, 50, 50, 0.1) !important;
    z-index: 1 !important;
  }

  #view-analytics .cal-day.is-today:hover{
    border-color: var(--accent) !important;
    background-color: var(--bg-input) !important;
    z-index: 5 !important;
  }

  #view-analytics .cal-day.empty:hover{
    transform: none !important;
    box-shadow: none !important;
    border-color: var(--border) !important;
    background: transparent !important;
    z-index: 0 !important;
  }

  #view-analytics .analytics-calendar-card{
    padding: 10px !important;
  }

  #view-analytics .month-navigation,
  #view-analytics .cal-header{
    margin-bottom: 8px;
    padding: 10px;
    border-radius: 16px;
    gap: 10px;
  }

  #view-analytics .month-nav-btn,
  #view-analytics .cal-nav-btn{
    width: 48px;
    height: 48px;
    border-radius: 12px;
    flex: 0 0 48px;
  }

  #view-analytics .current-month,
  #view-analytics #current-month{
    font-size: 13px;
    letter-spacing: .04em;
  }

  #view-analytics .weekdays{
    gap: 4px;
    margin-bottom: 4px;
  }

  #view-analytics .weekdays > div{
    font-size: 10px;
  }

  #view-analytics #cal-grid,
  #view-analytics .cal-grid{
    gap: 4px;
    padding-bottom: 0;
  }

  #view-analytics .cal-day{
    height: 60px;
    min-height: 60px;
    border-radius: 10px;
    padding: 5px 6px;
  }

  #view-analytics .cal-date-num{
    font-size: 11px;
    line-height: 1;
  }

  #view-analytics .cal-count-badge{
    top: 4px;
    right: 4px;
    font-size: 9px;
    line-height: 1;
    padding: 2px 5px;
    border-radius: 999px;
  }

  #view-analytics .cal-pnl-val{
    font-size: 8.5px;
    line-height: 1.08;
    align-self: flex-start;
    max-width: 100%;
    letter-spacing: 0;
  }
}
