/* UStar Games — synthwave / retrowave 80s sunset (warm magenta + violet, no cyan) */
:root {
  --night: #2a0a2f;
  --night-2: #3a0a3f;
  --sun-1: #ff2c93;
  --sun-2: #ff7a3c;
  --sun-3: #ffd048;
  --grid-violet: #b34cff;
  --grid-rose: #ff8ed1;
  --star: #ffffff;
  --ink: #fff7fb;
  --ink-soft: rgba(255,247,251,0.78);
  --display: 'Monoton', 'Impact', sans-serif;
  --body: 'Rubik', system-ui, sans-serif;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--night); color: var(--ink); font-family: var(--body); font-size: 16px; line-height: 1.7; -webkit-font-smoothing: antialiased; }
body {
  background:
    radial-gradient(ellipse at 50% 25%, rgba(255,122,60,0.34) 0, transparent 40%),
    radial-gradient(ellipse at 80% 85%, rgba(255,44,147,0.26) 0, transparent 38%),
    linear-gradient(180deg, var(--night) 0%, var(--night-2) 100%);
  background-attachment: fixed;
}
a { color: var(--sun-3); text-decoration: none; font-weight: 500; }
a:hover { color: var(--sun-1); text-shadow: 0 0 12px var(--sun-1); }
.wrap { max-width: 1180px; margin: 0 auto; padding: 0 28px; position: relative; z-index: 2; }
.wrap-narrow { max-width: 760px; margin: 0 auto; padding: 0 28px; }

header.us-top { display: flex; justify-content: space-between; align-items: center; padding: 28px 0; flex-wrap: wrap; gap: 16px; border-bottom: 1px solid rgba(179,76,255,0.32); }
.us-mark { display: flex; align-items: center; gap: 14px; }
.us-star { width: 52px; height: 52px; display: flex; align-items: center; justify-content: center; font-size: 36px; color: var(--sun-3); text-shadow: 0 0 18px var(--sun-1); }
.us-name { font-family: var(--display); font-size: 26px; letter-spacing: 0.04em; color: var(--ink); line-height: 1; }
.us-name b { color: var(--sun-1); }
.us-name .sub { display: block; font-family: var(--body); font-size: 11px; color: var(--grid-rose); letter-spacing: 0.24em; text-transform: uppercase; margin-top: 6px; font-weight: 500; }
nav.us-nav a { margin-left: 24px; font-family: var(--display); font-size: 12px; letter-spacing: 0.18em; color: var(--ink); }
nav.us-nav a:hover { color: var(--sun-1); }

/* Hero — sunset DOMINANT, grid is secondary and warm */
section.us-hero { padding: 96px 0 80px; text-align: center; position: relative; overflow: hidden; }
.us-hero::before {
  content: ""; position: absolute; bottom: 0; left: 0; right: 0; height: 180px;
  background:
    linear-gradient(180deg, transparent 0, rgba(179,76,255,0.16) 80%, rgba(179,76,255,0.30) 100%),
    repeating-linear-gradient(90deg, rgba(179,76,255,0.30) 0 1px, transparent 1px 96px),
    repeating-linear-gradient(0deg,  rgba(255,142,209,0.22) 0 1px, transparent 1px 48px);
  transform: perspective(380px) rotateX(48deg); transform-origin: bottom; opacity: 0.7;
}
.us-hero .sun { position: absolute; bottom: 100px; left: 50%; transform: translateX(-50%); width: 480px; height: 480px; border-radius: 50%; background: linear-gradient(180deg, var(--sun-3) 0%, var(--sun-2) 48%, var(--sun-1) 100%); box-shadow: 0 0 120px rgba(255,44,147,0.55), 0 0 240px rgba(255,122,60,0.32); }
.us-hero .sun::before { content: ""; position: absolute; inset: 0; border-radius: 50%; background:
    repeating-linear-gradient(0deg, transparent 0 28px, var(--night-2) 28px 36px); mask: linear-gradient(180deg, transparent 0%, transparent 50%, black 50%, black 100%); -webkit-mask: linear-gradient(180deg, transparent 0%, transparent 50%, black 50%, black 100%); }
@media (max-width: 720px) { .us-hero .sun { width: 320px; height: 320px; bottom: 80px; } }
.us-hero .eyebrow { font-family: var(--display); font-size: 14px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--sun-3); margin-bottom: 24px; position: relative; z-index: 2; }
.us-hero h1 { font-family: var(--display); font-size: clamp(64px, 11vw, 152px); line-height: 0.95; margin: 0 0 24px; color: var(--ink); position: relative; z-index: 2; text-shadow: 0 4px 32px rgba(255,44,147,0.45); letter-spacing: 0.02em; }
.us-hero h1 em { font-style: italic; color: var(--sun-3); text-shadow: 0 4px 32px rgba(255,208,72,0.55); }
.us-hero p.lead { font-size: 19px; max-width: 540px; margin: 0 auto; color: var(--ink-soft); position: relative; z-index: 2; }
.us-hero .strip { margin-top: 40px; display: inline-flex; gap: 16px; flex-wrap: wrap; padding: 12px 24px; border: 1px solid var(--grid-violet); background: rgba(179,76,255,0.08); font-family: var(--display); font-size: 12px; letter-spacing: 0.22em; color: var(--ink); position: relative; z-index: 2; }
.us-hero .strip b { color: var(--sun-3); margin-left: 6px; }

/* Section */
section.us-section { padding: 80px 0; }
.us-eyebrow { font-family: var(--display); font-size: 13px; letter-spacing: 0.32em; color: var(--sun-1); text-align: center; margin-bottom: 12px; }
section.us-section h2 { font-family: var(--display); font-size: clamp(40px, 6vw, 76px); line-height: 1; margin: 0 0 16px; text-align: center; color: var(--ink); }
section.us-section h2 em { font-style: italic; color: var(--sun-3); }
section.us-section p.lead { text-align: center; font-size: 18px; max-width: 56ch; margin: 0 auto 32px; color: var(--ink-soft); }

/* Games — cassette grid */
.cassette-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 32px; }
@media (max-width: 800px) { .cassette-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .cassette-grid { grid-template-columns: 1fr; } }
.tape { background: rgba(255,44,147,0.08); border: 1px solid var(--sun-1); padding: 24px 22px; position: relative; transition: all .15s ease; overflow: hidden; }
.tape::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 6px; background: linear-gradient(90deg, var(--sun-1), var(--sun-2), var(--sun-3)); }
.tape:hover { transform: translateY(-3px); box-shadow: 0 12px 32px rgba(255,44,147,0.22); }
.tape .stamp { font-family: var(--display); font-size: 12px; letter-spacing: 0.24em; color: var(--grid-violet); margin-top: 8px; margin-bottom: 8px; }
.tape h3 { font-family: var(--display); font-size: 22px; line-height: 1.1; margin: 0 0 6px; color: var(--ink); letter-spacing: 0.02em; }
.tape .alt { font-family: var(--body); font-size: 13px; color: var(--ink-soft); letter-spacing: 0.04em; }

/* Studio panel */
.us-studio { padding: 56px; border: 1px solid var(--sun-1); margin: 32px 0; background: rgba(255,44,147,0.04); position: relative; }
.us-studio::before, .us-studio::after { content: ""; position: absolute; width: 24px; height: 24px; }
.us-studio::before { top: -1px; left: -1px; border-top: 2px solid var(--grid-violet); border-left: 2px solid var(--grid-violet); }
.us-studio::after { bottom: -1px; right: -1px; border-bottom: 2px solid var(--sun-3); border-right: 2px solid var(--sun-3); }
.us-studio p { font-size: 18px; max-width: 60ch; margin: 0; color: var(--ink); }
.us-studio p + p { margin-top: 12px; color: var(--ink-soft); }

/* Contact */
.us-contact { text-align: center; padding: 64px 32px; border-top: 1px solid var(--grid-violet); border-bottom: 1px solid var(--sun-1); margin: 24px 0; }
.us-contact h3 { font-family: var(--display); font-size: 36px; margin: 0 0 16px; color: var(--ink); }
.us-contact a.mail { font-family: var(--display); font-size: 20px; color: var(--sun-3); border-bottom: 1px solid var(--sun-1); padding-bottom: 4px; letter-spacing: 0.04em; }

footer.us-foot { padding: 48px 0; text-align: center; font-family: var(--display); font-size: 12px; letter-spacing: 0.28em; color: var(--ink-soft); }
footer.us-foot a { color: var(--sun-3); margin: 0 12px; }

/* Legal */
.legal-page { padding: 48px 0 96px; }
.legal-page .legal-eyebrow { font-family: var(--display); font-size: 12px; letter-spacing: 0.32em; color: var(--sun-1); text-align: center; margin-bottom: 14px; }
.legal-page h1 { font-family: var(--display); font-size: clamp(44px, 7vw, 84px); margin: 0 0 16px; line-height: 1; color: var(--ink); text-align: center; text-shadow: 0 4px 32px rgba(255,44,147,0.45); letter-spacing: 0.02em; }
.legal-page h1 em { font-style: italic; color: var(--sun-3); }
.legal-page .back-link { display: block; text-align: center; font-family: var(--display); font-size: 12px; letter-spacing: 0.28em; color: var(--grid-violet); margin-bottom: 32px; }
.legal-page .legal-body { font-size: 15px; line-height: 1.85; color: var(--ink); margin-top: 24px; border-top: 1px solid var(--sun-1); padding-top: 32px; max-width: 70ch; margin-left: auto; margin-right: auto; }
.legal-page .legal-body h2, .legal-page .legal-body h3, .legal-page .legal-body h4 { font-family: var(--display); color: var(--ink); margin: 1.8em 0 0.5em; line-height: 1.15; letter-spacing: 0.02em; }
.legal-page .legal-body h2 { font-size: 24px; color: var(--sun-1); }
.legal-page .legal-body h3 { font-size: 18px; color: var(--grid-violet); }
.legal-page .legal-body h4 { font-size: 14px; color: var(--sun-3); }
.legal-page .legal-body p { margin: 0 0 1em; }
.legal-page .legal-body strong { color: var(--sun-3); }
.legal-page .legal-body a { color: var(--sun-3); border-bottom: 1px solid var(--sun-1); }
.legal-page .legal-body ul, .legal-page .legal-body ol { padding-left: 1.4em; margin: 0 0 1em; }
.legal-page .legal-body li { margin-bottom: 0.4em; }
.legal-page .legal-body table { width: 100%; border-collapse: collapse; margin: 1.5em 0; font-size: 13px; }
.legal-page .legal-body th, .legal-page .legal-body td { border: 1px solid rgba(179,76,255,0.32); padding: 10px 12px; vertical-align: top; text-align: left; }
.legal-page .legal-body th { background: rgba(255,44,147,0.12); font-family: var(--display); font-weight: 400; color: var(--grid-violet); letter-spacing: 0.12em; font-size: 12px; }
