/* DraftDayPlanner calendar.css - calendar grid, cells, and availability states */

/* SECTION 03.1 - Calendar Container */
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;padding:10px;}
#calendar-grid.calendar-grid{display:block;padding:1px 10px 10px;}
.calendar-row{display:contents;}

/* SECTION 03.2 - Month Sections */
.month-section{margin-bottom:12px;}
.month-bar{grid-column:1 / -1;background:var(--month-bar);color:var(--month-text);padding:5px 10px;margin:6px var(--bar-inset) 2px;border-radius:6px;font-weight:800;min-height:0;height:var(--cal-bar);display:flex;align-items:center;}
.month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;padding:0 12px;}
.month-grid.days{margin-top:6px;grid-auto-rows:var(--cal-cell);}

/* SECTION 03.3 - Day Of Week Row */
.dow-header{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;padding:8px 10px 0;}
.dow-cell{text-align:center;font-weight:800;color:var(--green-dark);background:transparent;font-size:.85rem;padding:2px 0;}
.month-grid.dow{margin-top:4px;}
.month-grid.dow .dow-cell{height:var(--cal-dow);display:flex;align-items:center;justify-content:center;}

/* SECTION 03.4 - Calendar Cells */
.calendar-cell{background:var(--green-mid);border-radius:8px;color:#fff;text-align:center;display:flex;flex-direction:column;justify-content:center;font-weight:700;position:relative;min-height:0;height:var(--cal-cell);overflow:hidden;padding:8px;user-select:none;-webkit-user-select:none;}
.calendar-cell.placeholder{background:transparent;box-shadow:none;border:none;pointer-events:none;min-height:0;height:var(--cal-cell);visibility:hidden;}

/* SECTION 03.5 - Cell Labels */
.cell-date{position:absolute;top:6px;left:7px;font-weight:700;font-size:.9rem;}
.calendar-cell .cell-date{font-size:.95rem;}
.calendar-cell .cell-label{align-self:stretch;text-align:left;font-size:.8rem;margin-top:4px;line-height:1.18;white-space:normal;overflow:hidden;text-overflow:ellipsis;padding-left:4px;transform:translateY(2px);}
.calendar-cell .cell-label.compact,.cell-label.compact{display:none;}

/* SECTION 03.6 - Today And Disabled States */
.calendar-cell.today{border:2px solid #008800;box-shadow:0 0 0 3px rgba(0,136,0,.18),inset 0 0 0 1px rgba(255,255,255,.32);}
.calendar-cell.today .cell-date{background:#d8eef7;color:#111a22;border-radius:999px;padding:2px 6px;top:5px;left:5px;line-height:1;}
.calendar-cell.past-day{background:var(--green-dim);color:#d7e4ec;}
.calendar-cell.disabled{pointer-events:none;user-select:none;}

/* SECTION 03.7 - Availability Colors */
.calendar-cell.poor{background:#0d1f10;color:#d7e4dc;filter:brightness(.72);}
.calendar-cell.limited{background:#133619;color:#fff;filter:brightness(.82);}
.calendar-cell.good{background:#266134;color:#fff;filter:brightness(.92);}
.calendar-cell.strong{background:#2fb54e;color:#fff;filter:none;}

/* SECTION 03.8 - NFL Start Day */
.calendar-cell.nfl-start{background-color:#2d7f43;opacity:1;color:#fff;}
.calendar-cell.nfl-start .cell-date{color:#fff;}
.calendar-cell.nfl-start .cell-label{display:none;}
.calendar-cell.nfl-start .cell-label.nfl-message{display:block;font-size:1.1rem;font-weight:600;text-align:center;margin-top:4px;color:#fff;transform:none;}

/* SECTION 03.9 - Compact Mobile Calendar */
@media (max-height:700px){.month-grid{gap:2px;}}
@media (max-width:640px){
.calendar-cell .cell-label:not(.compact):not(.nfl-message){display:none;}
.calendar-cell .cell-label.compact{display:flex;}
.calendar-cell{position:relative;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:24px 8px 10px;border-radius:12px;container-type:inline-size;height:auto;min-height:var(--cal-cell);overflow:visible;}
.month-grid.days{grid-auto-rows:auto;}
.calendar-cell .cell-date{position:absolute;top:6px;left:7px;font-weight:800;font-size:.95rem;}
.cell-label.compact{flex-direction:column;align-items:flex-start;align-self:stretch;text-align:left;font-weight:700;line-height:1.15;gap:2px;white-space:normal;overflow:visible;text-overflow:clip;padding-left:3px;}
.cell-label.compact .cell-range{font-size:clamp(var(--range-min),2.8cqw,var(--range-max));line-height:1.18;max-width:96%;white-space:normal;text-wrap:balance;overflow-wrap:anywhere;display:block;text-align:left;}
.calendar-cell .cell-label.nfl-message{display:block;white-space:normal;overflow:visible;text-overflow:clip;line-height:1.15;padding:0 6px;font-size:.9rem;text-wrap:balance;}
}
.day-update-badge{position:absolute;left:50%;bottom:15px;transform:translate(-50%,4px);z-index:2;background:var(--green-dark);color:#fff;border-radius:999px;padding:4px 10px;font-size:.76rem;font-weight:800;line-height:1;opacity:0;box-shadow:0 6px 14px rgba(0,0,0,.22);pointer-events:none;transition:opacity .16s ease,transform .16s ease;}
.day-update-badge.is-visible{opacity:1;transform:translate(-50%,0);}
@media (max-width:420px){.dow-cell{font-size:.8rem;}}
@media (max-width:360px){.calendar-cell .cell-label{display:none;}}
@supports not (container-type:inline-size){
@media (max-width:640px){
.cell-label.compact .cell-range{font-size:clamp(var(--range-min),3.2vw,var(--range-max));}
}
}
