/* Tech Vision Joy Games — Memphis 80s pastel postmodern aesthetic
   (intentionally completely different from www.casualjoygames.com Bauhaus geometric) */
:root {
  --bone: #f7f3eb;
  --bone-2: #ece6d5;
  --memph-pink: #ff5fa2;
  --memph-blue: #2e8efa;
  --memph-yellow: #ffd84a;
  --memph-mint: #5fd7c4;
  --memph-coral: #ff7a4d;
  --memph-violet: #8c5cf2;
  --ink: #1d1a2e;
  --ink-soft: #524d6b;
  --display: 'Plus Jakarta Sans', system-ui, sans-serif;
  --body: 'Manrope', system-ui, sans-serif;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--bone); color: var(--ink); font-family: var(--body); font-size: 17px; line-height: 1.65; -webkit-font-smoothing: antialiased; }
body {
  background:
    radial-gradient(circle at 10% 8%,  var(--memph-pink) 1.5px, transparent 2px) 0 0 / 64px 64px,
    radial-gradient(circle at 50% 50%, var(--memph-blue) 1px,   transparent 1.5px) 16px 16px / 64px 64px,
    var(--bone);
}
a { color: var(--memph-violet); text-decoration: none; font-weight: 800; }
a:hover { color: var(--memph-pink); }
.wrap { max-width: 1180px; margin: 0 auto; padding: 0 28px; }
.wrap-narrow { max-width: 760px; margin: 0 auto; padding: 0 28px; }

header.tv-top { display: flex; justify-content: space-between; align-items: center; padding: 28px 0; flex-wrap: wrap; gap: 16px; }
.tv-mark { display: flex; align-items: center; gap: 14px; }
.tv-blob { width: 52px; height: 52px; background: var(--memph-yellow); border: 3px solid var(--ink); position: relative; transform: rotate(-6deg); display: flex; align-items: center; justify-content: center; color: var(--ink); font-family: var(--display); font-weight: 800; font-size: 18px; }
.tv-blob::before { content: ""; position: absolute; top: -8px; right: -8px; width: 18px; height: 18px; background: var(--memph-pink); border: 3px solid var(--ink); border-radius: 50%; }
.tv-name { font-family: var(--display); font-weight: 800; font-size: 22px; color: var(--ink); line-height: 1.1; letter-spacing: -0.02em; }
.tv-name .sub { display: block; font-family: var(--body); font-weight: 500; font-size: 12px; color: var(--ink-soft); letter-spacing: 0.18em; text-transform: uppercase; margin-top: 4px; }
nav.tv-nav a { margin-left: 22px; font-family: var(--display); font-weight: 700; font-size: 14px; color: var(--ink); }
nav.tv-nav a:hover { color: var(--memph-pink); }

/* Decorative shapes (positioned in hero / sections) */
.shape { position: absolute; pointer-events: none; }
.shape.zig { width: 80px; height: 16px; background: repeating-linear-gradient(135deg, var(--memph-pink) 0 8px, transparent 8px 16px); transform: rotate(-10deg); }
.shape.tri { width: 0; height: 0; border-left: 22px solid transparent; border-right: 22px solid transparent; border-bottom: 38px solid var(--memph-blue); }
.shape.dot-grid { width: 64px; height: 64px; background: radial-gradient(circle at 50% 50%, var(--ink) 1.5px, transparent 2px) 0 0 / 12px 12px; }
.shape.squig { width: 80px; height: 20px; background: repeating-radial-gradient(circle at 0 0, var(--memph-violet) 0 5px, transparent 5px 10px) ; }
.shape.bean { width: 80px; height: 40px; background: var(--memph-coral); border-radius: 50%; transform: rotate(20deg); }

/* Hero */
section.tv-hero { padding: 56px 0; position: relative; }
.tv-hero::before { content: ""; position: absolute; top: 10px; right: 8%; width: 64px; height: 64px; background: var(--memph-mint); border-radius: 50%; }
.tv-hero::after { content: ""; position: absolute; bottom: -20px; left: 8%; width: 0; height: 0; border-left: 28px solid transparent; border-right: 28px solid transparent; border-bottom: 48px solid var(--memph-coral); transform: rotate(-12deg); }
.tv-hero .badge { display: inline-block; padding: 8px 18px; background: var(--memph-mint); border: 3px solid var(--ink); font-family: var(--display); font-weight: 800; font-size: 13px; letter-spacing: 0.08em; text-transform: uppercase; box-shadow: 4px 4px 0 var(--ink); transform: rotate(-2deg); margin-bottom: 24px; }
.tv-hero h1 { font-family: var(--display); font-weight: 800; font-size: clamp(64px, 9vw, 132px); line-height: 0.95; letter-spacing: -0.04em; margin: 0 0 24px; color: var(--ink); }
.tv-hero h1 .p { color: var(--memph-pink); }
.tv-hero h1 .b { color: var(--memph-blue); }
.tv-hero h1 .y { background: var(--memph-yellow); padding: 0 14px; transform: rotate(-1deg); display: inline-block; border: 3px solid var(--ink); }
.tv-hero p.lead { font-size: 19px; max-width: 520px; color: var(--ink); position: relative; }
.tv-hero .strip { margin-top: 32px; display: inline-flex; gap: 12px; flex-wrap: wrap; }
.tv-hero .strip .chip { padding: 8px 16px; border: 3px solid var(--ink); background: white; font-family: var(--display); font-weight: 700; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; box-shadow: 3px 3px 0 var(--ink); }
.tv-hero .strip .chip:nth-child(1) { background: var(--memph-pink); color: white; }
.tv-hero .strip .chip:nth-child(2) { background: var(--memph-yellow); }
.tv-hero .strip .chip:nth-child(3) { background: var(--memph-mint); }

/* Section */
section.tv-section { padding: 64px 0; position: relative; }
.tv-eyebrow { font-family: var(--display); font-weight: 800; font-size: 13px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--memph-pink); margin-bottom: 12px; }
section.tv-section h2 { font-family: var(--display); font-weight: 800; font-size: clamp(44px, 6.5vw, 88px); line-height: 0.95; letter-spacing: -0.03em; margin: 0 0 16px; color: var(--ink); }
section.tv-section h2 em { font-style: normal; color: var(--memph-blue); }
section.tv-section p.lead { font-size: 18px; max-width: 60ch; color: var(--ink-soft); }

/* Games — postmodern cards */
.pmodern-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 32px; }
@media (max-width: 900px) { .pmodern-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .pmodern-grid { grid-template-columns: 1fr; } }
.pm-card { background: white; border: 3px solid var(--ink); padding: 22px 20px; box-shadow: 5px 5px 0 var(--ink); position: relative; transition: all .15s ease; overflow: hidden; }
.pm-card:nth-child(6n+1) { background: var(--memph-pink); color: white; }
.pm-card:nth-child(6n+2) { background: var(--memph-yellow); }
.pm-card:nth-child(6n+3) { background: var(--memph-mint); }
.pm-card:nth-child(6n+4) { background: var(--memph-blue); color: white; }
.pm-card:nth-child(6n+5) { background: var(--memph-coral); color: white; }
.pm-card:nth-child(6n+6) { background: var(--memph-violet); color: white; }
.pm-card:hover { transform: translate(-2px, -2px); box-shadow: 7px 7px 0 var(--ink); }
.pm-card .stamp { font-family: var(--display); font-weight: 800; font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; margin-bottom: 6px; opacity: 0.85; }
.pm-card h3 { font-family: var(--display); font-weight: 800; font-size: 17px; line-height: 1.15; margin: 0 0 6px; letter-spacing: -0.01em; }
.pm-card .alt { font-family: var(--body); font-size: 13px; opacity: 0.85; }
.pm-card::after { content: ""; position: absolute; bottom: -10px; right: -10px; width: 36px; height: 36px; background: var(--ink); border-radius: 50%; opacity: 0.18; }

/* Studio */
.tv-studio { padding: 56px; border: 3px solid var(--ink); background: var(--memph-yellow); margin: 32px 0; box-shadow: 8px 8px 0 var(--ink); position: relative; }
.tv-studio::before { content: ""; position: absolute; top: -16px; left: 32px; padding: 8px 16px; background: var(--memph-pink); color: white; font-family: var(--display); font-weight: 800; font-size: 13px; letter-spacing: 0.16em; text-transform: uppercase; border: 3px solid var(--ink); transform: rotate(-3deg); content: "/ the studio /"; }
.tv-studio h2 { color: var(--ink); margin-top: 24px; }
.tv-studio h2 em { color: var(--memph-violet); }
.tv-studio p { font-size: 19px; max-width: 60ch; color: var(--ink); margin: 0; }
.tv-studio p + p { margin-top: 12px; }

/* Contact */
.tv-contact { padding: 56px 32px; border: 3px solid var(--ink); background: var(--memph-mint); box-shadow: 8px 8px 0 var(--ink); margin: 24px 0; text-align: center; }
.tv-contact h3 { font-family: var(--display); font-weight: 800; font-size: 40px; margin: 0 0 16px; line-height: 1; color: var(--ink); letter-spacing: -0.02em; }
.tv-contact a.mail { font-family: var(--display); font-weight: 800; font-size: 22px; color: var(--memph-violet); border-bottom: 3px solid var(--ink); padding-bottom: 4px; }

footer.tv-foot { padding: 48px 0; text-align: center; color: var(--ink-soft); font-size: 14px; }
footer.tv-foot a { color: var(--memph-violet); margin: 0 10px; font-weight: 800; }
footer.tv-foot .row { display: inline-flex; gap: 6px; margin-bottom: 12px; }
footer.tv-foot .row span { width: 14px; height: 14px; border: 2px solid var(--ink); }
footer.tv-foot .row span:nth-child(1) { background: var(--memph-pink); }
footer.tv-foot .row span:nth-child(2) { background: var(--memph-blue); border-radius: 50%; }
footer.tv-foot .row span:nth-child(3) { background: var(--memph-yellow); }
footer.tv-foot .row span:nth-child(4) { background: var(--memph-mint); border-radius: 50%; }

/* Legal */
.legal-page { padding: 48px 0 96px; }
.legal-page .legal-eyebrow { font-family: var(--display); font-weight: 800; font-size: 13px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--memph-pink); margin-bottom: 12px; }
.legal-page h1 { font-family: var(--display); font-weight: 800; font-size: clamp(48px, 7vw, 92px); margin: 0 0 16px; line-height: 0.95; color: var(--ink); letter-spacing: -0.04em; }
.legal-page h1 em { font-style: normal; color: var(--memph-blue); }
.legal-page .back-link { font-family: var(--display); font-weight: 700; font-size: 13px; color: var(--memph-violet); }
.legal-page .legal-body { font-size: 16px; line-height: 1.78; color: var(--ink); margin-top: 32px; border: 3px solid var(--ink); padding: 32px; background: white; box-shadow: 8px 8px 0 var(--ink); max-width: 70ch; }
.legal-page .legal-body h2, .legal-page .legal-body h3, .legal-page .legal-body h4 { font-family: var(--display); color: var(--ink); font-weight: 800; margin: 1.6em 0 0.4em; line-height: 1.15; letter-spacing: -0.01em; }
.legal-page .legal-body h2 { font-size: 28px; color: var(--memph-pink); }
.legal-page .legal-body h3 { font-size: 22px; color: var(--memph-blue); }
.legal-page .legal-body h4 { font-size: 17px; color: var(--memph-violet); }
.legal-page .legal-body p { margin: 0 0 1em; }
.legal-page .legal-body strong { background: var(--memph-yellow); padding: 0 4px; }
.legal-page .legal-body a { border-bottom: 2px solid var(--memph-violet); }
.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: 14px; }
.legal-page .legal-body th, .legal-page .legal-body td { border: 2px solid var(--ink); padding: 10px 12px; vertical-align: top; text-align: left; }
.legal-page .legal-body th { background: var(--memph-yellow); font-family: var(--display); font-weight: 800; font-size: 13px; text-transform: uppercase; letter-spacing: 0.08em; }
