.planner-router-page .page-hero,
.planner-desktop-page .page-hero,
.planner-mobile-page .page-hero {
  padding-top: clamp(2.5rem, 6vw, 4rem);
  padding-bottom: clamp(2rem, 5vw, 3.5rem);
}

.planner-router-page .page-hero > .container,
.planner-desktop-page .page-hero > .container,
.planner-mobile-page .page-hero > .container {
  display: grid;
  gap: 1.5rem;
}

.planner-launch-card,
.planner-choice-card,
.planner-inline-switch,
.mobile-card-dropdown,
.mobile-planner-shell,
.mobile-planner-panel,
.mobile-planner-stage,
.desktop-planner-shell,
.planner-clean-footer,
.planner-faq-card,
.planner-route-link-grid a,
.planner-process-card {
  background: rgba(255, 250, 240, 0.94);
  border: 1px solid rgba(20, 50, 38, 0.10);
  box-shadow: 0 22px 52px rgba(20, 50, 38, 0.10);
}

.planner-launch-card,
.planner-inline-switch,
.mobile-card-dropdown,
.desktop-planner-shell,
.mobile-planner-shell,
.planner-clean-footer {
  border-radius: 28px;
}

.planner-launch-card {
  display: grid;
  gap: 1rem;
  padding: 1.35rem;
}

.planner-launch-card.is-paused {
  border-color: rgba(197, 141, 79, 0.45);
  box-shadow: 0 22px 52px rgba(20, 50, 38, 0.12), 0 0 0 1px rgba(197, 141, 79, 0.18);
}

.planner-launch-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  align-items: center;
}

.planner-launch-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.45rem 0.8rem;
  border-radius: 999px;
  background: rgba(23, 53, 42, 0.08);
  color: var(--ink);
  font-size: 0.9rem;
  font-weight: 700;
}

.planner-launch-actions,
.planner-route-actions,
.planner-inline-switch-actions,
.mobile-planner-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.planner-choice-grid,
.planner-benefit-grid,
.planner-process-grid,
.planner-faq-grid,
.planner-route-link-grid {
  display: grid;
  gap: 1rem;
}

.planner-choice-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.planner-choice-card {
  border-radius: 26px;
  padding: 1.25rem;
  display: grid;
  gap: 0.9rem;
}

.planner-choice-card h3,
.planner-process-card h3,
.planner-faq-card h3 {
  margin: 0;
}

.planner-choice-card ul,
.planner-process-card ul,
.planner-route-link-grid,
.planner-checklist {
  margin: 0;
  padding: 0;
  list-style: none;
}

.planner-choice-card li,
.planner-process-card li,
.planner-checklist li {
  position: relative;
  padding-left: 1rem;
  color: #335546;
}

.planner-choice-card li + li,
.planner-process-card li + li,
.planner-checklist li + li {
  margin-top: 0.45rem;
}

.planner-choice-card li::before,
.planner-process-card li::before,
.planner-checklist li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.5rem;
  width: 0.4rem;
  height: 0.4rem;
  border-radius: 999px;
  background: #e86a1f;
}

.planner-choice-card .choice-label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.85rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--green);
}

.planner-choice-card .choice-label b {
  display: inline-grid;
  place-items: center;
  width: 1.8rem;
  height: 1.8rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #2c302f, #2a5a48);
  color: #fffaf4;
}

.planner-choice-card .choice-target {
  font-size: 0.95rem;
  color: #597163;
}

.planner-benefit-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.planner-process-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.planner-process-card,
.planner-faq-card {
  padding: 1.15rem;
  border-radius: 24px;
  display: grid;
  gap: 0.65rem;
}

.planner-process-step {
  display: inline-grid;
  place-items: center;
  width: 2.2rem;
  height: 2.2rem;
  border-radius: 999px;
  background: #2c302f;
  color: #fffaf4;
  font-weight: 800;
}

.planner-inline-switch {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: center;
  padding: 1rem 1.15rem;
}

.planner-inline-switch p,
.planner-inline-switch h2 {
  margin: 0;
}

.mobile-planner-hero-compact > .container {
  gap: 0.95rem;
}

.mobile-planner-hero-compact .lead {
  max-width: 42rem;
  margin-bottom: 0;
}

.desktop-planner-shell {
  padding: 1rem;
  overflow: hidden;
}

.desktop-planner-shell .planner-wrap {
  margin-top: 0;
}

.desktop-planner-shell .planner-pro-stage {
  margin-inline: 0;
}

.desktop-planner-shell .planner-pro-sidebar {
  max-width: 410px;
}

.planner-route-link-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.planner-route-link-grid a {
  display: grid;
  gap: 0.35rem;
  padding: 1rem;
  border-radius: 22px;
  text-decoration: none;
  color: var(--ink);
}

.planner-route-link-grid a span {
  font-size: 0.82rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--green);
}

.planner-clean-footer {
  margin-top: 2rem;
  padding: 1.35rem;
}

.planner-clean-footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 1rem;
  align-items: start;
}

.planner-clean-footer p,
.planner-clean-footer h2,
.planner-clean-footer h3 {
  margin-top: 0;
}

.planner-clean-footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem 1rem;
}

.planner-clean-footer-links a {
  color: var(--ink);
  font-weight: 700;
}

.planner-mobile-page main > .mobile-planner-priority-section {
  padding-top: 1rem;
}

.mobile-planner-intro {
  display: grid;
  gap: 0.45rem;
}

.mobile-planner-intro h1,
.mobile-planner-intro .lead {
  margin: 0;
}

.mobile-planner-intro .lead {
  max-width: 42rem;
}

.planner-mobile-page .mobile-planner-intro .breadcrumbs {
  display: none;
}

.planner-mobile-page .mobile-planner-intro h1 {
  font-size: clamp(2.2rem, 8.2vw, 3.15rem);
  line-height: 0.98;
  letter-spacing: -0.05em;
}

.planner-mobile-page .mobile-planner-intro .lead {
  font-size: 1rem;
  line-height: 1.45;
  max-width: 34rem;
}

.mobile-planner-shell {
  padding: 0;
  display: grid;
  gap: 0.9rem;
}

.mobile-planner-shell,
.mobile-planner-shell > *,
.mobile-planner-stage > *,
.mobile-planner-live-zone > *,
.mobile-planner-canvas-wrap,
.mobile-planner-live-sidebar,
.mobile-card-dropdown,
.mobile-card-dropdown > *,
.planner-inline-switch-accordion,
.planner-inline-switch-accordion > * {
  box-sizing: border-box;
  max-width: 100%;
  min-width: 0;
}

.mobile-planner-stage {
  border-radius: 24px;
  padding: 0.85rem;
  display: grid;
  gap: 0.75rem;
}

.mobile-planner-priority-note,
.mobile-planner-orientation-tip {
  margin: 0;
  color: #6d6a61;
  font-size: 0.92rem;
  line-height: 1.45;
}

.mobile-planner-quick-actions,
.mobile-planner-live-zone,
.mobile-planner-canvas-wrap,
.mobile-planner-live-sidebar {
  display: grid;
  gap: 0.75rem;
  width: 100%;
}

.mobile-planner-quick-actions {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.mobile-planner-orientation-tip {
  padding: 0.7rem 0.85rem;
  border-radius: 18px;
  background: rgba(232, 106, 31, 0.08);
}

.mobile-planner-stage-head,
.mobile-planner-summary,
.mobile-planner-style-grid,
.mobile-planner-toolbar,
.mobile-planner-upload-actions,
.mobile-planner-actions,
.mobile-planner-form-grid {
  display: grid;
  gap: 0.75rem;
}

.mobile-planner-stage-head {
  grid-template-columns: 1fr auto;
  align-items: center;
}

.mobile-planner-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.86rem;
  color: var(--green);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.mobile-planner-badge b {
  display: inline-grid;
  place-items: center;
  width: 1.9rem;
  height: 1.9rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #2c302f, #2a5a48);
  color: #fffaf4;
  font-size: 0.95rem;
}

.mobile-planner-summary {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.mobile-planner-summary div {
  padding: 0.85rem;
  border-radius: 18px;
  background: rgba(23, 53, 42, 0.06);
  min-width: 0;
}

.mobile-planner-summary span,
.mobile-planner-canvas-note,
.mobile-planner-help,
.mobile-planner-note {
  color: #597163;
}

.mobile-planner-summary strong,
.mobile-planner-upload-card strong,
.mobile-planner-panel strong {
  display: block;
  color: var(--ink);
}

.mobile-planner-upload-card {
  padding: 1rem;
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(243, 249, 244, 0.92));
  border: 1px dashed rgba(31, 91, 66, 0.28);
  display: grid;
  gap: 0.6rem;
}

.mobile-planner-upload-actions {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.mobile-card-dropdown {
  border-radius: 24px;
  overflow: hidden;
}

.planner-inline-switch-accordion {
  display: block;
  padding: 0;
}

.mobile-card-dropdown > summary,
.planner-inline-switch-accordion > summary {
  list-style: none;
  cursor: pointer;
  position: relative;
  display: grid;
  gap: 0.3rem;
  padding: 0.95rem 3.5rem 0.95rem 1rem;
}

.mobile-card-dropdown:not([open]) > summary,
.planner-inline-switch-accordion:not([open]) > summary {
  gap: 0;
  align-items: center;
  min-height: 4.2rem;
}

.mobile-card-dropdown > summary::-webkit-details-marker,
.planner-inline-switch-accordion > summary::-webkit-details-marker {
  display: none;
}

.mobile-card-dropdown > summary::after,
.planner-inline-switch-accordion > summary::after {
  content: '+';
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1.9rem;
  height: 1.9rem;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: rgba(42, 90, 72, 0.10);
  color: var(--ink);
  font-size: 1.15rem;
  font-weight: 800;
}

.mobile-card-dropdown[open] > summary::after,
.planner-inline-switch-accordion[open] > summary::after {
  content: '−';
}

.mobile-card-dropdown > summary span,
.planner-inline-switch-accordion > summary span {
  color: #8f4315;
  font-size: 0.82rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 800;
}

.mobile-card-dropdown > summary strong,
.planner-inline-switch-accordion > summary strong {
  display: block;
  color: var(--ink);
  font-size: 1rem;
  line-height: 1.2;
}

.mobile-card-dropdown:not([open]) > summary strong,
.planner-inline-switch-accordion:not([open]) > summary strong {
  display: none;
}

.mobile-card-dropdown-body {
  display: grid;
  gap: 0.85rem;
  padding: 0 1rem 1rem;
}

.mobile-card-dropdown-body-soft .mobile-planner-upload-card {
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.planner-inline-switch-body {
  display: grid;
  gap: 1rem;
}

.mobile-planner-style-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  overflow: visible;
  padding-bottom: 0;
}

.mobile-style-btn,
.mobile-toolbar-btn {
  width: 100%;
  border: 0;
  border-radius: 18px;
  background: rgba(23, 53, 42, 0.08);
  color: var(--ink);
  padding: 0.85rem 0.95rem;
  font: inherit;
  text-align: left;
  transition: transform 0.18s ease, background 0.18s ease, color 0.18s ease;
}

.mobile-style-btn {
  min-height: 74px;
}

.mobile-style-btn small,
.mobile-toolbar-btn small {
  display: block;
  color: #597163;
}

.mobile-style-btn.active,
.mobile-toolbar-btn.active,
.mobile-style-btn:hover,
.mobile-toolbar-btn:hover {
  background: linear-gradient(135deg, #2c302f, #2a5a48);
  color: #fffaf4;
  transform: translateY(-1px);
}

.mobile-style-btn.active small,
.mobile-toolbar-btn.active small,
.mobile-style-btn:hover small,
.mobile-toolbar-btn:hover small {
  color: rgba(255, 250, 240, 0.82);
}

.mobile-planner-toolbar {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.mobile-planner-toolbar-secondary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
}

#mobilePlannerCanvas {
  width: 100%;
  max-width: 100%;
  min-height: 340px;
  display: block;
  border-radius: 24px;
  background: linear-gradient(180deg, #f7f2e7, #dbe8de);
  touch-action: none;
}

.mobile-planner-panel {
  padding: 1rem;
  border-radius: 24px;
  display: grid;
  gap: 0.85rem;
}

.mobile-planner-form-grid {
  grid-template-columns: 1fr;
}

.mobile-planner-form-grid label,
.mobile-planner-panel label {
  display: grid;
  gap: 0.45rem;
  color: var(--ink);
  font-weight: 700;
}

.mobile-planner-form-grid input,
.mobile-planner-form-grid select,
.mobile-planner-form-grid textarea,
.mobile-planner-panel input,
.mobile-planner-panel select,
.mobile-planner-panel textarea {
  width: 100%;
  border-radius: 16px;
  border: 1px solid rgba(23, 53, 42, 0.14);
  background: #fffdf8;
  color: var(--ink);
  padding: 0.85rem 0.95rem;
  font: inherit;
}

.mobile-planner-actions .btn.is-disabled,
.mobile-planner-actions a[aria-disabled="true"] {
  pointer-events: none;
  opacity: 0.45;
}

.mobile-planner-note {
  margin: 0;
  font-size: 0.92rem;
}

.planner-router-page .site-footer,
.planner-desktop-page .site-footer,
.planner-mobile-page .site-footer {
  display: none;
}

@media (max-width: 980px) {
  .planner-choice-grid,
  .planner-benefit-grid,
  .planner-process-grid,
  .planner-route-link-grid,
  .planner-clean-footer-grid,
  .planner-inline-switch,
  .mobile-planner-toolbar,
  .mobile-planner-toolbar-secondary {
    grid-template-columns: 1fr;
  }

  .planner-inline-switch {
    align-items: stretch;
  }

  .planner-inline-switch-accordion {
    align-items: initial;
  }

  .planner-inline-switch-actions,
  .planner-route-actions,
  .planner-launch-actions {
    flex-direction: column;
  }

  .planner-choice-grid {
    grid-template-columns: 1fr;
  }

  .mobile-planner-summary,
  .mobile-planner-upload-actions {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 720px) {
  .planner-launch-card,
  .planner-choice-card,
  .planner-process-card,
  .planner-faq-card,
  .mobile-planner-shell,
  .mobile-planner-panel,
  .mobile-planner-stage,
  .desktop-planner-shell,
  .planner-clean-footer {
    border-radius: 22px;
  }

  .mobile-planner-upload-actions,
  .mobile-planner-actions {
    grid-template-columns: 1fr;
  }

  .planner-router-page .page-hero,
  .planner-desktop-page .page-hero,
  .planner-mobile-page .page-hero {
    padding-top: 1.25rem;
    padding-bottom: 1rem;
  }
}

@media (max-width: 560px) {
  .mobile-planner-stage-head,
  .mobile-planner-summary,
  .mobile-planner-style-grid {
    grid-template-columns: 1fr;
  }

  .mobile-planner-stage-head .btn {
    width: 100%;
  }
}

/* Truck palette alignment for planner routes */
.planner-launch-card,
.planner-choice-card,
.planner-inline-switch,
.mobile-card-dropdown,
.mobile-planner-shell,
.mobile-planner-panel,
.mobile-planner-stage,
.desktop-planner-shell,
.planner-clean-footer,
.planner-faq-card,
.planner-route-link-grid a,
.planner-process-card{
  background:rgba(255,250,244,.95);
  border:1px solid rgba(44,48,47,.08);
  box-shadow:0 22px 52px rgba(44,48,47,.12);
}

.planner-launch-badge{
  background:rgba(232,106,31,.12);
  color:var(--ink);
}

.planner-choice-card .choice-label,
.planner-choice-card .choice-target,
.planner-route-link-grid a span,
.mobile-planner-badge{
  color:#8f4315;
}

.planner-choice-card .choice-label b,
.mobile-planner-badge b,
.planner-process-step{
  background:linear-gradient(135deg,#e86a1f,#c95416);
  color:#fffaf4;
}

.planner-choice-card li::before,
.planner-process-card li::before,
.planner-checklist li::before{
  background:#e86a1f;
}

.planner-route-link-grid a{
  color:var(--ink);
}

.planner-route-link-grid a strong{
  color:var(--ink);
}

.planner-route-link-grid a small,
.planner-launch-card .fineprint,
.mobile-planner-note,
.mobile-planner-help,
.mobile-planner-summary span{
  color:#6d6a61;
}

.mobile-planner-upload-card{
  background:linear-gradient(180deg,rgba(255,250,244,.96),rgba(246,239,226,.96));
  border-color:rgba(232,106,31,.22);
}

.mobile-planner-summary div{
  background:rgba(232,106,31,.08);
}

.mobile-planner-summary strong{
  font-size:.98rem;
  line-height:1.1;
}

.mobile-style-btn,
.mobile-toolbar-btn{
  background:rgba(42,90,72,.08);
  color:var(--ink);
}

.mobile-style-btn.active,
.mobile-toolbar-btn.active,
.mobile-style-btn:hover,
.mobile-toolbar-btn:hover{
  background:linear-gradient(135deg,#e86a1f,#c95416);
  color:#fffaf4;
}

.mobile-style-btn.active small,
.mobile-toolbar-btn.active small,
.mobile-style-btn:hover small,
.mobile-toolbar-btn:hover small{
  color:rgba(255,250,244,.82);
}

#mobilePlannerCanvas{
  background:linear-gradient(180deg,#f6efe2,#dde5da);
}

@media (max-width:720px){
  .mobile-planner-hero-compact h1{
    font-size: clamp(1.95rem, 9vw, 2.55rem);
  }

  .mobile-planner-hero-compact .lead{
    font-size: 0.98rem;
  }

  .mobile-planner-shell{
    padding: .85rem;
  }

  .mobile-planner-quick-actions{
    grid-template-columns: 1fr;
  }

  .mobile-planner-summary{
    gap:.55rem;
  }

  .mobile-planner-summary div{
    padding:.7rem .6rem;
    border-radius:16px;
  }

  .mobile-planner-summary span{
    font-size:.72rem;
    line-height:1.15;
  }

  .mobile-style-btn{
    min-height:68px;
    padding:.8rem .85rem;
  }

  .mobile-style-btn strong{
    font-size:.95rem;
    line-height:1.05;
  }

  .mobile-style-btn small{
    font-size:.78rem;
    line-height:1.2;
  }
}

@media (max-width: 980px) and (orientation: landscape) {
  .planner-mobile-page main > .mobile-planner-priority-section {
    padding-top: 0.65rem;
  }

  .mobile-planner-intro {
    gap: 0.35rem;
  }

  .mobile-planner-intro .breadcrumbs {
    display: none;
  }

  .mobile-planner-live-zone {
    grid-template-columns: minmax(0, 1.45fr) minmax(220px, 0.8fr);
    align-items: start;
  }

  .mobile-planner-live-sidebar .mobile-planner-toolbar,
  .mobile-planner-live-sidebar .mobile-planner-toolbar-secondary,
  .mobile-planner-quick-actions {
    grid-template-columns: 1fr;
  }

  #mobilePlannerCanvas {
    min-height: 62vh;
  }
}

/* 2026-06 final planner palette: orange bodywork, charcoal trim, off-white field */
.planner-launch-card,
.planner-choice-card,
.planner-inline-switch,
.mobile-card-dropdown,
.mobile-planner-shell,
.mobile-planner-stage,
.desktop-planner-shell,
.planner-clean-footer,
.planner-faq-card,
.planner-route-link-grid a,
.planner-process-card{
  background:rgba(255,250,244,.97);
  border-color:rgba(33,28,25,.10);
  box-shadow:0 22px 52px rgba(33,28,25,.10);
}

.planner-choice-card .choice-label,
.planner-choice-card .choice-target,
.planner-route-link-grid a span,
.mobile-planner-badge,
.mobile-card-dropdown > summary span,
.planner-inline-switch-accordion > summary span{
  color:#9a4515;
}

.planner-choice-card .choice-label b,
.mobile-planner-badge b,
.planner-process-step{
  background:linear-gradient(135deg,#f07a2b,#d85714);
  color:#fffaf4;
}

.mobile-card-dropdown > summary::after,
.planner-inline-switch-accordion > summary::after{
  background:rgba(33,28,25,.08);
  color:#2c302f;
}

.mobile-planner-priority-note,
.mobile-planner-orientation-tip,
.planner-route-link-grid a small,
.planner-launch-card .fineprint,
.mobile-planner-note,
.mobile-planner-help,
.mobile-planner-summary span{
  color:#77685e;
}

.mobile-planner-summary div,
.mobile-planner-orientation-tip{
  background:rgba(232,106,31,.08);
  border:1px solid rgba(232,106,31,.14);
}

.mobile-planner-upload-card{
  background:linear-gradient(180deg,rgba(255,250,244,.98),rgba(255,241,229,.96));
  border-color:rgba(232,106,31,.22);
}

.mobile-style-btn,
.mobile-toolbar-btn{
  background:rgba(33,28,25,.05);
  color:var(--ink);
  border:1px solid rgba(33,28,25,.08);
}

.mobile-style-btn small,
.mobile-toolbar-btn small{
  color:#77685e;
}

.mobile-style-btn.active,
.mobile-toolbar-btn.active,
.mobile-style-btn:hover,
.mobile-toolbar-btn:hover{
  background:linear-gradient(135deg,#f07a2b,#d85714);
  border-color:rgba(216,87,20,.45);
  color:#fffaf4;
}

.mobile-style-btn.active small,
.mobile-toolbar-btn.active small,
.mobile-style-btn:hover small,
.mobile-toolbar-btn:hover small{
  color:rgba(255,250,244,.84);
}

#mobilePlannerCanvas{
  background:linear-gradient(180deg,#fff5ec,#f1e7db);
  border:1px solid rgba(33,28,25,.08);
}

/* 2026-06 UX refinement: surface the tools faster on desktop and mobile */
body.planner-desktop-page main{
  display:flex;
  flex-direction:column;
}

body.planner-desktop-page main > *{
  order:4;
}

body.planner-desktop-page .planner-hero-pro{
  order:1;
}

body.planner-desktop-page #plannerStudio{
  order:2;
  margin-top:-0.85rem;
  padding-top:0.35rem;
  position:relative;
  z-index:2;
  scroll-margin-top:5.6rem;
}

body.planner-desktop-page #plannerWorkflow{
  order:3;
  padding-top:1rem;
  border-bottom:0;
}

body.planner-desktop-page .planner-hero-pro > .container{
  gap:1rem;
}

body.planner-desktop-page .planner-inline-switch{
  padding:0.95rem 1rem;
}

.planner-desktop-hero-actions{
  align-items:center;
}

body.planner-mobile-page .mobile-planner-stage-head{
  gap:0.55rem 0.85rem;
  align-items:start;
}

body.planner-mobile-page #mobilePlannerRestoreBtn{
  min-height:2.65rem;
  padding:0.62rem 0.9rem;
  white-space:nowrap;
  justify-self:end;
}

body.planner-mobile-page .mobile-planner-priority-note{
  font-size:0.88rem;
  line-height:1.35;
}

body.planner-mobile-page .mobile-planner-live-zone{
  align-items:start;
}

body.planner-mobile-page #mobilePlannerCanvas{
  min-height:300px;
}

body.planner-mobile-page #mobilePlannerStage,
body.planner-desktop-page #dropZone{
  scroll-margin-top:5.6rem;
}

body.planner-mobile-page .mobile-planner-summary{
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:0.55rem;
  margin-top:0.15rem;
}

body.planner-mobile-page .mobile-planner-summary div{
  padding:0.68rem 0.72rem;
  border-radius:16px;
  min-width:0;
}

body.planner-mobile-page .mobile-planner-summary span{
  font-size:0.71rem;
  letter-spacing:0.03em;
}

body.planner-mobile-page .mobile-planner-summary strong{
  font-size:0.95rem;
  line-height:1.08;
  overflow-wrap:anywhere;
}

@media (max-width:980px){
  body.planner-desktop-page #plannerStudio{
    margin-top:-0.45rem;
  }
}

@media (max-width:560px){
  body.planner-mobile-page .mobile-planner-stage-head{
    grid-template-columns:minmax(0, 1fr) auto;
  }

  body.planner-mobile-page .mobile-planner-stage-head .btn{
    width:auto;
  }

  body.planner-mobile-page .mobile-planner-summary{
    grid-template-columns:repeat(3, minmax(0, 1fr));
  }
}

/* UX max pass: planner power stays available, but the first view is calmer. */
body.planner-desktop-page,
body.planner-mobile-page{
  overflow-x:hidden;
}

body.planner-desktop-page .planner-control-focus{
  display:grid;
  grid-column:1 / -1;
  gap:0.65rem;
  padding:0.85rem;
  border:1px solid rgba(23,53,42,0.12);
  border-radius:22px;
  background:linear-gradient(135deg,rgba(255,250,240,0.96),rgba(237,246,238,0.92));
  box-shadow:0 14px 36px rgba(22,49,38,0.08);
}

body.planner-desktop-page .planner-control-focus > div{
  display:grid;
  gap:0.15rem;
}

body.planner-desktop-page .planner-control-focus strong{
  color:#10251d;
  line-height:1.12;
}

body.planner-desktop-page .planner-control-focus button{
  appearance:none;
  border:1px solid rgba(23,53,42,0.14);
  border-radius:999px;
  background:#fff;
  color:#17352a;
  min-height:42px;
  padding:0.58rem 0.72rem;
  font:inherit;
  font-weight:950;
  cursor:pointer;
}

body.planner-desktop-page .planner-control-focus button.active,
body.planner-desktop-page .planner-control-focus button:focus-visible{
  background:linear-gradient(135deg,#2c302f,#17352a);
  color:#fffaf0;
  border-color:rgba(232,106,31,0.42);
}

@media (min-width:761px){
  body.planner-desktop-page .planner-control-focus{
    grid-template-columns:1fr repeat(3,auto);
    align-items:center;
    position:sticky;
    top:84px;
    z-index:5;
  }

  body.planner-desktop-page .planner-sidebar .planner-accordion-card{
    padding:0;
    overflow:hidden;
    border-radius:22px;
  }

  body.planner-desktop-page .planner-sidebar .planner-accordion-card > .mobile-card-toggle{
    appearance:none;
    display:flex !important;
    align-items:center;
    justify-content:space-between;
    gap:1rem;
    width:100%;
    min-height:58px;
    border:0;
    border-radius:0;
    padding:0.95rem 1rem;
    background:linear-gradient(135deg,#fffaf0,#f3f9f4);
    color:#10251d;
    box-shadow:none;
    cursor:pointer;
    text-align:left;
    font:inherit;
  }

  body.planner-desktop-page .planner-sidebar .planner-accordion-card > .mobile-card-toggle::after{
    content:"Show";
    flex:0 0 auto;
    border-radius:999px;
    background:rgba(23,53,42,0.08);
    color:#17352a;
    padding:0.42rem 0.66rem;
    font-size:0.72rem;
    font-weight:1000;
    letter-spacing:0.04em;
    text-transform:uppercase;
  }

  body.planner-desktop-page .planner-sidebar .planner-accordion-card.is-open > .mobile-card-toggle::after{
    content:"Hide";
    background:#17352a;
    color:#fffaf0;
  }

  body.planner-desktop-page .planner-sidebar .planner-accordion-card > .mobile-card-toggle span{
    display:block;
    color:#e86a1f;
    font-size:0.68rem;
    line-height:1;
    letter-spacing:0.08em;
    text-transform:uppercase;
    margin-bottom:0.2rem;
  }

  body.planner-desktop-page .planner-sidebar .planner-accordion-card > .mobile-card-toggle strong{
    display:block;
    font-size:1rem;
    line-height:1.1;
    color:#10251d;
  }

  body.planner-desktop-page .planner-sidebar .planner-accordion-card > .card-kicker,
  body.planner-desktop-page .planner-sidebar .planner-accordion-card > h2{
    display:none;
  }

  body.planner-desktop-page .planner-sidebar .planner-accordion-card:not(.is-open) > :not(.mobile-card-toggle){
    display:none !important;
  }

  body.planner-desktop-page .planner-sidebar .planner-accordion-card.is-open{
    padding-bottom:1rem;
  }

  body.planner-desktop-page .planner-sidebar .planner-accordion-card.is-open > :not(.mobile-card-toggle):not(.card-kicker):not(h2){
    margin-left:1rem;
    margin-right:1rem;
  }

  body.planner-desktop-page .planner-sidebar .planner-accordion-card.is-open > .type-grid,
  body.planner-desktop-page .planner-sidebar .planner-accordion-card.is-open > .planner-actions,
  body.planner-desktop-page .planner-sidebar .planner-accordion-card.is-open > .mini-field-grid,
  body.planner-desktop-page .planner-sidebar .planner-accordion-card.is-open > .metric-grid,
  body.planner-desktop-page .planner-sidebar .planner-accordion-card.is-open > .preset-panel,
  body.planner-desktop-page .planner-sidebar .planner-accordion-card.is-open > .layout-template-panel,
  body.planner-desktop-page .planner-sidebar .planner-accordion-card.is-open > .material-intel-card,
  body.planner-desktop-page .planner-sidebar .planner-accordion-card.is-open > .control-group{
    margin-top:0.85rem;
  }

  body.planner-desktop-page .planner-canvas-dock{
    top:auto;
    bottom:16px;
    width:auto;
    max-width:min(90%,760px);
    background:rgba(8,22,18,0.68);
  }

  body.planner-desktop-page .planner-coach{
    left:18px;
    top:18px;
    bottom:auto;
  }

  body.planner-desktop-page .planner-selection-panel{
    bottom:86px;
  }
}

.mobile-planner-next-step{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:0.75rem;
  align-items:center;
  margin-top:0.65rem;
  padding:0.82rem;
  border:1px solid rgba(23,53,42,0.12);
  border-radius:20px;
  background:linear-gradient(135deg,rgba(255,250,240,0.96),rgba(237,246,238,0.94));
  box-shadow:0 14px 34px rgba(22,49,38,0.08);
}

.mobile-planner-next-meter{
  grid-column:1 / -1;
  height:0.48rem;
  border-radius:999px;
  background:rgba(23,53,42,0.10);
  overflow:hidden;
}

.mobile-planner-next-meter span{
  display:block;
  height:100%;
  width:0;
  border-radius:inherit;
  background:linear-gradient(90deg,#e86a1f,#17352a);
  transition:width 0.2s ease;
}

.mobile-planner-next-copy{
  display:grid;
  gap:0.18rem;
  min-width:0;
}

.mobile-planner-next-copy strong{
  color:#10251d;
  line-height:1.14;
}

.mobile-planner-next-copy span{
  color:#53695d;
  font-size:0.86rem;
  line-height:1.28;
  font-weight:760;
}

.mobile-planner-next-step .btn{
  white-space:nowrap;
}

@media (max-width:560px){
  .mobile-planner-next-step{
    grid-template-columns:1fr;
    padding:0.75rem;
  }

  .mobile-planner-next-step .btn{
    width:100%;
  }

  body.planner-mobile-page .mobile-planner-live-zone,
  body.planner-mobile-page .mobile-planner-stage,
  body.planner-mobile-page .mobile-card-dropdown{
    max-width:100%;
  }
}

/* 2026-06 deeper mobile planner pass: bring the canvas closer to the first screen. */
.mobile-planner-next-actions{
  display:grid;
  grid-template-columns:1fr;
  gap:0.48rem;
  min-width:0;
}

.mobile-planner-next-actions .btn{
  width:100%;
  min-width:0;
  justify-content:center;
}

@media (max-width:760px){
  body.planner-mobile-page main > .mobile-planner-priority-section{
    padding-top:0.35rem;
  }

  body.planner-mobile-page .mobile-planner-shell{
    gap:0.55rem;
  }

  body.planner-mobile-page .mobile-planner-intro{
    gap:0.2rem;
  }

  body.planner-mobile-page .mobile-planner-intro .eyebrow{
    font-size:0.68rem;
    letter-spacing:0.09em;
  }

  body.planner-mobile-page .mobile-planner-intro h1{
    font-size:clamp(1.56rem,7.6vw,2.05rem);
    line-height:0.98;
    letter-spacing:-0.045em;
  }

  body.planner-mobile-page .mobile-planner-intro .lead{
    max-width:29rem;
    font-size:0.86rem;
    line-height:1.28;
  }

  body.planner-mobile-page #mobilePlannerStage{
    gap:0.5rem;
    padding:0.62rem;
    border-radius:20px;
  }

  body.planner-mobile-page .mobile-planner-stage-head{
    gap:0.4rem 0.6rem;
  }

  body.planner-mobile-page #mobilePlannerRestoreBtn:disabled{
    display:none;
  }

  body.planner-mobile-page .mobile-planner-stage-head strong{
    font-size:0.94rem;
    line-height:1.12;
  }

  body.planner-mobile-page .mobile-planner-badge{
    gap:0.36rem;
    font-size:0.7rem;
    letter-spacing:0.075em;
  }

  body.planner-mobile-page .mobile-planner-badge b{
    width:1.45rem;
    height:1.45rem;
    font-size:0.78rem;
  }

  body.planner-mobile-page .mobile-planner-priority-note{
    padding:0.48rem 0.58rem;
    border:1px solid rgba(232,106,31,.13);
    border-radius:14px;
    background:rgba(232,106,31,.07);
    font-size:0.76rem;
    line-height:1.22;
  }

  body.planner-mobile-page .mobile-planner-quick-actions{
    gap:0.46rem;
  }

  body.planner-mobile-page .mobile-planner-quick-actions .btn{
    min-height:42px;
    padding:0.58rem 0.5rem;
    border-radius:14px;
    font-size:0.84rem;
    line-height:1.05;
  }

  body.planner-mobile-page #mobilePlannerCanvas{
    min-height:280px;
    border-radius:18px;
  }

  body.planner-mobile-page .mobile-planner-help{
    margin-top:-0.16rem;
    font-size:0.78rem;
    line-height:1.22;
  }

  body.planner-mobile-page .mobile-planner-toolbar,
  body.planner-mobile-page .mobile-planner-toolbar-secondary{
    gap:0.45rem;
  }

  body.planner-mobile-page .mobile-toolbar-btn{
    min-height:52px;
    padding:0.52rem 0.42rem;
    border-radius:14px;
  }

  body.planner-mobile-page .mobile-toolbar-btn strong{
    font-size:0.82rem;
    line-height:1.05;
  }

  body.planner-mobile-page .mobile-toolbar-btn small{
    font-size:0.68rem;
    line-height:1.12;
  }

  body.planner-mobile-page .mobile-planner-toolbar-secondary .btn{
    min-height:40px;
    padding:0.5rem 0.35rem;
    border-radius:13px;
    font-size:0.72rem;
    line-height:1.05;
  }

  body.planner-mobile-page .mobile-planner-orientation-tip{
    padding:0.52rem 0.62rem;
    border-radius:14px;
    font-size:0.76rem;
    line-height:1.2;
  }

  body.planner-mobile-page .mobile-card-dropdown:not([open]) > summary,
  body.planner-mobile-page .planner-inline-switch-accordion:not([open]) > summary{
    min-height:3.45rem;
    padding-top:0.72rem;
    padding-bottom:0.72rem;
  }
}

@media (max-width:380px){
  body.planner-mobile-page .mobile-planner-intro h1{
    font-size:1.45rem;
  }

  body.planner-mobile-page .mobile-planner-stage-head{
    grid-template-columns:1fr;
  }

  body.planner-mobile-page #mobilePlannerRestoreBtn{
    justify-self:start;
  }
}

/* Landscape phone mode: turn the planner into a compact field sketch studio. */
@media (max-width:980px) and (orientation:landscape){
  body.planner-mobile-page .site-header{
    position:relative;
  }

  body.planner-mobile-page .header-inner{
    min-height:48px;
    padding:5px 0;
  }

  body.planner-mobile-page .brand img{
    width:118px;
  }

  body.planner-mobile-page .nav-toggle{
    min-height:38px;
    padding:0.42rem 0.68rem;
  }

  body.planner-mobile-page .header-cta{
    display:none;
  }

  body.planner-mobile-page main > .mobile-planner-priority-section{
    padding-top:0.25rem;
    padding-bottom:1rem;
  }

  body.planner-mobile-page .mobile-planner-shell{
    gap:0.45rem;
    padding:0.5rem;
    border-radius:20px;
  }

  body.planner-mobile-page .mobile-planner-intro{
    display:none;
  }

  body.planner-mobile-page #mobilePlannerStage{
    position:relative;
    gap:0.45rem;
    padding:0.5rem;
    border-radius:18px;
  }

  body.planner-mobile-page .mobile-planner-stage-head{
    grid-template-columns:minmax(0,1fr) auto;
    gap:0.45rem;
    min-height:40px;
    padding-right:calc(min(45vw,260px) + 0.6rem);
  }

  body.planner-mobile-page #mobilePlannerRestoreBtn{
    display:none !important;
  }

  body.planner-mobile-page .mobile-planner-stage-head strong{
    font-size:0.9rem;
    line-height:1.08;
  }

  body.planner-mobile-page .mobile-planner-priority-note{
    display:none;
  }

  body.planner-mobile-page .mobile-planner-quick-actions{
    position:absolute;
    top:0.5rem;
    right:0.5rem;
    z-index:3;
    width:min(45vw,260px);
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:0.45rem;
  }

  body.planner-mobile-page .mobile-planner-quick-actions .btn{
    min-height:38px;
    padding:0.48rem 0.55rem;
    border-radius:13px;
    font-size:0.8rem;
  }

  body.planner-mobile-page .mobile-planner-live-zone{
    grid-template-columns:minmax(0,1.55fr) minmax(210px,0.7fr);
    gap:0.5rem;
  }

  body.planner-mobile-page #mobilePlannerCanvas{
    min-height:260px;
    border-radius:16px;
  }

  body.planner-mobile-page .mobile-planner-help{
    display:none;
  }

  body.planner-mobile-page .mobile-planner-live-sidebar{
    gap:0.45rem;
  }

  body.planner-mobile-page .mobile-planner-toolbar,
  body.planner-mobile-page .mobile-planner-toolbar-secondary{
    grid-template-columns:1fr;
    gap:0.38rem;
  }

  body.planner-mobile-page .mobile-toolbar-btn,
  body.planner-mobile-page .mobile-planner-toolbar-secondary .btn{
    min-height:36px;
    padding:0.42rem 0.48rem;
    border-radius:12px;
    font-size:0.72rem;
  }

  body.planner-mobile-page .mobile-toolbar-btn small{
    display:none;
  }

  body.planner-mobile-page .mobile-planner-orientation-tip{
    display:none;
  }

  body.planner-mobile-page .mobile-planner-summary{
    gap:0.4rem;
  }

  body.planner-mobile-page .mobile-planner-summary div{
    padding:0.48rem 0.55rem;
    border-radius:13px;
  }

  body.planner-mobile-page .mobile-planner-summary span{
    font-size:0.64rem;
  }

  body.planner-mobile-page .mobile-planner-summary strong{
    font-size:0.82rem;
  }

  body.planner-mobile-page .mobile-planner-next-step{
    grid-template-columns:minmax(0,1fr) auto;
    gap:0.48rem;
    margin-top:0.45rem;
    padding:0.55rem;
    border-radius:16px;
  }

  body.planner-mobile-page .mobile-planner-next-copy span{
    display:none;
  }

  body.planner-mobile-page .mobile-planner-next-actions{
    grid-template-columns:repeat(2,minmax(0,1fr));
    min-width:min(260px,42vw);
  }

  body.planner-mobile-page .mobile-card-dropdown:not([open]) > summary,
  body.planner-mobile-page .planner-inline-switch-accordion:not([open]) > summary{
    min-height:3rem;
    padding:0.62rem 3rem 0.62rem 0.82rem;
  }
}

/* 2026-06 spruce accent pass for planner routes. */
:root{
  --spruce:#145c5a;
  --spruce-2:#0f4947;
  --spruce-3:#eaf4f1;
  --spruce-line:rgba(20,92,90,.18);
  --spruce-line-strong:rgba(20,92,90,.32);
  --orange:#f07a2b;
  --orange-2:#d85714;
}

.planner-launch-badge,
.mobile-planner-summary div,
.mobile-planner-orientation-tip{
  background:rgba(20,92,90,.09) !important;
  border-color:var(--spruce-line) !important;
}

.planner-choice-card .choice-label,
.planner-choice-card .choice-target,
.planner-route-link-grid a span,
.mobile-planner-badge,
.mobile-card-dropdown > summary span,
.planner-inline-switch-accordion > summary span{
  color:var(--spruce-2) !important;
}

.planner-choice-card li::before,
.planner-process-card li::before,
.planner-checklist li::before{
  background:var(--spruce) !important;
}

.mobile-planner-upload-card{
  background:linear-gradient(180deg,rgba(255,250,244,.98),rgba(234,244,241,.92)) !important;
  border-color:var(--spruce-line-strong) !important;
}

.planner-route-link-grid a:hover,
.planner-choice-card:hover,
.planner-faq-card:hover{
  border-color:var(--spruce-line-strong) !important;
  box-shadow:0 18px 40px rgba(20,92,90,.12) !important;
}

.mobile-style-btn,
.mobile-toolbar-btn{
  background:rgba(20,92,90,.07) !important;
  border-color:var(--spruce-line) !important;
}

.mobile-style-btn.active,
.mobile-toolbar-btn.active,
.mobile-style-btn:hover,
.mobile-toolbar-btn:hover,
.planner-choice-card .choice-label b,
.mobile-planner-badge b,
.planner-process-step{
  background:linear-gradient(135deg,var(--orange),var(--orange-2)) !important;
  border-color:rgba(216,87,20,.42) !important;
  color:#fffaf4 !important;
}

#mobilePlannerCanvas{
  background:linear-gradient(180deg,#f6efe2,#e1ece7) !important;
}
