/* Consumer-first live session: one task, one pane, secondary detail on demand. */
body.session-active .site-header,
body.session-active .auth-shell,
body.session-active #eccentrx-auth-slot,
body.session-active .assistant-toggle,
body.session-active .assistant-panel,
body.session-active .back-to-top,
body.session-active .momentum-hud,
body.session-active #aziap-zeigarnik-hud,
body.session-active .pr-celebrate {
  display: none !important;
}

body.session-active .toast.toast-success,
body.session-active #fatigue-overlay-el {
  display: none !important;
}

.session-mode.open {
  display: flex !important;
  flex-direction: column;
  width: 100%;
  height: 100dvh;
  max-height: 100dvh;
  overflow: hidden;
  opacity: 1 !important;
  filter: none !important;
  animation: none !important;
  /* ambient focal depth: a subtle brand-blue glow at top-center (where the
     active target + log sit) fading to the deep cockpit base — GPU-cheap static
     gradient, no blur/filter, no motion (reduced-motion-safe by construction). */
  background:
    radial-gradient(125% 85% at 50% 0%, rgba(37, 99, 235, 0.1) 0%, rgba(7, 11, 16, 0) 58%),
    #070b10 !important;
  backdrop-filter: none !important;
}

.session-progress-wrapper {
  flex: 0 0 3px;
  height: 3px;
  min-height: 3px;
  gap: 0 !important;
  overflow: hidden;
  background: rgba(37, 99, 235, 0.14) !important; /* brand-blue track: the unfilled portion reads on the #070b10 cockpit */
}

.session-progress {
  height: 3px !important;
  border: 0 !important;
  border-radius: 0 !important;
  position: relative !important;
  overflow: hidden !important;
  /* kinetic brand-blue fill — de-neon compliant (#2563eb→#60a5fa, no retired cyan/lime), GPU-cheap gradient */
  background: linear-gradient(90deg, #2563eb 0%, #60a5fa 100%) !important;
}

/* Premium compositor-only sheen sweeping the filled bar — the cockpit's live
   signature. Motion-gated: reduced-motion users get the static gradient
   (the ::after never renders), so this can never trigger vestibular distress. */
@media (prefers-reduced-motion: no-preference) {
  .session-progress::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.5) 50%, rgba(255, 255, 255, 0) 100%);
    transform: translateX(-100%);
    will-change: transform;
    animation: session-progress-sheen 2.4s linear infinite;
  }
}

@keyframes session-progress-sheen {
  from {
    transform: translateX(-100%);
  }
  to {
    transform: translateX(100%);
  }
}

/* .session-phone-brief restored */
.session-progress-text,
.fatigue-heatmap,
.metabolic-indicator,
.session-export {
  display: none !important;
}

.session-head {
  flex: 0 0 auto;
  min-height: 66px !important;
  padding: 10px clamp(12px, 2vw, 24px) !important;
  border-bottom: 1px solid rgba(216, 227, 248, 0.12) !important;
  background: rgba(7, 11, 16, 0.98) !important;
}

.session-head-left,
.session-head-right {
  flex: 1 1 0;
  min-width: 0;
}

.session-head-right {
  justify-content: flex-end;
}

.session-head-clock {
  flex: 0 0 auto;
}

.session-clock-label {
  font-size: 0.58rem !important;
  letter-spacing: 0.14em !important;
}

.session-clock-num {
  font-size: clamp(1rem, 2vw, 1.35rem) !important;
}

.session-state-tag {
  min-height: 26px !important;
  padding: 4px 8px !important;
  font-size: 0.62rem !important;
}

.session-save-state:not(.warning):not(.unsaved) {
  display: none !important;
}

.session-close,
.session-finish {
  min-height: 44px !important;
}

.session-finish {
  border: 1px solid #2563eb !important; /* de-neon: brand blue, retired cyan */
  background: transparent !important;
  color: var(--text) !important;
  box-shadow: none !important;
}

.session-phone-nav {
  position: fixed !important;
  z-index: calc(var(--z-modal) + 2) !important;
  inset: auto 0 0;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
  padding: 8px max(10px, env(safe-area-inset-right))
    calc(8px + env(safe-area-inset-bottom))
    max(10px, env(safe-area-inset-left)) !important;
  border-top: 1px solid rgba(216, 227, 248, 0.14);
  background: rgba(7, 11, 16, 0.98) !important;
  backdrop-filter: blur(14px);
}

.session-phone-nav-btn {
  min-height: 44px;
  border: 1px solid transparent !important;
  border-radius: 9px !important;
  background: transparent !important;
  color: var(--text-muted) !important;
  box-shadow: none !important;
  font-size: 0.78rem !important;
  font-weight: 760 !important;
}

.session-phone-nav-btn.active,
.session-phone-nav-btn[aria-pressed="true"] {
  border-color: rgba(37, 99, 235, 0.5) !important; /* de-neon: brand blue */
  background: rgba(37, 99, 235, 0.14) !important;
  color: var(--text) !important;
}

.session-body[data-session-panel] {
  display: block !important;
  flex: 1 1 auto;
  min-height: 0;
  width: 100%;
  max-width: 100vw;
  box-sizing: border-box;
  padding: clamp(12px, 2vw, 24px) 12px
    calc(76px + env(safe-area-inset-bottom)) !important;
  overflow: hidden auto !important;
}

.session-body[data-session-panel] > .session-pane {
  display: none !important;
  min-width: 0 !important;
  box-sizing: border-box;
}

.session-body[data-session-panel="sessionInputPane"] > #sessionInputPane,
.session-body[data-session-panel="sessionPlanRail"] > #sessionPlanRail,
.session-body[data-session-panel="sessionStatsPane"] > #sessionStatsPane,
.session-body[data-session-panel="sessionFeedPane"] > #sessionFeedPane {
  display: block !important;
  width: min(900px, 100%);
  min-height: 0 !important;
  margin: 0 auto;
  animation: session-focus-panel-in 0.16s ease-out;
}

@keyframes session-focus-panel-in {
  from {
    opacity: 0;
    transform: translateY(4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.session-body[data-session-panel] .session-pane {
  padding: clamp(14px, 2vw, 24px) !important;
  border: 1px solid rgba(216, 227, 248, 0.14) !important;
  border-radius: 16px !important;
  background: rgba(10, 15, 21, 0.94) !important;
  box-shadow: none !important;
}

.session-body[data-session-panel="sessionInputPane"] > #sessionInputPane {
  display: flex !important;
  flex-direction: column;
}

.session-input > .session-pane-label {
  display: none !important;
}

.session-active-target {
  order: 1;
}

.session-quick-form {
  order: 2;
}

.session-adapt-details {
  order: 3;
}

.session-body[data-session-panel] .session-active-target {
  position: static !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr);
  gap: 3px;
  margin: 0 0 18px !important;
  padding: 0 0 18px !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(216, 227, 248, 0.15) !important;
  border-radius: 0 !important;
  background: transparent !important;
}

.session-active-target span {
  color: #9ecbff !important; /* de-neon: brand light-blue (11.5:1 on cockpit, AA) */
  font-size: 0.66rem !important;
  letter-spacing: 0.14em !important;
}

.session-active-target strong {
  color: var(--text) !important;
  font-size: clamp(2rem, 5vw, 3.6rem) !important;
  line-height: 0.98 !important;
}

.session-active-target small {
  color: var(--text-muted) !important;
  font-size: 0.82rem !important;
}

.session-quick-form {
  display: flex !important;
  flex-direction: column;
  gap: 12px !important;
  min-width: 0;
  max-width: 100%;
  overflow: clip;
}

.session-quick-form > .session-form-row:first-child {
  order: 1;
}

.session-last-set-hint {
  order: 2;
}

.session-form-3 {
  order: 3;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 10px !important;
}

.session-plate-hint {
  order: 4;
}

.session-actions {
  order: 5;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 8px !important;
  margin: 4px 0 0 !important;
  min-width: 0;
  max-width: 100%;
  overflow: clip;
}

.session-actions button {
  min-width: 0 !important;
}

.session-body[data-session-panel] .session-log {
  grid-column: 1 / -1;
  min-height: 62px !important;
  border-color: #2563eb !important;
  background: #2563eb !important;
  color: #ffffff !important;
  box-shadow: none !important;
  font-size: 1.08rem !important;
  letter-spacing: 0.06em;
}

body.session-active #sessLog:not(:disabled) {
  border-color: #2563eb !important;
  background: #2563eb !important;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
}

.session-rest,
.session-repeat {
  height: auto !important;
  min-height: 46px !important;
  border: 1px solid rgba(216, 227, 248, 0.22) !important;
  background: transparent !important;
  color: var(--text) !important;
  box-shadow: none !important;
  font-size: 0.82rem !important;
  white-space: nowrap;
}

.session-actions:has(.session-repeat:not([hidden])) {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.session-actions .session-repeat:not([hidden]) {
  grid-column: auto !important;
}

.session-more-details {
  order: 6;
}

.session-adapt-details {
  margin-top: 14px;
}

.session-more-details,
.session-adapt-details {
  border: 1px solid rgba(216, 227, 248, 0.14);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.018);
}

.session-more-details:not([open]) > :not(summary),
.session-adapt-details:not([open]) > :not(summary) {
  display: none !important;
}

.session-more-details summary,
.session-adapt-details summary {
  min-height: 46px;
  padding: 13px 14px;
  color: #9ecbff; /* de-neon: brand light-blue */
  font-size: 0.82rem;
  font-weight: 800;
  cursor: pointer;
}

.session-more-details[open],
.session-adapt-details[open] {
  padding-bottom: 12px;
}

.session-more-details[open] > :not(summary),
.session-adapt-details[open] > :not(summary) {
  margin-right: 12px !important;
  margin-left: 12px !important;
}

.session-adapt-details .session-floor-fix {
  margin-top: 0 !important;
}

.session-body[data-session-panel] .session-form-row input,
.session-body[data-session-panel] .session-form-row select,
.session-body[data-session-panel] .session-swap-search input {
  width: 100% !important;
  min-height: 54px !important;
  border: 1px solid rgba(216, 227, 248, 0.24) !important;
  border-radius: 10px !important;
  background: #f4f7fb !important;
  color: #101114 !important;
  font-size: 1.08rem !important;
  font-weight: 760 !important;
}

.session-body[data-session-panel] .session-form-row input:focus,
.session-body[data-session-panel] .session-form-row select:focus {
  border-color: #2563eb !important; /* de-neon: brand blue */
  outline: 2px solid rgba(37, 99, 235, 0.4) !important;
  outline-offset: 1px;
}

.session-plan,
.session-stats,
.session-feed {
  max-width: 900px;
}

.session-feed-empty,
.session-plan-empty {
  min-height: 120px !important;
}

body.session-active .rest-timer {
  z-index: calc(var(--z-modal) + 4) !important;
  inset: 82px 16px auto auto !important;
  display: none;
  width: min(300px, calc(100vw - 32px)) !important;
  padding: 12px !important;
  border: 1px solid rgba(37, 99, 235, 0.5) !important; /* de-neon: brand blue */
  border-radius: 14px !important;
  background: #0a1017 !important;
  box-shadow: 0 18px 52px rgba(0, 0, 0, 0.42) !important;
  backdrop-filter: none !important;
}

body.session-active .rest-timer.open {
  display: block !important;
}

body.session-active .rest-timer-inner {
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

body.session-active .rest-timer-label {
  margin-bottom: 0 !important;
  color: #7ce8ff !important;
  -webkit-text-fill-color: #7ce8ff !important;
}

body.session-active .rest-timer-num {
  margin: 0 0 3px !important;
  color: #f4f7fb !important;
  -webkit-text-fill-color: #f4f7fb !important;
  font-size: 2.35rem !important;
}

body.session-active .rest-timer-cue {
  min-height: 0 !important;
  margin: 0 0 9px !important;
  color: #b5c1d3 !important;
  -webkit-text-fill-color: #b5c1d3 !important;
  font-size: 0.72rem !important;
}

body.session-active .metabolic-pathway-ui {
  display: none !important;
}

body.session-active .rest-timer-presets,
body.session-active .rest-timer-controls {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 5px !important;
  margin: 0 0 6px !important;
}

body.session-active .rest-timer-controls {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-bottom: 0 !important;
}

body.session-active .rest-preset,
body.session-active .rest-ctrl {
  min-height: 40px !important;
  padding: 6px !important;
  border: 1px solid rgba(216, 227, 248, 0.2) !important;
  border-radius: 8px !important;
  background: rgba(255, 255, 255, 0.04) !important;
  color: #f4f7fb !important;
  -webkit-text-fill-color: #f4f7fb !important;
}

@media (max-width: 700px) {
  .session-head {
    min-height: 58px !important;
    padding: 7px 9px !important;
  }

  .session-head-left,
  .session-head-right {
    gap: 5px !important;
  }

  .session-state-tag {
    display: none !important;
  }

  .session-finish {
    min-height: 40px !important;
    padding: 7px 9px !important;
    font-size: 0.72rem !important;
  }

  .session-clock-label {
    display: none !important;
  }

  .session-body[data-session-panel] {
    padding: 10px 8px calc(72px + env(safe-area-inset-bottom)) !important;
  }

  .session-body[data-session-panel] .session-pane {
    padding: 13px !important;
    border-radius: 12px !important;
  }

  .session-active-target {
    margin-bottom: 12px !important;
    padding-bottom: 12px !important;
  }

  .session-active-target strong {
    font-size: clamp(1.85rem, 11vw, 2.8rem) !important;
  }

  .session-form-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
  }

  .session-body[data-session-panel] .session-form-3 label:nth-child(3) {
    grid-column: auto !important;
  }

  .session-form-row label {
    font-size: 0.66rem !important;
  }

  .session-body[data-session-panel] .session-form-row input,
  .session-body[data-session-panel] .session-form-row select {
    min-height: 50px !important;
    padding: 8px !important;
    font-size: 1rem !important;
  }

  .session-log {
    min-height: 56px !important;
  }

  .session-actions:has(.session-repeat:not([hidden])) {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .session-more-details summary,
  .session-adapt-details summary {
    min-height: 44px;
  }

  body.session-active .rest-timer {
    inset: 66px 8px auto 8px !important;
    width: auto !important;
  }
}
