.cc-page {
  margin-top: -0.35rem;
}

.cc-root {
  --cc-bg: #f3f9fc;
  --cc-panel: #ffffff;
  --cc-panel-soft: #f5fbff;
  --cc-line: #b6d4e3;
  --cc-line-strong: #7faec3;
  --cc-text: #113144;
  --cc-muted: #345d72;
  --cc-accent: #1e7aa7;
  --cc-accent-dark: #135a7d;
  --cc-good: #1d7f57;
  --cc-bad: #a33d2b;
  --cc-warn: #9a6a1f;
  --cc-ocean: #2d84b5;
  --cc-ocean-deep: #1f628c;
  --cc-land: #6a8e52;
  --cc-shore: #cdb37c;
  --cc-marsh: #2f8758;
  --cc-wall: #8e9096;
  font-family: "Atkinson Hyperlegible", "Segoe UI", Tahoma, sans-serif;
  color: var(--cc-text);
  margin-top: 0;
}

.cc-shell {
  border: 1px solid var(--cc-line);
  border-radius: 18px;
  overflow: hidden;
  background: linear-gradient(180deg, #fcfeff, #ebf6fc);
  box-shadow: 0 14px 34px rgba(9, 44, 67, 0.16);
  min-height: min(88vh, 1040px);
}

.cc-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.75rem;
  padding: 0.95rem;
  color: #f2fbff;
  border-bottom: 1px solid rgba(216, 240, 252, 0.42);
  background: linear-gradient(152deg, #0f4f73, #1777a2 58%, #1a8a8b);
}

.cc-header h2 {
  margin: 0;
  color: #ffffff;
  font-size: clamp(1.2rem, 2.4vw, 1.62rem);
}

.cc-header p {
  margin: 0.25rem 0 0;
  font-size: 0.92rem;
  color: rgba(241, 251, 255, 0.96);
}

.cc-start-grid,
.cc-layout {
  display: grid;
  gap: 0.78rem;
  padding: 0.85rem;
}

.cc-start-grid {
  grid-template-columns: 1.1fr 0.9fr;
}

.cc-layout {
  grid-template-columns: minmax(0, 1.95fr) minmax(310px, 0.9fr);
  align-items: stretch;
}

.cc-panel {
  border: 1px solid var(--cc-line);
  border-radius: 14px;
  background: var(--cc-panel);
  padding: 0.72rem;
}

.cc-panel h3,
.cc-panel h4 {
  margin: 0;
  color: #124d69;
}

.cc-label {
  margin: 0.45rem 0 0.28rem;
  display: block;
  font-size: 0.8rem;
  font-weight: 700;
  color: #245367;
}

.cc-input {
  width: 100%;
  border: 1px solid #9ec6da;
  border-radius: 10px;
  padding: 0.54rem 0.64rem;
  font: inherit;
  color: var(--cc-text);
  background: #f8fdff;
}

.cc-row {
  display: flex;
  align-items: center;
  gap: 0.45rem;
}

.cc-row.wrap {
  flex-wrap: wrap;
}

.cc-row.spread {
  justify-content: space-between;
}

.cc-btn {
  border: 1px solid var(--cc-accent-dark);
  border-radius: 10px;
  padding: 0.46rem 0.72rem;
  font: inherit;
  font-weight: 700;
  letter-spacing: 0.01em;
  color: #ffffff;
  background: linear-gradient(180deg, #1794c8, #0f709a);
  cursor: pointer;
  transition: transform 120ms ease, filter 120ms ease;
}

.cc-btn:hover {
  filter: brightness(1.05);
}

.cc-btn:active {
  transform: translateY(1px);
}

.cc-btn.soft {
  border-color: #97bfd4;
  color: #184c66;
  background: linear-gradient(180deg, #f9fdff, #e4f1fa);
}

.cc-btn:disabled,
.cc-tool-btn:disabled,
.cc-choice-btn:disabled {
  cursor: not-allowed;
  opacity: 0.45;
  filter: grayscale(0.2);
}

.cc-badge {
  border: 1px solid #95bfd6;
  border-radius: 999px;
  font-size: 0.72rem;
  padding: 0.1rem 0.44rem;
  color: #1f5a72;
  background: #eff8fd;
}

.cc-note {
  margin: 0.2rem 0;
  font-size: 0.88rem;
  color: #2b576d;
}

.cc-metrics-bar {
  padding: 0.75rem 0.85rem 0;
  display: grid;
  gap: 0.46rem;
  grid-template-columns: repeat(5, minmax(120px, 1fr));
}

.cc-metric {
  border: 1px solid #c2deeb;
  border-radius: 12px;
  padding: 0.52rem 0.56rem;
  background: linear-gradient(180deg, #f9fdff, #eef8fd);
}

.cc-metric span {
  display: block;
  font-size: 0.72rem;
  color: #2d5c74;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.cc-metric strong {
  display: block;
  margin-top: 0.14rem;
  font-size: 1.12rem;
  color: #0f3950;
}

.cc-delta {
  display: inline-block;
  margin-top: 0.2rem;
  font-size: 0.74rem;
  font-weight: 700;
}

.cc-delta.up { color: var(--cc-good); }
.cc-delta.down { color: var(--cc-bad); }
.cc-delta.flat { color: #4f7285; }

.cc-map-panel {
  min-height: 100%;
  display: grid;
  gap: 0.55rem;
  align-content: start;
}

.cc-side-panel {
  display: grid;
  gap: 0.5rem;
  align-content: start;
  max-height: min(80vh, 860px);
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-gutter: stable;
  position: sticky;
  top: 0.45rem;
}

.cc-action-bar {
  position: sticky;
  top: -0.05rem;
  z-index: 4;
  padding: 0.3rem 0;
  margin: -0.18rem 0 0.12rem;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(255, 255, 255, 0.92));
  border-bottom: 1px solid #d8ebf5;
}

.cc-map-wrap {
  position: relative;
  border: 1px solid #9bc1d6;
  border-radius: 12px;
  overflow: hidden;
  min-height: clamp(460px, 68vh, 760px);
}

#cc-map {
  width: 100%;
  display: block;
  background: linear-gradient(180deg, var(--cc-ocean), var(--cc-ocean-deep));
  cursor: pointer;
}

#cc-map.cc-storm-pulse {
  animation: ccStormPulse 580ms ease-out;
}

.cc-map-overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}

.cc-map-overlay.storm::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(175, 225, 246, 0) 0%, rgba(175, 225, 246, 0.34) 45%, rgba(255, 255, 255, 0.2) 58%, rgba(175, 225, 246, 0) 100%);
  transform: translateX(-110%);
  animation: ccWaveSweep 800ms ease-out;
}

.cc-float {
  position: absolute;
  font-size: 0.78rem;
  font-weight: 700;
  text-shadow: 0 1px 2px rgba(255, 255, 255, 0.62);
  transform: translate(-50%, -50%);
  white-space: nowrap;
}

.cc-preview {
  margin-top: 0.42rem;
  border: 1px solid #a6cde1;
  border-radius: 10px;
  padding: 0.45rem 0.54rem;
  background: #f5fbff;
  font-size: 0.82rem;
  color: #254f63;
}

.cc-preview.ok {
  border-color: #95d1b5;
  background: #eef9f3;
}

.cc-preview.bad {
  border-color: #e1b3ab;
  background: #fff3f1;
}

.cc-objectives {
  border: 1px solid #b3d3e4;
  border-radius: 11px;
  background: linear-gradient(180deg, #f9fdff, #eef8fd);
  padding: 0.5rem;
  display: grid;
  gap: 0.4rem;
}

.cc-objectives h4 {
  margin: 0;
}

.cc-objective-list {
  display: grid;
  gap: 0.34rem;
}

.cc-objective {
  display: grid;
  grid-template-columns: 62px 1fr auto;
  gap: 0.45rem;
  align-items: center;
  border: 1px solid #c5deea;
  border-radius: 10px;
  background: #ffffff;
  padding: 0.34rem 0.42rem;
}

.cc-objective span {
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: #8c5317;
  text-transform: uppercase;
}

.cc-objective strong {
  font-size: 0.78rem;
  color: #164d66;
}

.cc-objective em {
  font-style: normal;
  font-size: 0.75rem;
  color: #2a5b71;
}

.cc-objective.met {
  border-color: #b8decb;
  background: #f3fbf6;
}

.cc-objective.met span {
  color: #1b7a50;
}

.cc-sites-panel {
  border: 1px solid #b5d5e5;
  border-radius: 11px;
  background: #f8fcff;
  padding: 0.5rem;
  display: grid;
  gap: 0.38rem;
}

.cc-sites-panel h4 {
  margin: 0;
}

.cc-sites-grid {
  display: grid;
  gap: 0.4rem;
}

.cc-site-card {
  border: 1px solid #c5deeb;
  border-radius: 10px;
  background: #ffffff;
  padding: 0.42rem 0.48rem;
  display: grid;
  gap: 0.24rem;
}

.cc-site-card.city {
  border-left: 4px solid #0f719c;
}

.cc-site-card.resource {
  border-left: 4px solid #a86b24;
}

.cc-site-card.lost {
  background: #fff5f3;
  border-color: #e0bbb4;
}

.cc-site-card strong {
  color: #14506c;
}

.cc-site-card p {
  margin: 0;
  font-size: 0.75rem;
  color: #345e73;
}

.cc-site-health {
  height: 0.38rem;
  border-radius: 999px;
  background: #d8e8f1;
  overflow: hidden;
}

.cc-site-health span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #3db57e, #7be59d);
}

.cc-site-card.lost .cc-site-health span {
  background: linear-gradient(90deg, #d58d86, #e5b1ab);
}

.cc-site-status {
  font-size: 0.75rem;
  font-weight: 700;
  color: #284f62;
}

.cc-scenario-grid {
  display: grid;
  gap: 0.45rem;
  margin-top: 0.1rem;
}

.cc-scenario-btn {
  border: 1px solid #a3cbe0;
  border-radius: 10px;
  background: #f6fbff;
  padding: 0.48rem 0.58rem;
  text-align: left;
  cursor: pointer;
  display: grid;
  gap: 0.2rem;
}

.cc-scenario-btn strong {
  color: #0f4f6c;
  font-size: 0.89rem;
}

.cc-scenario-btn span {
  font-size: 0.75rem;
  color: #3a6479;
}

.cc-scenario-btn.active {
  border-color: #0f719c;
  background: linear-gradient(180deg, #e8f6ff, #d5ecf9);
}

.cc-scenario-box {
  border: 1px solid #afcfdf;
  border-radius: 12px;
  padding: 0.56rem;
  background: var(--cc-panel-soft);
  display: grid;
  gap: 0.42rem;
}

.cc-scenario-box p {
  margin: 0;
  color: #28556c;
  font-size: 0.84rem;
}

.cc-choice-grid {
  display: grid;
  gap: 0.36rem;
}

.cc-choice-btn {
  border: 1px solid #a8cbde;
  border-radius: 10px;
  background: #ffffff;
  padding: 0.44rem 0.5rem;
  text-align: left;
  display: grid;
  gap: 0.16rem;
  cursor: pointer;
}

.cc-choice-btn strong {
  font-size: 0.85rem;
  color: #134e6a;
}

.cc-choice-btn span {
  font-size: 0.77rem;
  color: #38657b;
}

.cc-choice-detail {
  display: block;
  font-size: 0.72rem;
  line-height: 1.3;
  margin-top: 0.08rem;
}

.cc-choice-detail.now {
  color: #1f5b78;
}

.cc-choice-detail.later {
  color: #356245;
}

.cc-choice-btn.active {
  border-color: #1979a5;
  background: linear-gradient(180deg, #eaf7ff, #d9edf8);
}

.cc-tool-grid {
  margin-top: 0.12rem;
  display: grid;
  gap: 0.38rem;
  grid-template-columns: repeat(3, minmax(100px, 1fr));
}

.cc-tool-btn {
  border: 1px solid #a3c7db;
  border-radius: 10px;
  background: #f8fcff;
  color: #164f68;
  padding: 0.46rem 0.5rem;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  text-align: left;
}

.cc-tool-btn.active {
  border-color: #0f6f98;
  background: linear-gradient(180deg, #e6f4fd, #d8ebf8);
}

.cc-tool-info {
  border: 1px solid #b5d4e2;
  border-radius: 11px;
  background: #f8fcff;
  padding: 0.5rem;
  display: grid;
  gap: 0.32rem;
}

.cc-tool-info h4 {
  margin: 0;
}

.cc-tool-info-card {
  border: 1px solid #c6dfec;
  border-radius: 10px;
  background: #ffffff;
  padding: 0.36rem 0.44rem;
}

.cc-tool-info-card strong {
  color: #14506c;
  font-size: 0.82rem;
}

.cc-tool-info-card p {
  margin: 0.2rem 0 0;
  font-size: 0.75rem;
  color: #2f5d72;
}

.cc-tool-info-card p span {
  font-weight: 700;
  color: #1d5370;
}

.cc-pill {
  border: 1px solid #9cc4d9;
  background: #edf8ff;
  color: #20586f;
  border-radius: 999px;
  font-size: 0.68rem;
  padding: 0.08rem 0.4rem;
  font-weight: 700;
}

.cc-forecast {
  border: 1px solid #afcfe0;
  border-radius: 11px;
  background: #f7fcff;
  padding: 0.52rem;
  margin-top: 0.5rem;
  display: grid;
  gap: 0.2rem;
}

.cc-forecast h4 {
  margin: 0 0 0.15rem;
}

.cc-forecast div {
  display: flex;
  justify-content: space-between;
  gap: 0.5rem;
  font-size: 0.82rem;
  color: #2e5b70;
}

.cc-forecast strong {
  color: #0f3f57;
}

.cc-event-log {
  border: 1px solid #afcfe0;
  border-radius: 11px;
  background: #f8fcff;
  margin-top: 0.5rem;
  padding: 0.48rem;
}

.cc-event-log h4 {
  margin: 0;
}

.cc-event-log ul {
  margin: 0.35rem 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.28rem;
  max-height: 130px;
  overflow: auto;
}

.cc-event-log li {
  display: grid;
  grid-template-columns: 1.3rem 1fr;
  align-items: start;
  gap: 0.28rem;
  font-size: 0.79rem;
  color: #2c566b;
}

.cc-event-log .icon {
  line-height: 1.1;
}

.cc-link-btn {
  border: 0;
  padding: 0;
  font: inherit;
  background: transparent;
  color: #146a92;
  text-decoration: underline;
  cursor: pointer;
}

.cc-divider {
  border-top: 1px solid #d5e8f3;
  margin: 0.65rem 0;
}

.cc-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.79rem;
}

.cc-table th,
.cc-table td {
  padding: 0.31rem 0.2rem;
  border-bottom: 1px solid #d4e7f2;
  text-align: left;
}

.cc-table th {
  font-size: 0.69rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: #386579;
}

.cc-switch {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  color: #f0fbff;
  font-size: 0.82rem;
  font-weight: 700;
}

.cc-switch input {
  margin: 0;
}

.cc-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(8, 32, 48, 0.56);
  display: grid;
  place-items: center;
  padding: 1rem;
  z-index: 60;
}

.cc-modal {
  width: min(520px, 94vw);
  border-radius: 14px;
  border: 1px solid #9ec3d6;
  background: #f9fdff;
  box-shadow: 0 15px 35px rgba(10, 43, 66, 0.3);
  padding: 0.85rem;
}

.cc-modal h3 {
  margin: 0;
  color: #124e6a;
}

.cc-modal p {
  margin: 0.45rem 0 0;
  color: #264f64;
}

.cc-events-modal {
  width: min(560px, 94vw);
}

.cc-events-list {
  margin-top: 0.55rem;
  display: grid;
  gap: 0.34rem;
  max-height: 260px;
  overflow-y: auto;
}

.cc-events-list p {
  margin: 0;
  border: 1px solid #c5dfed;
  border-radius: 10px;
  background: #f6fbff;
  padding: 0.4rem 0.48rem;
  display: grid;
  gap: 0.14rem;
}

.cc-events-list strong {
  color: #114d69;
  font-size: 0.84rem;
}

.cc-events-list span {
  color: #2f596f;
  font-size: 0.79rem;
}

.cc-warning-box {
  margin-top: 0.55rem;
  border: 1px solid #dcb184;
  border-radius: 10px;
  background: #fff8ef;
  padding: 0.35rem 0.5rem;
}

.cc-warning-box p {
  margin: 0.2rem 0;
  color: #8d5715;
}

.cc-debrief {
  margin: 0.3rem 0.85rem 0.85rem;
  border: 1px solid #a8cde0;
  border-radius: 14px;
  background: linear-gradient(180deg, #f9fdff, #edf7fc);
  padding: 0.72rem;
  display: grid;
  gap: 0.52rem;
}

.cc-debrief p {
  margin: 0;
  color: #2b566c;
}

.cc-loss-banner {
  border: 1px solid #d39b93;
  border-radius: 12px;
  background: linear-gradient(180deg, #fff1ef, #ffe5e0);
  padding: 0.52rem 0.62rem;
  display: flex;
  align-items: center;
  gap: 0.55rem;
  flex-wrap: wrap;
}

.cc-loss-banner strong {
  color: #9d2f23;
  font-size: 1.08rem;
  letter-spacing: 0.03em;
}

.cc-loss-banner span {
  flex: 1 1 220px;
  color: #733228;
  font-size: 0.86rem;
}

.cc-metric-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(110px, 1fr));
  gap: 0.44rem;
}

.cc-metric-grid div {
  border: 1px solid #c2deec;
  border-radius: 10px;
  background: #f6fbff;
  padding: 0.42rem;
}

.cc-metric-grid span {
  display: block;
  font-size: 0.72rem;
  color: #386177;
  text-transform: uppercase;
}

.cc-metric-grid strong {
  display: block;
  margin-top: 0.12rem;
  font-size: 1.08rem;
  color: #103a51;
}

.cc-debrief-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(170px, 1fr));
  gap: 0.32rem;
}

.cc-debrief-text {
  border: 1px solid #c3deea;
  border-radius: 10px;
  background: #f8fcff;
  padding: 0.5rem;
  display: grid;
  gap: 0.35rem;
}

.cc-toast-stack {
  position: fixed;
  top: 0.8rem;
  right: 0.8rem;
  display: grid;
  gap: 0.4rem;
  z-index: 70;
  width: min(320px, 88vw);
  pointer-events: none;
}

.cc-toast {
  border: 1px solid #9fc7dc;
  border-radius: 10px;
  background: rgba(249, 254, 255, 0.97);
  box-shadow: 0 8px 18px rgba(16, 54, 77, 0.18);
  padding: 0.45rem 0.52rem;
  animation: ccToastIn 180ms ease-out;
}

.cc-toast strong {
  color: #124f6d;
  font-size: 0.83rem;
}

.cc-toast p {
  margin: 0.2rem 0 0;
  color: #2d576d;
  font-size: 0.78rem;
}

@keyframes ccWaveSweep {
  0% {
    transform: translateX(-110%);
  }
  100% {
    transform: translateX(115%);
  }
}

@keyframes ccStormPulse {
  0% {
    filter: brightness(1.08) saturate(1.1);
  }
  100% {
    filter: brightness(1) saturate(1);
  }
}

@keyframes ccToastIn {
  0% {
    opacity: 0;
    transform: translateY(-6px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 1080px) {
  .cc-layout,
  .cc-start-grid {
    grid-template-columns: 1fr;
  }

  .cc-metrics-bar {
    grid-template-columns: repeat(3, minmax(120px, 1fr));
  }

  .cc-metric-grid {
    grid-template-columns: repeat(2, minmax(120px, 1fr));
  }

  .cc-side-panel {
    max-height: none;
    overflow: visible;
    position: static;
  }

  .cc-action-bar {
    position: static;
    margin: 0;
    border-bottom: 0;
    padding: 0;
    background: transparent;
  }
}

@media (max-width: 720px) {
  .cc-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .cc-metrics-bar {
    grid-template-columns: repeat(2, minmax(120px, 1fr));
  }

  .cc-tool-grid {
    grid-template-columns: 1fr;
  }

  .cc-debrief {
    margin: 0.25rem 0.7rem 0.7rem;
  }

  .cc-debrief-stats {
    grid-template-columns: 1fr;
  }
}

@media (prefers-reduced-motion: reduce) {
  #cc-map.cc-storm-pulse,
  .cc-map-overlay.storm::before,
  .cc-toast,
  .cc-btn,
  .cc-tool-btn,
  .cc-choice-btn {
    animation: none !important;
    transition: none !important;
  }
}
