/* Particle Cloud V17 — responsive Three.js visual with Canvas fallback. */
:root { --cloud-hue: 178; }

html, body, #root { max-width: 100%; }
body { overflow-x: clip; }

.orb-v17-shell {
  position: relative;
  isolation: isolate;
  width: min(1180px, calc(100% - 2rem));
  height: clamp(360px, 46vw, 560px);
  min-height: 360px;
  margin: 1.25rem auto 2.25rem;
  overflow: hidden;
  color: #f8f8fb;
  background:
    radial-gradient(circle at 50% 50%, hsl(var(--cloud-hue) 100% 50% / .16), transparent 34%),
    radial-gradient(circle at 28% 72%, hsl(calc(var(--cloud-hue) + 105) 100% 48% / .08), transparent 30%),
    linear-gradient(180deg, #09090c 0%, #020203 100%);
  border: 3px solid #111;
  border-radius: 3px 30px 3px 22px;
  box-shadow:
    9px 9px 0 hsl(calc(var(--cloud-hue) + 115) 100% 52%),
    -4px -4px 0 hsl(var(--cloud-hue) 100% 52%);
  contain: layout paint style;
}

.orb-v17-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: .34;
  background-image:
    linear-gradient(hsl(var(--cloud-hue) 100% 60% / .09) 1px, transparent 1px),
    linear-gradient(90deg, hsl(var(--cloud-hue) 100% 60% / .09) 1px, transparent 1px);
  background-size: 34px 34px;
  mask-image: linear-gradient(to bottom, transparent 2%, #000 22%, #000 82%, transparent 100%);
}

.orb-v17-shell::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 4;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(0,0,0,.62), transparent 14%, transparent 86%, rgba(0,0,0,.58)),
    linear-gradient(180deg, rgba(0,0,0,.34), transparent 22%, transparent 76%, rgba(0,0,0,.55));
  box-shadow:
    inset 0 0 90px #000,
    inset 0 0 26px hsl(var(--cloud-hue) 100% 55% / .11);
}

.orb-v17-canvas {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: block;
  width: 100%;
  height: 100%;
  opacity: 0;
  touch-action: pan-y pinch-zoom;
  cursor: grab;
  outline: none;
  transition: opacity .35s ease;
}

.cloud-ready .orb-v17-canvas { opacity: 1; }
.cloud-dragging .orb-v17-canvas { cursor: grabbing; }
.orb-v17-canvas:focus-visible { box-shadow: inset 0 0 0 3px #fff; }

.orb-v17-topline,
.orb-v17-caption {
  position: absolute;
  z-index: 6;
  left: 1rem;
  right: 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  pointer-events: none;
  font-family: "JetBrains Mono", "Cascadia Code", ui-monospace, monospace;
  text-transform: uppercase;
}

.orb-v17-topline { top: .9rem; }
.orb-v17-caption { bottom: .9rem; align-items: flex-end; }

.orb-v17-kicker,
.orb-v17-mode,
.orb-v17-status {
  display: inline-flex;
  align-items: center;
  min-width: 0;
  padding: .42rem .62rem;
  border: 2px solid #050506;
  font-size: .66rem;
  font-weight: 950;
  letter-spacing: .08em;
}

.orb-v17-kicker {
  color: #050506;
  background: hsl(var(--cloud-hue) 100% 55%);
  box-shadow: 3px 3px 0 hsl(calc(var(--cloud-hue) + 115) 100% 52%);
}

.orb-v17-meta {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: .45rem;
  min-width: 0;
}

.orb-v17-status {
  color: hsl(var(--cloud-hue) 100% 72%);
  background: rgba(5, 5, 7, .86);
  border-color: hsl(var(--cloud-hue) 100% 55% / .78);
  font-size: .56rem;
  white-space: nowrap;
}

.orb-v17-mode {
  max-width: 50%;
  color: #fff;
  background: #09090c;
  border-color: hsl(var(--cloud-hue) 100% 55%);
  text-align: right;
}

.orb-v17-title {
  max-width: 72%;
  color: #fff;
  text-shadow: 2px 2px 0 #000, 0 0 22px hsl(var(--cloud-hue) 100% 55% / .45);
  font-size: clamp(.85rem, 2vw, 1.2rem);
  font-weight: 950;
  letter-spacing: .04em;
}

.orb-v17-hint {
  color: hsl(var(--cloud-hue) 100% 72%);
  font-size: .62rem;
  font-weight: 800;
  letter-spacing: .06em;
  text-align: right;
}

.cloud-fallback .orb-v17-status::before {
  content: "";
  width: .45rem;
  height: .45rem;
  margin-right: .35rem;
  border-radius: 999px;
  background: #f7ff00;
  box-shadow: 0 0 12px #f7ff00;
}

.cloud-unavailable .orb-v17-canvas { display: none; }
.orb-v17-noscript { color: #fff; padding: 4rem 1rem; text-align: center; }

@media (max-width: 1023.98px) {
  html, body { overflow-x: clip !important; }
  #root, #root main, #root section { min-width: 0; }
  #root :is(.grid,.flex) > * { min-width: 0; }
  #root :is(p,li,td,th,code,pre,span,strong,small) { overflow-wrap: anywhere; }
  #root canvas, #root svg, #root img { max-width: 100%; }

  .orb-v17-shell {
    width: min(calc(100% - 1rem), 46rem);
    max-width: calc(100vw - 1rem);
    height: clamp(320px, 88vw, 450px);
    min-height: 320px;
    margin-top: 1rem;
    border-radius: 3px 22px 3px 17px;
    box-shadow:
      6px 6px 0 hsl(calc(var(--cloud-hue) + 115) 100% 52%),
      -3px -3px 0 hsl(var(--cloud-hue) 100% 52%);
  }

  .orb-v17-topline,
  .orb-v17-caption { left: .7rem; right: .7rem; }
  .orb-v17-topline { top: .7rem; }
  .orb-v17-caption { bottom: .7rem; }
  .orb-v17-kicker,
  .orb-v17-mode,
  .orb-v17-status { padding: .34rem .48rem; font-size: .53rem; }
  .orb-v17-title { max-width: 64%; font-size: .75rem; }
  .orb-v17-hint { max-width: 35%; font-size: .52rem; }
}

@media (max-width: 560px) {
  .orb-v17-status { display: none; }
}

@media (max-width: 430px) {
  .orb-v17-shell {
    width: calc(100% - .55rem);
    max-width: calc(100vw - .55rem);
    height: clamp(300px, 98vw, 405px);
    min-height: 300px;
    margin-left: .15rem;
    margin-right: .4rem;
  }
  .orb-v17-mode { display: none; }
  .orb-v17-title { max-width: 66%; }
}

@media (prefers-reduced-motion: reduce) {
  .orb-v17-canvas { transition: none; }
}
