/* Kriskoll marketing site
 *
 * Aesthetic: civilförsvar operations × Nordic editorial.
 * Hero is a full-bleed dark band with a faint Sweden map overlay
 * and an iPhone mockup showing a static recreation of the app's
 * home screen. Below the fold respects light/dark via media query.
 *
 * No build step. No web fonts. CSS-only motion.
 */

:root {
  /* Surfaces and ink */
  --bg: #f1f4f7;
  --surface: #ffffff;
  --surface-deep: #0F2545;
  --surface-deeper: #070d18;
  --on-deep: #f5f7fb;
  --ink: #0b1320;
  --ink-muted: #4b5868;
  --ink-faint: #8893a3;
  --rule: #d3dbe3;
  --rule-strong: #b9c3cf;

  /* Brand and accent */
  --brand: #0d3b66;
  --accent: #ffcc00;
  --live: #16a34a;

  /* Severity (matches lib/theme.ts SEV_HUES.light) */
  --sev-info: #0d3b66;
  --sev-advisory: #a05a00;
  --sev-warning: #b94a07;
  --sev-severe: #b21f1f;
  --sev-extreme: #7f1d1d;

  /* Typography */
  --font-body: -apple-system, BlinkMacSystemFont, system-ui, "Segoe UI", Roboto, sans-serif;
  --font-mono: ui-monospace, "SF Mono", "Menlo", "Consolas", monospace;

  /* Layout */
  --content-max: 760px;
  --hero-max: 1200px;
  --pad-x: 24px;

  /* Elevation */
  --shadow-sm: 0 1px 2px rgba(11, 19, 32, 0.04), 0 1px 3px rgba(11, 19, 32, 0.05);
  --shadow-md: 0 4px 12px rgba(11, 19, 32, 0.06), 0 12px 32px rgba(11, 19, 32, 0.08);
  --shadow-lg: 0 8px 24px rgba(11, 19, 32, 0.08), 0 24px 64px rgba(11, 19, 32, 0.10);
}

@media (prefers-color-scheme: dark) {
  :root {
    --bg: #0a0f17;
    --surface: #131c2a;
    --surface-deep: #0F2545;
    --surface-deeper: #050810;
    --on-deep: #f5f7fb;
    --ink: #e6edf6;
    --ink-muted: #9ba8bc;
    --ink-faint: #5e6a7d;
    --rule: #222d3f;
    --rule-strong: #2e3b52;

    --brand: #5b9cdc;
    --accent: #ffd633;
    --live: #4ade80;

    --sev-info: #7fb3e6;
    --sev-advisory: #f5b53d;
    --sev-warning: #fb923c;
    --sev-severe: #f87171;
    --sev-extreme: #fca5a5;

    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3), 0 1px 3px rgba(0, 0, 0, 0.4);
    --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.4), 0 12px 32px rgba(0, 0, 0, 0.5);
    --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.5), 0 24px 64px rgba(0, 0, 0, 0.6);
  }
}

* { box-sizing: border-box; }

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a {
  color: var(--ink);
  text-decoration: underline;
  text-decoration-color: color-mix(in oklab, var(--brand) 60%, transparent);
  text-decoration-thickness: 1.5px;
  text-underline-offset: 3px;
  transition: text-decoration-color 150ms ease;
}

a:hover { text-decoration-color: var(--brand); }
a:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 3px;
  border-radius: 2px;
}

img, svg {
  display: block;
  max-width: 100%;
}

h1, h2, h3 {
  margin: 0;
  letter-spacing: -0.02em;
  line-height: 1.08;
  font-weight: 700;
  text-wrap: balance;
}

p { margin: 0; }

ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

/* -- Eyebrow labels -------------------------------------------------------- */

.eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 1.6px;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: 24px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.eyebrow--accent::before {
  content: "";
  display: inline-block;
  width: 18px;
  height: 1px;
  background: currentColor;
}

.eyebrow--on-deep {
  color: color-mix(in oklab, var(--on-deep) 75%, transparent);
}

.eyebrow__shield {
  width: 14px;
  height: 14px;
  display: inline-block;
  vertical-align: middle;
}

/* -- Hero band (full-bleed dark) ------------------------------------------ */

.hero-band {
  position: relative;
  isolation: isolate;
  background:
    radial-gradient(ellipse 80% 60% at 30% 30%,
      color-mix(in oklab, #1a3b6a 60%, transparent),
      transparent 70%),
    linear-gradient(180deg, #14233b 0%, #101a2c 100%);
  color: var(--on-deep);
  overflow: hidden;
  padding-bottom: 112px;
  /* Uneven separator: left sits 90px higher than right, with a 40° slant
     shifted 80px right of centre. For a 90px rise at 40°, run is
     90/tan(40°) ≈ 107px (half-run ≈ 54px). */
  clip-path: polygon(
    0 0,
    100% 0,
    100% 100%,
    calc(50% + 204px) 100%,
    calc(50% + 96px) calc(100% - 90px),
    0 calc(100% - 90px)
  );
}

@media (min-width: 880px) {
  .hero-band { padding-bottom: 144px; }
}

.hero-sources {
  max-width: var(--hero-max);
  margin: -76px auto 0;
  padding: 0 var(--pad-x);
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 18px;
  min-height: 56px;
  pointer-events: none;
}

.hero-sources__label {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 1.6px;
  text-transform: uppercase;
  color: var(--ink-faint);
  flex-shrink: 0;
}

.hero-sources__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}

.hero-sources__list li { display: inline-flex; align-items: center; }

.hero-sources__list img {
  height: 32px;
  width: auto;
  max-width: 150px;
  opacity: 0.78;
  filter: saturate(0.55);
  transition: opacity 200ms ease, filter 200ms ease;
}

.hero-sources:hover .hero-sources__list img,
.hero-sources:focus-within .hero-sources__list img {
  opacity: 1;
  filter: saturate(1);
}

@media (max-width: 879px) {
  .hero-sources {
    margin-top: -56px;
    margin-bottom: 8px;
    align-items: center;
    justify-content: flex-start;
    gap: 10px;
    min-height: 0;
  }
  .hero-sources__label { display: none; }
  .hero-sources__list {
    justify-content: flex-start;
    gap: 14px;
    flex-wrap: nowrap;
  }
  .hero-sources__list img { height: 24px; max-width: 100px; }
}

.hero-band__map {
  position: absolute;
  inset: 0;
  background:
    /* Horizontal fade from dark on the left to map showing through on the right */
    linear-gradient(90deg,
      rgba(7, 13, 24, 0.95) 0%,
      rgba(7, 13, 24, 0.7) 25%,
      rgba(7, 13, 24, 0.3) 55%,
      transparent 85%),
    /* Stockholm street grid, slightly desaturated to read as backdrop */
    url('/map.jpg') no-repeat right center / cover;
  pointer-events: none;
  z-index: 0;
  opacity: 0.25;
  filter: saturate(0.3);
}

@media (max-width: 880px) {
  .hero-band__map {
    background:
      linear-gradient(90deg,
        rgba(7, 13, 24, 0.95) 0%,
        rgba(7, 13, 24, 0.7) 35%,
        rgba(7, 13, 24, 0.3) 65%,
        transparent 95%),
      url('/map.jpg') no-repeat 70% center / cover;
    opacity: 0.18;
  }
}

.hero-band > .topbar,
.hero-band > .hero { position: relative; z-index: 1; }

/* -- Topbar ---------------------------------------------------------------- */

.topbar {
  max-width: var(--hero-max);
  margin: 0 auto;
  padding: 28px var(--pad-x) 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.topbar--dark { color: var(--on-deep); }

.lockup {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  text-decoration: none;
  color: inherit;
  font-weight: 700;
}

.lockup:hover { text-decoration: none; }

.lockup__shield {
  width: 40px;
  height: 40px;
  display: inline-block;
  filter: drop-shadow(0 1px 0 rgba(0, 0, 0, 0.3));
}

.lockup__name {
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.01em;
}

.topbar__live {
  display: none;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 1.6px;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--on-deep) 70%, transparent);
}

@media (min-width: 720px) {
  .topbar__live { display: inline-flex; }
}

/* -- Status dots ----------------------------------------------------------- */

.dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--ink-faint);
  flex-shrink: 0;
  position: relative;
}

.dot--live { background: var(--live); }
.dot--live::after {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: 50%;
  background: var(--live);
  opacity: 0.5;
  animation: live-pulse 2.4s ease-out infinite;
}

@keyframes live-pulse {
  0%   { transform: scale(1);   opacity: 0.5; }
  70%  { transform: scale(2.6); opacity: 0;   }
  100% { transform: scale(2.6); opacity: 0;   }
}

.dot--ok { background: var(--live); }
.dot--info { background: var(--sev-info); }
.dot--advisory { background: var(--sev-advisory); }
.dot--warning { background: var(--sev-warning); }
.dot--severe { background: var(--sev-severe); }
.dot--extreme { background: var(--sev-extreme); }

@media (prefers-reduced-motion: reduce) {
  .dot--live::after { animation: none; }
}

/* -- Hero ------------------------------------------------------------------ */

.hero {
  max-width: var(--hero-max);
  margin: 0 auto;
  padding: 28px var(--pad-x) 40px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
  align-items: center;
}

@media (max-width: 879px) {
  .hero { gap: 24px; }
  .hero__copy { display: contents; }
  .hero__copy > .eyebrow { order: 1; margin-left: auto; margin-right: auto; }
  .hero__copy > h1 { order: 2; margin-left: auto; margin-right: auto; }
  .hero__phone-wrap { order: 3; }
  .hero__copy > .hero__sub { order: 4; margin-bottom: 0; margin-left: auto; margin-right: auto; }
  .hero__copy > .hero__badges { order: 5; justify-content: center; }
}

@media (min-width: 880px) {
  .hero {
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
    gap: 56px;
    padding-top: 36px;
    padding-bottom: 56px;
  }
}

.hero__copy > * {
  animation: hero-rise 700ms cubic-bezier(0.2, 0.6, 0.2, 1) both;
}
.hero__copy > *:nth-child(1) { animation-delay: 60ms; }
.hero__copy > *:nth-child(2) { animation-delay: 140ms; }
.hero__copy > *:nth-child(3) { animation-delay: 220ms; }
.hero__copy > *:nth-child(4) { animation-delay: 320ms; }

.hero__phone-wrap {
  animation: hero-rise 900ms cubic-bezier(0.2, 0.6, 0.2, 1) 240ms both;
  display: flex;
  justify-content: center;
  perspective: 1600px;
  perspective-origin: 50% 40%;
}

@keyframes hero-rise {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
  .hero__copy > *,
  .hero__phone-wrap { animation: none; }
}

.hero h1 {
  font-size: clamp(40px, 7vw, 80px);
  letter-spacing: -0.04em;
  line-height: 1.0;
  margin-bottom: 28px;
  max-width: 14ch;
  color: var(--on-deep);
}

.hero__sub {
  font-size: clamp(17px, 1.5vw, 19px);
  line-height: 1.55;
  color: color-mix(in oklab, var(--on-deep) 78%, transparent);
  margin-bottom: 36px;
  max-width: 50ch;
}

.hero__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.badge {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  border-radius: 10px;
  transition: transform 200ms cubic-bezier(0.2, 0.6, 0.2, 1),
              filter 200ms ease;
}

.badge:hover { text-decoration: none; }

.badge:hover img {
  transform: translateY(-2px);
  filter: drop-shadow(0 6px 14px rgba(0, 0, 0, 0.35));
}

.badge:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 4px;
}

.badge img {
  height: 56px;
  width: auto;
  max-width: 100%;
  transition: transform 200ms cubic-bezier(0.2, 0.6, 0.2, 1),
              filter 200ms ease;
}

/* -- iPhone mockup --------------------------------------------------------- */

.phone {
  position: relative;
  width: 280px;
  aspect-ratio: 9 / 18;
  background:
    linear-gradient(135deg, #2a2a2e 0%, #16161a 50%, #2a2a2e 100%);
  border-radius: 44px;
  padding: 12px;
  transform: rotateY(-18deg) rotateX(8deg) rotateZ(-2deg);
  transform-style: preserve-3d;
  transition: transform 600ms cubic-bezier(0.2, 0.6, 0.2, 1);
  box-shadow:
    inset 0 0 0 1.5px rgba(255, 255, 255, 0.10),
    inset 0 0 0 3px rgba(0, 0, 0, 0.5),
    -30px 40px 60px -20px rgba(0, 0, 0, 0.55),
    -60px 80px 140px -40px rgba(0, 0, 0, 0.55),
    0 30px 80px -16px rgba(0, 0, 0, 0.5);
}

.phone:hover {
  transform: rotateY(0deg) rotateX(0deg) rotateZ(0deg);
}

@media (prefers-reduced-motion: reduce) {
  .phone, .phone:hover { transform: none; transition: none; }
}

@media (max-width: 720px) {
  .phone { transform: rotateY(-10deg) rotateX(5deg) rotateZ(-1deg); }
}

@media (min-width: 540px) {
  .phone { width: 300px; }
}

@media (min-width: 880px) {
  .phone { width: 320px; }
}

.phone__island {
  position: absolute;
  top: 24px;
  left: 50%;
  transform: translateX(-50%);
  width: 92px;
  height: 30px;
  background: #000;
  border-radius: 20px;
  z-index: 3;
}

.phone__btn {
  position: absolute;
  background: linear-gradient(90deg, #1a1a1d, #2a2a2e, #1a1a1d);
  z-index: 0;
}

.phone__btn--mute     { left: -2px; top: 100px; width: 3px; height: 26px; border-radius: 2px 0 0 2px; }
.phone__btn--vol-up   { left: -2px; top: 138px; width: 3px; height: 50px; border-radius: 2px 0 0 2px; }
.phone__btn--vol-down { left: -2px; top: 200px; width: 3px; height: 50px; border-radius: 2px 0 0 2px; }
.phone__btn--power    { right: -2px; top: 154px; width: 3px; height: 80px; border-radius: 0 2px 2px 0; }

.phone__screen {
  width: 100%;
  height: 100%;
  background: #ffffff;
  border-radius: 32px;
  overflow: hidden;
  position: relative;
  isolation: isolate;
  /* Soft fade at the bottom hints there's more app below the visible window
     once the screen is shorter than the full app would render. */
  -webkit-mask-image: linear-gradient(180deg, #000 calc(100% - 40px), rgba(0,0,0,0.85) 100%);
          mask-image: linear-gradient(180deg, #000 calc(100% - 40px), rgba(0,0,0,0.85) 100%);
}

/* -- Mock app screen ------------------------------------------------------- */

.mock {
  --m-bg: #f1f4f7;
  --m-surface: #ffffff;
  --m-ink: #0b1320;
  --m-ink-muted: #4b5868;
  --m-ink-faint: #8893a3;
  --m-rule: #d3dbe3;
  --m-brand: #0d3b66;
  --m-accent: #ffcc00;

  width: 100%;
  height: 100%;
  background: var(--m-bg);
  color: var(--m-ink);
  font-family: var(--font-body);
  font-size: 13px;
  line-height: 1.4;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}

.mock__bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px 28px 6px;
  font-weight: 600;
  font-size: 14px;
  color: var(--m-ink);
  flex-shrink: 0;
}

.mock__time {
  font-feature-settings: "tnum";
  letter-spacing: -0.01em;
}

.mock__indicators {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--m-ink);
}

.mock__net {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.4px;
}

.mock__masthead {
  padding: 18px 18px 16px;
  flex-shrink: 0;
}

.mock__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 1.6px;
  color: var(--m-ink-muted);
  margin-bottom: 6px;
}

.mock__brand-shield {
  width: 12px;
  height: 12px;
  display: inline-block;
  vertical-align: middle;
}

.mock__title {
  font-size: 24px;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin: 0 0 4px;
  color: var(--m-ink);
}

.mock__place {
  font-size: 12px;
  color: var(--m-ink-muted);
  margin: 0;
}

.mock__banner {
  margin: 0 18px 14px;
  padding: 14px 16px;
  border-radius: 12px;
  background: #fbe8c8;
  border: 1px solid color-mix(in oklab, #a05a00 30%, transparent);
}

.mock__banner-eyebrow {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: #a05a00;
  margin: 0 0 4px;
}

.mock__banner-title {
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--m-ink);
  margin: 0 0 3px;
}

.mock__banner-meta {
  font-size: 11.5px;
  color: var(--m-ink-muted);
  margin: 0;
}

.mock__block { padding: 0 18px 14px; }

.mock__block-eyebrow {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 1.6px;
  text-transform: uppercase;
  color: var(--m-ink-muted);
  margin: 0 0 10px;
}

.mock__sources {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 6px;
  background: var(--m-surface);
  border: 1px solid var(--m-rule);
  border-radius: 10px;
  padding: 10px 6px;
}

.mock__src {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.8px;
  color: var(--m-ink-muted);
}

.mock__src .dot {
  width: 6px;
  height: 6px;
}

.mock__event {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--m-rule);
}

.mock__event:last-child { border-bottom: 0; }

.mock__event-sev {
  flex-shrink: 0;
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  padding: 4px 7px;
  border-radius: 4px;
  background: color-mix(in oklab, var(--m-ink) 6%, transparent);
  color: var(--m-ink-muted);
  margin-top: 2px;
}

.mock__event-sev--advisory {
  background: #fbe8c8;
  color: #a05a00;
}

.mock__event-sev--info {
  background: #dce7f3;
  color: #0d3b66;
}

.mock__event-text { flex: 1; min-width: 0; }

.mock__event h4 {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: 0 0 2px;
  color: var(--m-ink);
}

.mock__event p {
  font-size: 11px;
  color: var(--m-ink-muted);
  margin: 0;
}

.mock__radio {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.mock__viewport {
  flex: 1;
  min-height: 0;
  overflow: hidden;
  position: relative;
}

.mock__view {
  position: absolute;
  inset: 0;
  overflow-y: auto;
  display: none;
  padding-bottom: 4px;
  scrollbar-width: none;
}
.mock__view::-webkit-scrollbar { display: none; }

.mock:has(#mock-tab-hem:checked) .mock__view--hem,
.mock:has(#mock-tab-karta:checked) .mock__view--karta,
.mock:has(#mock-tab-skyddsrum:checked) .mock__view--skyddsrum,
.mock:has(#mock-tab-beredskap:checked) .mock__view--beredskap {
  display: block;
}

/* Defcon mode replaces the Hem view with the ops dashboard. */
.mock:has(#mock-tab-hem:checked):has(#mock-defcon:checked) .mock__view--hem {
  display: none;
}
.mock:has(#mock-tab-hem:checked):has(#mock-defcon:checked) .mock__view--defcon {
  display: block;
}

.mock__tabs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background: var(--m-surface);
  border-top: 1px solid var(--m-rule);
  padding: 8px 0 18px;
  flex-shrink: 0;
}

.mock__tab {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  font-size: 9.5px;
  font-weight: 600;
  color: var(--m-ink-faint);
  cursor: pointer;
  user-select: none;
  padding-top: 4px;
}

.mock__tab svg { display: block; }
.mock__tab .mock__tab-active { display: none; }
.mock__tab .mock__tab-inactive { display: block; }

.mock:has(#mock-tab-hem:checked) .mock__tab[for="mock-tab-hem"],
.mock:has(#mock-tab-karta:checked) .mock__tab[for="mock-tab-karta"],
.mock:has(#mock-tab-skyddsrum:checked) .mock__tab[for="mock-tab-skyddsrum"],
.mock:has(#mock-tab-beredskap:checked) .mock__tab[for="mock-tab-beredskap"] {
  color: var(--m-brand);
}

.mock:has(#mock-tab-hem:checked) .mock__tab[for="mock-tab-hem"] .mock__tab-inactive,
.mock:has(#mock-tab-karta:checked) .mock__tab[for="mock-tab-karta"] .mock__tab-inactive,
.mock:has(#mock-tab-skyddsrum:checked) .mock__tab[for="mock-tab-skyddsrum"] .mock__tab-inactive,
.mock:has(#mock-tab-beredskap:checked) .mock__tab[for="mock-tab-beredskap"] .mock__tab-inactive {
  display: none;
}

.mock:has(#mock-tab-hem:checked) .mock__tab[for="mock-tab-hem"] .mock__tab-active,
.mock:has(#mock-tab-karta:checked) .mock__tab[for="mock-tab-karta"] .mock__tab-active,
.mock:has(#mock-tab-skyddsrum:checked) .mock__tab[for="mock-tab-skyddsrum"] .mock__tab-active,
.mock:has(#mock-tab-beredskap:checked) .mock__tab[for="mock-tab-beredskap"] .mock__tab-active {
  display: block;
}

.mock:has(#mock-tab-hem:checked) .mock__tab[for="mock-tab-hem"]::before,
.mock:has(#mock-tab-karta:checked) .mock__tab[for="mock-tab-karta"]::before,
.mock:has(#mock-tab-skyddsrum:checked) .mock__tab[for="mock-tab-skyddsrum"]::before,
.mock:has(#mock-tab-beredskap:checked) .mock__tab[for="mock-tab-beredskap"]::before {
  content: "";
  position: absolute;
  top: -2px;
  width: 28px;
  height: 3px;
  border-radius: 2px;
  background: var(--m-brand);
}

/* Karta view */
.mock__filters {
  display: flex;
  gap: 6px;
  padding: 0 18px 12px;
  flex-wrap: wrap;
}
.mock__filter {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 5px 9px;
  border-radius: 999px;
  background: var(--m-surface);
  border: 1px solid var(--m-rule);
  color: var(--m-ink-muted);
}
.mock__filter--active {
  background: var(--m-brand);
  color: #fff;
  border-color: var(--m-brand);
}

.mock__map {
  position: relative;
  margin: 0 18px 12px;
  padding: 8px;
  background: #e3eaf1;
  border: 1px solid var(--m-rule);
  border-radius: 12px;
  aspect-ratio: 2 / 3;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mock__map-img {
  display: block;
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: 100%;
  object-fit: contain;
}
.mock__map-pins {
  position: absolute;
  inset: 8px;
  width: calc(100% - 16px);
  height: calc(100% - 16px);
  pointer-events: none;
}
.mock__map-pin--advisory { fill: #a05a00; }
.mock__map-pin--warning  { fill: #b94a07; }
.mock__map-pin--info     { fill: #0d3b66; }
.mock__map-here {
  fill: #0d3b66;
  stroke: #fff;
  stroke-width: 2;
}
.mock__map-here-ring {
  fill: none;
  stroke: #0d3b66;
  stroke-width: 1.2;
  opacity: 0.45;
}

.mock__legend {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  padding: 0 18px 12px;
}
.mock__legend-item {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.6px;
  color: var(--m-ink-muted);
}
.mock__legend-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
}
.mock__legend-dot--advisory { background: #a05a00; }
.mock__legend-dot--warning  { background: #b94a07; }
.mock__legend-dot--info     { background: #0d3b66; }
.mock__legend-dot--here {
  background: #0d3b66;
  box-shadow: 0 0 0 2px #fff, 0 0 0 3px rgba(13,59,102,0.45);
}

/* Skyddsrum view */
.mock__notice {
  margin: 0 18px 12px;
  padding: 10px 12px;
  background: #f6ecd9;
  border: 1px solid color-mix(in oklab, #a05a00 25%, transparent);
  border-radius: 10px;
  font-size: 11px;
  color: #6a3a00;
  line-height: 1.4;
}

.mock__shelters {
  padding: 0 18px 14px;
}
.mock__shelter {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid var(--m-rule);
}
.mock__shelter:last-child { border-bottom: 0; }
.mock__shelter-icon {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: var(--m-brand);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.mock__shelter-text { flex: 1; min-width: 0; }
.mock__shelter h4 {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: 0 0 2px;
  color: var(--m-ink);
}
.mock__shelter p {
  font-size: 11px;
  color: var(--m-ink-muted);
  margin: 0;
}
.mock__shelter-dist {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  color: var(--m-ink);
  letter-spacing: -0.01em;
  flex-shrink: 0;
}

/* Beredskap view */
.mock__progress {
  margin: 0 18px 14px;
  padding: 14px 16px;
  background: var(--m-surface);
  border: 1px solid var(--m-rule);
  border-radius: 12px;
}
.mock__progress-row {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 12px;
  gap: 12px;
}
.mock__progress-left { min-width: 0; }
.mock__progress-eyebrow {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: var(--m-ink-muted);
  margin: 0 0 2px;
}
.mock__progress-count {
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--m-ink);
  margin: 0;
  line-height: 1;
}
.mock__progress-total {
  font-size: 14px;
  font-weight: 600;
  color: var(--m-ink-faint);
  letter-spacing: -0.01em;
}
.mock__progress-pct {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 700;
  color: var(--m-brand);
  margin: 0;
  line-height: 1;
}
.mock__progress-bar {
  height: 6px;
  background: var(--m-bg);
  border-radius: 999px;
  overflow: hidden;
}
.mock__progress-bar span {
  display: block;
  height: 100%;
  background: var(--m-brand);
  border-radius: 999px;
}

.mock__check {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 0;
  border-bottom: 1px solid var(--m-rule);
  font-size: 12.5px;
  color: var(--m-ink);
}
.mock__check:last-child { border-bottom: 0; }
.mock__box {
  width: 18px;
  height: 18px;
  border-radius: 5px;
  border: 1.5px solid var(--m-rule);
  background: var(--m-surface);
  flex-shrink: 0;
  position: relative;
}
.mock__check--done .mock__box {
  background: var(--m-brand);
  border-color: var(--m-brand);
}
.mock__check--done .mock__box::after {
  content: "";
  position: absolute;
  left: 5px;
  top: 2px;
  width: 5px;
  height: 9px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
.mock__check--done {
  color: var(--m-ink-muted);
}

/* -- Layout primitives (below the fold) ------------------------------------ */

main > section {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 88px var(--pad-x);
  border-top: 1px solid var(--rule);
  position: relative;
}

main > section:first-child { border-top: 0; }

@media (min-width: 720px) {
  main > section { padding: 128px var(--pad-x); }
}

main > section.trust {
  padding-top: 64px;
  padding-bottom: 64px;
  border-top: 0;
}

@media (min-width: 720px) {
  main > section.trust {
    padding-top: 96px;
    padding-bottom: 96px;
  }
}

/* -- Features -------------------------------------------------------------- */

.feature-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
}

@media (min-width: 720px) {
  .feature-list {
    grid-template-columns: 1fr 1fr;
    gap: 72px 80px;
  }
  .feature__viz {
    height: 180px;
  }
}

.feature {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.feature__viz {
  display: flex;
  align-items: flex-end;
  color: var(--ink);
}

.feature__viz > svg {
  width: 100%;
  height: auto;
  max-width: 180px;
}

.feature__viz--map {
  align-items: center;
  color: var(--brand);
}
.feature__map-wrap {
  position: relative;
  height: 88px;
  aspect-ratio: 1024 / 1536;
  display: inline-block;
}

@media (min-width: 720px) {
  .feature__map-wrap {
    height: 180px;
  }
}
.feature__map {
  display: block;
  width: 100%;
  height: 100%;
  background: currentColor;
  -webkit-mask: url('/sverige.svg') no-repeat center / contain;
          mask: url('/sverige.svg') no-repeat center / contain;
}
.feature__pin {
  position: absolute;
  width: 3px;
  height: 3px;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  box-shadow: 0 0 0 1px color-mix(in oklab, var(--bg) 70%, transparent);
}

@media (min-width: 720px) {
  .feature__pin {
    width: 5px;
    height: 5px;
    box-shadow: 0 0 0 1.5px color-mix(in oklab, var(--bg) 70%, transparent);
  }
}
.feature__pin--info { background: var(--sev-info); }
.feature__pin--advisory { background: var(--sev-advisory); }
.feature__pin--warning { background: var(--sev-warning); }
.feature__pin--severe { background: var(--sev-severe); }

.feature h2 {
  font-size: clamp(22px, 2vw, 26px);
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin: 0;
}

.feature p {
  color: var(--ink-muted);
  font-size: 16.5px;
  line-height: 1.55;
  max-width: 38ch;
}

/* -- Sources data feed ---------------------------------------------------- */

.sources__intro {
  color: var(--ink-muted);
  margin-bottom: 32px;
  max-width: 56ch;
}

.sources-feed {
  font-family: var(--font-mono);
  font-size: 13.5px;
  border-top: 1px solid var(--rule);
}

.src-row {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: baseline;
  gap: 16px;
  padding: 18px 4px;
  border-bottom: 1px solid var(--rule);
}

.src-row .dot { align-self: center; }

.src-row__name {
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: -0.005em;
}

.src-row__interval {
  font-variant-numeric: tabular-nums;
  color: var(--ink-muted);
}

.src-row__tag {
  color: var(--ink-faint);
  font-size: 10.5px;
  letter-spacing: 1.6px;
  text-transform: uppercase;
  display: none;
}

@media (min-width: 560px) {
  .src-row__tag { display: inline; }
}

/* -- Screenshots ----------------------------------------------------------- */

.screenshots__grid {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: 80%;
  gap: 16px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-padding: var(--pad-x);
  padding: 0 var(--pad-x) 8px;
  margin: 0 calc(var(--pad-x) * -1);
  scrollbar-width: none;
}
.screenshots__grid::-webkit-scrollbar { display: none; }
.screenshots__grid > figure { scroll-snap-align: center; }

.screenshots__dots {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-top: 18px;
}
.screenshots__dots a {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--rule);
  transition: background 200ms ease, transform 200ms ease;
}
.screenshots__dots a:hover,
.screenshots__dots a:focus-visible {
  background: var(--ink-faint);
  transform: scale(1.15);
}
.screenshots__dots a.is-active {
  background: var(--brand);
  transform: scale(1.25);
}

@media (min-width: 560px) {
  .screenshots__grid {
    grid-auto-columns: 60%;
    gap: 24px;
  }
}

@media (min-width: 960px) {
  .screenshots__grid {
    display: grid;
    grid-auto-flow: row;
    grid-template-columns: repeat(4, 1fr);
    grid-auto-columns: auto;
    gap: 32px 24px;
    overflow: visible;
    scroll-snap-type: none;
    padding: 0;
    margin: 0;
  }
  .screenshots__dots { display: none; }
}

.screenshots figure {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.screenshots figure img {
  width: 100%;
  height: auto;
  aspect-ratio: 1179 / 2556;
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: 28px;
  box-shadow: var(--shadow-md);
}

.screenshots figcaption {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 1.6px;
  text-transform: uppercase;
  color: var(--ink-muted);
  text-align: center;
}

/* -- Trust statements ----------------------------------------------------- */

.trust__panel {
  background:
    linear-gradient(135deg,
      color-mix(in oklab, var(--surface-deep) 92%, white),
      var(--surface-deep) 55%,
      var(--surface-deeper));
  color: var(--on-deep);
  border-radius: 24px;
  padding: 56px 32px;
  box-shadow: var(--shadow-lg);
  position: relative;
  overflow: hidden;
}

@media (min-width: 720px) {
  .trust__panel { padding: 80px 64px; }
}

.trust__panel .eyebrow {
  color: color-mix(in oklab, var(--on-deep) 65%, transparent);
  margin-bottom: 28px;
}

.trust__line {
  font-size: clamp(34px, 6vw, 60px);
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1.02;
  margin: 0;
  color: var(--on-deep);
}

.trust__line + .trust__line { margin-top: 4px; }

.trust__line:nth-of-type(2) {
  color: color-mix(in oklab, var(--on-deep) 80%, transparent);
}

.trust__line:nth-of-type(3) {
  color: color-mix(in oklab, var(--on-deep) 65%, transparent);
}

.trust__note {
  margin-top: 36px;
  color: color-mix(in oklab, var(--on-deep) 78%, transparent);
  max-width: 56ch;
  font-size: 15.5px;
}

/* -- Official disclaimer --------------------------------------------------- */

.official p {
  color: var(--ink-muted);
  max-width: 56ch;
  font-size: 16.5px;
  line-height: 1.6;
}

/* -- Footer ---------------------------------------------------------------- */

.footer {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 56px var(--pad-x) 80px;
  border-top: 1px solid var(--rule);
  color: var(--ink-muted);
  font-size: 14px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

@media (min-width: 720px) {
  .footer {
    grid-template-columns: 1fr auto;
    align-items: end;
    gap: 24px;
  }
  .footer__attrib {
    grid-column: 1 / -1;
    margin-top: 12px;
    border-top: 1px solid var(--rule);
    padding-top: 18px;
    color: var(--ink-faint);
    font-family: var(--font-mono);
    font-size: 11.5px;
    letter-spacing: 0.4px;
  }
}

.footer__copy {
  font-family: var(--font-mono);
  letter-spacing: 0.6px;
  font-size: 12px;
  text-transform: uppercase;
  color: var(--ink-muted);
}

.footer__links {
  display: flex;
  gap: 10px;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 1.4px;
  text-transform: uppercase;
}

.footer a { color: var(--ink-muted); }
.footer__placeholder { color: var(--ink-faint); }

/* -- Defcon (ops) mode in the iPhone mock -------------------------------- */

.mock {
  --ops-bg: #040608;
  --ops-bg-grid: #0a0f14;
  --ops-panel: #0b1117;
  --ops-panel-elev: #0f161e;
  --ops-rule: #1a2330;
  --ops-ink: #d6e4f0;
  --ops-ink-muted: #7a8b9e;
  --ops-ink-faint: #3f4d5d;
  --ops-green: #3ddc97;
  --ops-amber: #f5b53d;
  --ops-orange: #fb923c;
  --ops-red: #f87171;
}

.mock__defcon-pill {
  position: absolute;
  top: 22px;
  right: 16px;
  z-index: 4;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px;
  border-radius: 999px;
  border: 1px solid var(--brand);
  background: color-mix(in oklab, var(--brand) 12%, var(--m-surface));
  color: var(--brand);
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 1.4px;
  cursor: pointer;
  user-select: none;
  transition: background 150ms ease, color 150ms ease, transform 150ms ease,
              box-shadow 150ms ease;
  box-shadow: 0 0 0 0 color-mix(in oklab, var(--brand) 50%, transparent);
  animation: defcon-pulse 2.4s ease-in-out infinite;
}
.mock__defcon-pill:hover {
  background: var(--brand);
  color: var(--on-brand, #fff);
  transform: translateY(-1px);
  animation: none;
  box-shadow: 0 6px 18px -6px color-mix(in oklab, var(--brand) 70%, transparent);
}

@keyframes defcon-pulse {
  0%, 100% {
    box-shadow: 0 0 0 0 color-mix(in oklab, var(--brand) 45%, transparent);
  }
  50% {
    box-shadow: 0 0 0 6px color-mix(in oklab, var(--brand) 0%, transparent);
  }
}

@media (prefers-reduced-motion: reduce) {
  .mock__defcon-pill { animation: none; }
}

/* When defcon is on AND hem tab is active: flip the entire mock dark. */
.mock:has(#mock-tab-hem:checked):has(#mock-defcon:checked) {
  background: var(--ops-bg);
  color: var(--ops-ink);
}
.mock:has(#mock-tab-hem:checked):has(#mock-defcon:checked) .mock__bar {
  color: var(--ops-ink);
}
.mock:has(#mock-tab-hem:checked):has(#mock-defcon:checked) .mock__tabs {
  background: var(--ops-bg);
  border-top-color: var(--ops-rule);
}
.mock:has(#mock-tab-hem:checked):has(#mock-defcon:checked) .mock__tab {
  color: var(--ops-ink-faint);
}
.mock:has(#mock-tab-hem:checked):has(#mock-defcon:checked) .mock__tab[for="mock-tab-hem"] {
  color: var(--ops-green);
}
.mock:has(#mock-tab-hem:checked):has(#mock-defcon:checked) .mock__tab[for="mock-tab-hem"]::before {
  background: var(--ops-green);
}

/* Defcon view content */
.mock__view--defcon {
  background: var(--ops-bg);
  color: var(--ops-ink);
  font-family: var(--font-mono);
  padding: 0 0 8px;
}

.mock__defcon-close {
  position: absolute;
  top: 7px;
  right: 14px;
  z-index: 4;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 1px solid var(--ops-rule);
  background: var(--ops-panel);
  color: var(--ops-ink-muted);
  font-size: 14px;
  line-height: 18px;
  text-align: center;
  cursor: pointer;
  user-select: none;
  font-family: var(--font-body);
}
.mock__defcon-close:hover { color: var(--ops-ink); }

/* Header strip */
.ops__header {
  padding: 12px 16px;
  border-bottom: 1px solid var(--ops-rule);
}
.ops__header-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}
.ops__live {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 1.4px;
  color: var(--ops-green);
}
.ops__live-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--ops-green);
  position: relative;
}
.ops__live-dot::after {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: 50%;
  background: var(--ops-green);
  opacity: 0.5;
  animation: ops-pulse 2.4s ease-out infinite;
}
@keyframes ops-pulse {
  0%   { transform: scale(1);   opacity: 0.5; }
  70%  { transform: scale(2.6); opacity: 0;   }
  100% { transform: scale(2.6); opacity: 0;   }
}
.ops__rule {
  width: 1px;
  height: 10px;
  background: var(--ops-rule);
}
.ops__callsign {
  font-size: 9px;
  letter-spacing: 1.2px;
  color: var(--ops-ink-muted);
}
.ops__date {
  font-size: 8.5px;
  letter-spacing: 1.6px;
  color: var(--ops-ink-faint);
  margin: 0 0 3px;
}
.ops__header-grid {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
}
.ops__label {
  font-size: 8.5px;
  letter-spacing: 1.6px;
  color: var(--ops-ink-faint);
  margin: 0 0 3px;
}
.ops__label--green { color: var(--ops-green); }
.ops__label--block { padding: 0 16px; margin-bottom: 8px; }
.ops__sector {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 1.2px;
  color: var(--ops-ink);
  margin: 0;
}
.ops__coord {
  font-size: 9px;
  color: var(--ops-ink-muted);
  margin: 2px 0 0;
  letter-spacing: 0.4px;
}
.ops__time-wrap { text-align: right; }
.ops__time {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 1.6px;
  color: var(--ops-ink);
  margin: 0;
  font-variant-numeric: tabular-nums;
}

/* Ticker */
.ops__ticker {
  margin: 10px 0 0;
  padding: 6px 0;
  border-top: 1px solid var(--ops-rule);
  border-bottom: 1px solid var(--ops-rule);
  background: var(--ops-panel);
  overflow: hidden;
  position: relative;
}
.ops__ticker-track {
  display: flex;
  gap: 28px;
  white-space: nowrap;
  animation: ops-ticker 28s linear infinite;
  font-size: 9.5px;
  letter-spacing: 1px;
  color: var(--ops-ink-muted);
  width: max-content;
}
.ops__ticker-track span { display: inline-flex; align-items: center; gap: 8px; }
.ops__tick-sev {
  display: inline-block;
  padding: 2px 5px;
  border-radius: 2px;
  font-size: 8.5px;
  letter-spacing: 1.2px;
  font-weight: 700;
}
.ops__tick-sev--info { color: var(--ops-green); border: 1px solid color-mix(in oklab, var(--ops-green) 40%, transparent); }
.ops__tick-sev--advisory { color: var(--ops-amber); border: 1px solid color-mix(in oklab, var(--ops-amber) 50%, transparent); }
@keyframes ops-ticker {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* Threat level */
.ops__threat {
  position: relative;
  margin: 14px 16px 0;
  padding: 14px 16px;
  border: 1px solid var(--ops-amber);
  background: var(--ops-panel);
}
.ops__corner {
  position: absolute;
  width: 9px;
  height: 9px;
  border-color: var(--ops-amber);
  border-style: solid;
  border-width: 0;
}
.ops__corner--tl { top: 0; left: 0; border-top-width: 2px; border-left-width: 2px; }
.ops__corner--tr { top: 0; right: 0; border-top-width: 2px; border-right-width: 2px; }
.ops__corner--bl { bottom: 0; left: 0; border-bottom-width: 2px; border-left-width: 2px; }
.ops__corner--br { bottom: 0; right: 0; border-bottom-width: 2px; border-right-width: 2px; }
.ops__threat-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}
.ops__threat-head .ops__label { margin: 0; }
.ops__pulse {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--ops-amber);
  margin-left: auto;
  position: relative;
}
.ops__pulse::after {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: 50%;
  background: var(--ops-amber);
  opacity: 0.45;
  animation: ops-pulse 2.4s ease-out infinite;
}
.ops__threat-row {
  display: flex;
  align-items: center;
  gap: 12px;
}
.ops__threat-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--ops-amber);
}
.ops__threat-label {
  font-size: 22px;
  font-weight: 900;
  letter-spacing: 2px;
  color: var(--ops-amber);
}
.ops__threat-stats {
  display: flex;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--ops-rule);
}
.ops__threat-stats > div { flex: 1; }
.ops__threat-stats .ops__label { margin: 0 0 4px; }
.ops__divider {
  width: 1px;
  background: var(--ops-rule);
  margin: 0 10px;
}
.ops__stat {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 1px;
  color: var(--ops-ink);
  margin: 0;
}
.ops__stat--accent { color: var(--ops-amber); }

/* Radar */
.ops__radar {
  margin: 12px 16px 0;
  padding: 12px;
  border: 1px solid var(--ops-rule);
  background: var(--ops-panel);
}
.ops__radar-head,
.ops__radar-foot {
  display: flex;
  justify-content: space-between;
}
.ops__radar-head { margin-bottom: 8px; }
.ops__radar-foot { margin-top: 8px; }
.ops__radar-head .ops__label,
.ops__radar-foot .ops__label { margin: 0; }
.ops__radar-scope {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  background: var(--ops-bg-grid);
  border: 1px solid var(--ops-rule);
  overflow: hidden;
  margin: 0 auto;
}
.ops__ring {
  position: absolute;
  top: 50%;
  left: 50%;
  border-radius: 50%;
  border: 1px solid var(--ops-rule);
  transform: translate(-50%, -50%);
}
.ops__ring--1 { width: 25%;  height: 25%; }
.ops__ring--2 { width: 50%;  height: 50%; }
.ops__ring--3 { width: 75%;  height: 75%; }
.ops__ring--4 { width: 100%; height: 100%; }
.ops__crosshair {
  position: absolute;
  background: var(--ops-rule);
}
.ops__crosshair--h { top: 50%; left: 0; width: 100%; height: 1px; }
.ops__crosshair--v { left: 50%; top: 0; width: 1px; height: 100%; }
.ops__sweep {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  pointer-events: none;
  background: conic-gradient(
    from 0deg,
    transparent 0deg,
    transparent 310deg,
    color-mix(in oklab, var(--ops-green) 55%, transparent) 360deg
  );
  animation: ops-sweep 4s linear infinite;
}
.ops__sweep::after {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  width: 2px;
  height: 50%;
  margin-left: -1px;
  background: var(--ops-green);
  opacity: 0.9;
}
@keyframes ops-sweep {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
.ops__center {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--ops-green);
  transform: translate(-50%, -50%);
  box-shadow: 0 0 8px color-mix(in oklab, var(--ops-green) 70%, transparent);
}
.ops__ping {
  position: absolute;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  border: 1px solid #000;
  transform: translate(-50%, -50%);
}
.ops__ping--info { background: var(--ops-green); }
.ops__ping--advisory { background: var(--ops-amber); }
.ops__ping--warning { background: var(--ops-orange); }

/* Section labels — [tick] LABEL [flex line] like the app's SectionLabel */
.ops__section { margin: 14px 16px 0; }
.ops__section-label {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}
.ops__section-tick {
  width: 14px;
  height: 1px;
  background: color-mix(in oklab, var(--ops-rule) 70%, var(--ops-ink-muted));
  flex-shrink: 0;
}
.ops__section-line {
  flex: 1;
  height: 1px;
  background: var(--ops-rule);
}
.ops__section-label-text {
  font-size: 9px;
  letter-spacing: 2px;
  font-weight: 700;
  color: var(--ops-ink-muted);
}
.ops__section-label--accent .ops__section-tick { background: var(--ops-green); }
.ops__section-label--accent .ops__section-label-text { color: var(--ops-green); }

/* Stats row */
.ops__stats-row {
  display: flex;
  border: 1px solid var(--ops-rule);
  background: var(--ops-panel);
}
.ops__stats-cell {
  flex: 1;
  padding: 12px;
}
.ops__stats-cell .ops__label { margin: 0 0 4px; }
.ops__stats-cell .ops__stat {
  font-size: 18px;
  margin: 0 0 4px;
  letter-spacing: 1px;
}
.ops__stat--green { color: var(--ops-green); }

/* Source grid */
.ops__source-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
}
.ops__source {
  padding: 9px 10px 10px;
  border: 1px solid var(--ops-rule);
  background: var(--ops-panel);
}
.ops__source-head {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 6px;
}
.ops__source-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}
.ops__source-dot--online { background: var(--ops-green); }
.ops__source-dot--syncing {
  background: var(--ops-amber);
  animation: ops-blink 1.2s ease-in-out infinite;
}
@keyframes ops-blink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.3; }
}
.ops__source-name {
  font-size: 9.5px;
  letter-spacing: 1.2px;
  color: var(--ops-ink);
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ops__source-count {
  display: flex;
  align-items: baseline;
  gap: 6px;
  margin: 0;
}
.ops__source-count b {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 1px;
  color: var(--ops-ink);
}
.ops__source-count span {
  font-size: 8.5px;
  letter-spacing: 1px;
  color: var(--ops-ink-faint);
}

/* Feed cards */
.ops__row--card {
  display: flex;
  border: 1px solid var(--ops-rule);
  background: var(--ops-panel);
  padding: 10px 12px;
  margin-top: 10px;
}
.ops__row--card:first-of-type { margin-top: 0; }
.ops__row-bar {
  width: 3px;
  align-self: stretch;
  margin-right: 12px;
  margin-top: 2px;
  margin-bottom: 2px;
  flex-shrink: 0;
}
.ops__row-bar--info { background: var(--ops-green); }
.ops__row-bar--advisory { background: var(--ops-amber); }
.ops__row-bar--warning { background: var(--ops-orange); }
.ops__row-text { flex: 1; min-width: 0; }
.ops__row-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 0 0 4px;
  font-size: 8.5px;
  letter-spacing: 1.2px;
}
.ops__row-time { color: var(--ops-ink-faint); }
.ops__row-sep { color: var(--ops-ink-faint); }
.ops__row-src { font-weight: 700; }
.ops__row-src--info { color: var(--ops-green); }
.ops__row-src--advisory { color: var(--ops-amber); }
.ops__row-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--ops-ink);
  letter-spacing: 0.4px;
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ops__row-area {
  font-size: 9.5px;
  letter-spacing: 0.6px;
  color: var(--ops-ink-muted);
  margin: 3px 0 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ops__footnote {
  margin: 14px 16px 0;
  padding-top: 10px;
  border-top: 1px solid var(--ops-rule);
  text-align: center;
  font-size: 8px;
  letter-spacing: 1.4px;
  color: var(--ops-ink-faint);
}

.ops__legend {
  display: flex;
  align-items: center;
  justify-content: space-between;
  list-style: none;
  margin: 8px 16px 0;
  padding: 0;
}
.ops__legend li {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 8.5px;
  letter-spacing: 1px;
  color: var(--ops-ink-faint);
}
.ops__legend-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}
.ops__legend-dot--info { background: var(--ops-green); }
.ops__legend-dot--advisory { background: var(--ops-amber); }
.ops__legend-dot--warning { background: var(--ops-orange); }
.ops__legend-dot--severe { background: var(--ops-red); }
.ops__legend-dot--extreme { background: #dc2626; }
