:root {
  --bg: #000000;
  --fg: #ffffff;
  --muted: rgba(255,255,255,.70);
  --soft: rgba(255,255,255,.38);
  --line: rgba(255,255,255,.20);
  --glow: rgba(255,255,255,.10);
}

* { box-sizing: border-box; }

html, body { min-height: 100%; }

body {
  margin: 0;
  font-family: "Inter", Arial, Helvetica, sans-serif;
  color: var(--fg);
  background: var(--bg);
  overflow-x: hidden;
}

.page {
  position: relative;
  min-height: 100svh;
  display: grid;
  place-items: center;
  padding: clamp(28px, 6vw, 72px) 20px;
  isolation: isolate;
  background: #000000;
}

.page::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: -2;
  background: repeating-linear-gradient(90deg, transparent 0 28px, rgba(255,255,255,.018) 29px 30px);
  opacity: 0;
}

.hero {
  width: min(92vw, 520px);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  animation: appear .9s ease both;
}

.logo {
  width: clamp(64px, 7vw, 96px);
  height: auto;
  color: var(--fg);
  filter: drop-shadow(0 0 26px var(--glow));
  margin-bottom: clamp(18px, 2.2vw, 26px);
}

.brand h1 {
  margin: 0;
  font-size: clamp(21px, 2.5vw, 36px);
  line-height: 1;
  letter-spacing: clamp(.24em, .7vw, .38em);
  font-weight: 700;
  padding-left: .34em;
}

.design-line {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 13px;
  margin-top: 9px;
}

.design-line span {
  display: block;
  width: 35px;
  height: 1px;
  background: var(--soft);
}

.design-line p {
  margin: 0;
  font-size: clamp(9px, 1vw, 13px);
  letter-spacing: .54em;
  padding-left: .54em;
  color: var(--muted);
  font-weight: 400;
}

.tagline {
  margin: clamp(28px, 4.2vw, 44px) 0 0;
  color: rgba(255,255,255,.86);
  font-size: clamp(13px, 1.45vw, 18px);
  line-height: 1.5;
  letter-spacing: .07em;
  font-weight: 300;
}

.divider {
  display: block;
  width: 1px;
  height: clamp(34px, 5vw, 58px);
  background: linear-gradient(180deg, transparent, var(--soft), transparent);
  margin: clamp(28px, 4.6vw, 48px) 0 clamp(25px, 3.8vw, 38px);
}

.message { margin: 0 0 22px; }

.status,
.substatus {
  margin: 0;
  line-height: 1.55;
  font-weight: 300;
}

.status {
  font-size: clamp(14px, 1.5vw, 18px);
  color: rgba(255,255,255,.92);
}

.substatus {
  font-size: clamp(12px, 1.25vw, 15px);
  color: var(--muted);
}

.instagram {
  width: min(220px, 78vw);
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  padding: 12px 18px;
  border: 1px solid rgba(255,255,255,.55);
  border-radius: 5px;
  color: var(--fg);
  text-decoration: none;
  background: rgba(255,255,255,.018);
  transition: transform .25s ease, border-color .25s ease, background .25s ease, box-shadow .25s ease;
}

.instagram svg {
  width: 21px;
  height: 21px;
  fill: currentColor;
  flex: 0 0 auto;
}

.instagram span {
  width: 1px;
  height: 22px;
  background: var(--line);
}

.instagram strong {
  font-size: 13px;
  letter-spacing: .02em;
  font-weight: 400;
}

.instagram:hover,
.instagram:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.95);
  background: rgba(255,255,255,.045);
  box-shadow: 0 0 34px rgba(255,255,255,.08);
  outline: none;
}

.dots {
  position: absolute;
  width: 96px;
  height: 96px;
  opacity: .78;
  background-image: radial-gradient(circle, rgba(255,255,255,.85) 1.5px, transparent 1.8px);
  background-size: 18px 18px;
}

.dots-top { top: 7vh; right: 7vw; }
.dots-bottom { bottom: 7vh; left: 4vw; }


.dots {
  position: absolute;
  width: 96px;
  height: 96px;
  opacity: .74;
  background-image: radial-gradient(circle, rgba(255,255,255,.82) 1.4px, transparent 1.8px);
  background-size: 18px 18px;
}

.dots-top { top: 7vh; right: 7vw; }
.dots-bottom { bottom: 7vh; left: 4vw; }

.decor {
  position: absolute;
  pointer-events: none;
  opacity: .32;
  width: clamp(220px, 26vw, 430px);
  height: clamp(220px, 26vw, 430px);
}

.decor::before,
.decor::after {
  content: "";
  position: absolute;
  inset: 0;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url("data:image/svg+xml,%3Csvg width='420' height='420' viewBox='0 0 420 420' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='rgba(255,255,255,0.45)' stroke-width='1'%3E%3Cpath d='M72 44l58 34-58 34-58-34 58-34zM14 78v68l58 34 58-34V78M72 112v68'/%3E%3Cpath d='M188 44l58 34-58 34-58-34 58-34zM130 78v68l58 34 58-34V78M188 112v68'/%3E%3Cpath d='M130 146l58 34-58 34-58-34 58-34zM72 180v68l58 34 58-34v-68M130 214v68'/%3E%3Cpath d='M246 146l58 34-58 34-58-34 58-34zM188 180v68l58 34 58-34v-68M246 214v68'/%3E%3Cpath d='M304 248l58 34-58 34-58-34 58-34zM246 282v68l58 34 58-34v-68M304 316v68'/%3E%3C/g%3E%3C/svg%3E");
}

.decor-left { top: -80px; left: -35px; transform: rotate(0deg); }
.decor-right { right: -90px; bottom: -70px; transform: rotate(0deg); }

@keyframes appear {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

@media (max-width: 900px) {
  .decor { opacity: .22; }
  .dots { width: 78px; height: 78px; background-size: 16px 16px; }
}

@media (max-width: 640px) {
  .page { padding: 30px 18px; }
  .hero { width: min(100%, 360px); }
  .logo { width: 64px; margin-bottom: 18px; }
  .brand h1 { font-size: 22px; }
  .design-line span { width: 28px; }
  .tagline { max-width: 260px; margin-top: 28px; }
  .divider { height: 34px; margin: 26px 0 24px; }
  .message { margin-bottom: 18px; }
  .instagram { width: 214px; min-height: 46px; }
  .dots-top { top: 28px; right: 22px; }
  .dots-bottom { bottom: 28px; left: 22px; }
  .decor-left { top: -60px; left: -100px; }
  .decor-right { right: -130px; bottom: -70px; }
}

@media (max-width: 380px) {
  .instagram { width: 206px; gap: 12px; }
  .instagram strong { font-size: 12px; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}
