/* /public_html/assets/css/planning/planning-public.base.css
   Planning hebdomadaire — socle commun
*/

body.is-dashboard-shell-visible:has(#planning-public-content) .planning-public-header {
  display: none !important;
}

body.is-dashboard-shell-visible:has(#planning-public-content) .planning-public-header + .panel-body .planning-public-wrapper,
body.is-dashboard-shell-visible:has(#planning-public-content) .planning-public-wrapper {
  margin-top: 0 !important;
}

.planning-public-loader-host {
  width: 100%;
  min-height: min(42vh, 24rem);
  display: grid;
  place-items: start center;
  padding-top: clamp(1.4rem, 5vh, 3.5rem);
}

.planning-public-loader-host[hidden],
.planning-public-content[hidden] {
  display: none !important;
}

.planning-public-wrapper {
  width: 100%;
  max-width: min(100%, 122rem);
  margin-inline: auto;
  padding: 0 clamp(.75rem, 2vw, 1.35rem) clamp(1.6rem, 4vh, 2.5rem);
  box-sizing: border-box;
}

.planning-public-content,
.planning-public-mobile-week,
.planning-public-grid,
.planning-public-day,
.planning-public-day-list,
.planning-public-row,
.planning-public-course {
  box-sizing: border-box;
  min-width: 0;
}

.planning-public-content {
  width: 100%;
}

.planning-public-mobile-filters-host,
.planning-public-mobile-daybar,
.planning-public-landscape-daybar,
.planning-public-day-inline-title {
  display: none;
}

.planning-public-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr));
  align-items: start;
  gap: clamp(.65rem, 1.2vw, 1rem);
  width: 100%;
}

.planning-public-day {
  background: transparent;
  border: 0;
  border-radius: 1.15rem;
  box-shadow: none;
  overflow: visible;
}

.planning-public-day-header {
  position: sticky;
  top: var(--planning-public-sticky-top, calc(var(--app-header-height, 4rem) + 1rem));
  z-index: 6;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .32rem;
  padding: .64rem .6rem .72rem;
  border-radius: 0 0 .9rem .9rem;
  text-align: center;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

html:not([data-theme="dark"]) .planning-public-day-header {
  background: linear-gradient(
    180deg,
    rgba(255,255,255,.92) 0%,
    rgba(255,255,255,.78) 55%,
    rgba(255,255,255,.68) 100%
  );
  border: 1px solid rgba(15,23,42,.12);
  border-top: 0;
  box-shadow: 0 .65rem 1.65rem rgba(15,23,42,.12);
}

html[data-theme="dark"] .planning-public-day-header {
  background: linear-gradient(
    180deg,
    rgba(2,6,23,.72) 0%,
    rgba(2,6,23,.58) 55%,
    rgba(2,6,23,.50) 100%
  );
  border: 1px solid rgba(148,163,184,.22);
  border-top: 0;
  box-shadow: 0 .75rem 1.9rem rgba(0,0,0,.45);
}

.planning-public-day-header h3 {
  width: 100%;
  margin: 0;
  color: var(--color-text);
  font-size: clamp(1.02rem, 1.8vw, 1.22rem);
  font-weight: 900;
  line-height: 1.04;
  letter-spacing: -.025em;
}

.planning-public-day-count {
  margin: 0;
  color: color-mix(in srgb, var(--color-text-muted, #64748b) 82%, transparent 18%);
  font-size: clamp(.78rem, 1.15vw, .92rem);
  font-weight: 760;
  line-height: 1;
}

.planning-public-day-list {
  padding-top: .85rem;
}

.planning-public-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: .52rem;
  margin: 0 0 .52rem;
}

.planning-public-row:last-child {
  margin-bottom: 0;
}

.planning-public-row.is-two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.planning-public-course {
  --planning-course-bg: color-mix(in srgb, var(--course-color, #38bdf8) 18%, transparent);
  --planning-course-border: color-mix(in srgb, var(--course-color, #38bdf8) 35%, rgba(148,163,184,.35));
  width: 100%;
  min-height: 6.4rem;
  padding: .92rem .75rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .42rem;
  text-align: center;
  background: var(--planning-course-bg);
  border: 1px solid var(--planning-course-border);
  border-radius: 1.12rem;
  box-shadow: 0 .9rem 2.1rem rgba(0,0,0,.10);
}

html[data-theme="dark"] .planning-public-course {
  --planning-course-bg: color-mix(in srgb, var(--course-color, #38bdf8) 16%, rgba(2,6,23,.20));
  --planning-course-border: color-mix(in srgb, var(--course-color, #38bdf8) 28%, rgba(148,163,184,.25));
  box-shadow: 0 1.1rem 2.8rem rgba(0,0,0,.35);
}

.planning-public-course-time {
  color: var(--color-text);
  font-size: clamp(.92rem, 1.45vw, 1.08rem);
  font-weight: 900;
  letter-spacing: .01em;
  line-height: 1.08;
}

.planning-public-course-style {
  display: flex;
  justify-content: center;
  max-width: 100%;
}

.planning-public-course .style-badge {
  max-width: 100%;
  padding-inline: .64rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.planning-public-course-level {
  color: var(--color-text);
  font-weight: 900;
  font-style: italic;
  line-height: 1.08;
  opacity: .96;
}

.planning-public-course-teacher {
  color: var(--color-text);
  font-weight: 800;
  line-height: 1.08;
  opacity: .88;
}

body.is-dashboard-shell-visible:has(#planning-public-content) .mobile-shell-navbar__left .filter-bubbles-trigger {
  flex: 0 0 auto;
}
