:root {
    --page: #eef0f3;
    --paper: #fff;
    --paper-2: #f7f8fa;
    --ink: #15171f;
    --ink-2: #2a2e3a;
    --muted: #7c818d;
    --line: #c4c8d2;
    --line-soft: #dbdee4;
    --block: #d6d9e0;
    --block-2: #c2c6cf;
    --block-dark: #2c3040;
    --block-darker: #1a1d28;
    --accent: #1aa46a;
    --accent-2: #f06b4d;
    --accent-3: #f1c40f;
    --accent-4: #6e62ff;
    --bad: #d34a4a;
    --good: #1aa46a;
    --radius-sm: 4px;
    --radius: 8px;
    --radius-lg: 12px;
    --gap: 14px;
    --gap-lg: 22px;
    --gap-xl: 36px;
    --font-sans: "Helvetica Neue", Helvetica, Arial, sans-serif;
    --font-mono: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
    --font-hand: "Caveat", "Comic Sans MS", cursive
}

* {
    box-sizing: border-box
}

html,
body {
    margin: 0;
    padding: 0
}

body {
    background: var(--page);
    color: var(--ink);
    font: 14px/1.5 var(--font-sans);
    min-height: 100vh
}

.type-tab:hover {
    color: #fff
}

.page-tab:hover {
    color: var(--ink)
}

.wf-frame {
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--radius-lg);
    box-shadow: 0 24px 60px -32px rgba(15, 18, 28, 0.25), 0 2px 0 rgba(0, 0, 0, 0.02);
    overflow: hidden
}

.wf-frame-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 14px;
    background: var(--paper-2);
    border-bottom: 1px solid var(--line-soft);
    font: 600 12px/1 var(--font-mono);
    color: var(--muted)
}

.wf-frame-head .lbl {
    color: var(--ink)
}

.wf-frame-head .dots {
    display: inline-flex;
    gap: 5px
}

.wf-frame-head .dots i {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: var(--line);
    display: inline-block
}

.wf-frame-body {
    padding: 0
}

.ph {
    position: relative;
    display: grid;
    place-items: center;
    background: repeating-linear-gradient(135deg, var(--block)0 6px, var(--block-2) 6px 7px);
    border: 1px dashed var(--line);
    border-radius: var(--radius-sm);
    color: var(--ink-2);
    font: 600 11px/1.3 var(--font-mono);
    letter-spacing: .04em;
    text-align: center;
    padding: 8px;
    overflow: hidden
}

.ph.dark {
    background: var(--block-dark);
    color: #e8eaf0;
    border-color: #000
}

.ph.flat {
    background: var(--paper-2);
    border-style: solid;
    color: var(--muted)
}

.ph .ph-tag {
    position: absolute;
    top: 6px;
    left: 6px;
    background: rgba(255, 255, 255, .85);
    color: var(--ink);
    padding: 2px 6px;
    font: 600 10px/1 var(--font-mono);
    border-radius: 3px;
    pointer-events: none
}

.ph.dark .ph-tag {
    background: rgba(0, 0, 0, .55);
    color: #fff
}

.txt {
    height: 12px;
    background: var(--block);
    border-radius: 3px
}

.txt.on-dark {
    background: rgba(255, 255, 255, 0.18)
}

.lines {
    display: grid;
    gap: 6px
}

.btn {
    display: inline-grid;
    place-items: center;
    height: 36px;
    padding: 0 18px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: var(--paper);
    color: var(--ink);
    font: 700 12px/1 var(--font-sans);
    letter-spacing: .04em;
    text-transform: uppercase;
    white-space: nowrap
}

.btn.accent {
    background: var(--accent);
    color: #fff;
    border-color: var(--accent)
}

.btn.cta {
    background: var(--accent-2);
    color: #fff;
    border-color: var(--accent-2)
}

.btn.ghost {
    background: transparent
}

.btn.sm {
    height: 28px;
    padding: 0 12px;
    font-size: 11px
}

.btn.lg {
    height: 46px;
    padding: 0 26px;
    font-size: 13px
}

.tag {
    display: inline-grid;
    place-items: center;
    height: 22px;
    padding: 0 10px;
    border-radius: 999px;
    font: 700 10px/1 var(--font-mono);
    letter-spacing: .06em;
    text-transform: uppercase
}

.tag.warn {
    background: var(--accent-3);
    color: #1a1d28
}

.tag.info {
    background: var(--accent-4);
    color: #fff
}

.tag.ghost {
    background: transparent;
    border: 1px solid var(--line);
    color: var(--muted)
}

.icon-sq {
    border: 1px solid var(--line);
    background: var(--paper-2);
    flex-shrink: 0
}

.site {
    background: var(--paper);
    display: grid
}

.site-header {
    display: grid;
    grid-template-columns: 140px 1fr auto;
    align-items: center;
    gap: 18px;
    padding: 14px 28px;
    border-bottom: 1px solid var(--line-soft)
}

.site-logo {
    display: grid;
    place-items: center;
    height: 32px;
    border: 1px dashed var(--line);
    border-radius: 6px;
    color: var(--ink);
    font: 800 12px/1 var(--font-mono);
    letter-spacing: .08em
}

.site-nav {
    display: flex;
    gap: 22px;
    flex-wrap: wrap;
    justify-content: center
}

.site-nav a {
    font: 600 12px/1 var(--font-sans);
    color: var(--ink-2);
    cursor: pointer
}

.site-nav a.is-active {
    color: var(--accent)
}

.site-actions {
    display: flex;
    gap: 10px;
    align-items: center
}

.site-section {
    padding: 32px 28px;
    border-bottom: 1px solid var(--line-soft)
}

.site-section.hero {
    padding: 40px 28px 28px
}

.site-section.bg {
    background: var(--paper-2)
}

.site-h {
    font: 800 22px/1.15 var(--font-sans)
}

.site-grid {
    display: grid;
    gap: var(--gap)
}

.cols-2 {
    grid-template-columns: repeat(2, 1fr)
}

.cols-3 {
    grid-template-columns: repeat(3, 1fr)
}

.cols-4 {
    grid-template-columns: repeat(4, 1fr)
}

.row {
    display: flex;
    gap: var(--gap);
    align-items: center
}

.row.wrap {
    flex-wrap: wrap
}

.row.between {
    justify-content: space-between
}

.stack {
    display: grid
}

.stack.tight {
    gap: 8px
}

.spacer {
    height: var(--gap)
}

.card {
    background: var(--paper);
    border: 1px solid var(--line-soft);
    border-radius: var(--radius);
    display: grid
}

.game-card {
    display: grid;
    gap: 8px
}

.game-card .meta {
    font: 600 12px/1.2 var(--font-sans)
}

.game-card .provider {
    font: 500 10px/1 var(--font-mono);
    color: var(--muted)
}

.stars {
    display: inline-flex;
    gap: 2px;
    align-items: center;
    font: 700 12px/1 var(--font-sans)
}

.stars .s {
    width: 12px;
    height: 12px;
    background: var(--accent-3);
    clip-path: polygon(50%0, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%)
}

.stars .s.empty {
    background: var(--line)
}

.site-footer {
    padding: 28px;
    background: var(--ink);
    color: #c4c8d2;
    display: grid;
    gap: 18px
}

.site-footer .cols {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 28px
}

.site-footer h5 {
    margin: 0 0 10px;
    font: 700 11px/1 var(--font-mono);
    letter-spacing: .08em;
    text-transform: uppercase;
    color: #fff
}

.site-footer .links {
    display: grid;
    gap: 6px
}

.site-footer .links span {
    font-size: 12px
}

.site-footer .disclaimer {
    border-top: 1px solid #2a2e3a;
    padding-top: 18px;
    font-size: 11px;
    color: #7c818d;
    display: grid;
    gap: 6px
}

.pin {
    position: relative;
    display: inline-grid;
    place-items: center;
    width: 22px;
    height: 22px;
    border-radius: 999px;
    background: var(--accent-4);
    color: #fff;
    font: 800 11px/1 var(--font-mono);
    flex-shrink: 0
}

.anno {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    background: rgba(110, 98, 255, 0.12);
    border: 1px dashed var(--accent-4);
    border-radius: 999px;
    font: 600 11px/1 var(--font-mono);
    color: var(--accent-4)
}

.notes {
    margin-top: 16px;
    padding: 14px 16px;
    background: var(--paper-2);
    border: 1px dashed var(--line);
    border-radius: var(--radius)
}

.notes h4 {
    margin: 0 0 8px;
    font: 700 11px/1 var(--font-mono);
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--muted)
}

.notes ol {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 6px
}

.notes li {
    display: grid;
    grid-template-columns: 22px 1fr;
    gap: 10px;
    align-items: start;
    font-size: 12px;
    color: var(--ink-2)
}

.notes li .pin {
    width: 18px;
    height: 18px;
    font-size: 10px
}

.muted {
    color: var(--muted)
}

.center {
    text-align: center
}

.mono {
    font-family: var(--font-mono)
}

.grow {
    flex: 1
}

.shell {
    min-height: 100vh;
    background: var(--page);
    display: grid;
    grid-template-rows: auto 1fr
}

.shell-bar {
    position: sticky;
    top: 0;
    z-index: 80;
    background: rgba(15, 17, 25, 0.96);
    color: #fff;
    backdrop-filter: blur(10px);
    border-bottom: 1px solid rgba(0, 0, 0, 0.4)
}

.shell-bar-inner {
    max-width: 1480px;
    margin: 0 auto;
    padding: 10px 22px;
    display: flex;
    align-items: center;
    gap: 18px;
    flex-wrap: wrap
}

.shell-brand {
    font: 700 12px/1 var(--font-mono);
    letter-spacing: .08em;
    color: #fff;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 8px
}

.shell-brand .dot {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: var(--accent);
    display: inline-block
}

.shell-crumbs {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #8a8e99;
    font: 600 12px/1 var(--font-mono);
    letter-spacing: .02em
}

.shell-crumbs a {
    color: #c4c8d2;
    text-decoration: none
}

.shell-crumbs a:hover {
    color: #fff
}

.shell-crumbs .sep {
    opacity: .4
}

.shell-crumbs .cur {
    color: #fff
}

.shell-pages {
    display: inline-flex;
    gap: 4px;
    margin-left: auto;
    align-items: center;
    flex-wrap: wrap
}

.shell-page-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    border-radius: 999px;
    background: transparent;
    color: #a4a8b3;
    font: 600 11px/1 var(--font-sans);
    text-decoration: none;
    border: 1px solid transparent
}

.shell-page-link:hover {
    color: #fff;
    background: rgba(255, 255, 255, 0.05)
}

.shell-page-link.is-active {
    background: var(--accent);
    color: #fff;
    border-color: var(--accent)
}

.shell-page-link .n {
    font-family: var(--font-mono);
    font-size: 10px;
    opacity: .7
}

.shell-stage {
    max-width: 1480px;
    margin: 0 auto;
    padding: 28px 22px 60px;
    width: 100%
}

.shell-intro {
    display: grid;
    gap: 6px;
    padding: 0 0 22px;
    margin-bottom: 22px;
    border-bottom: 1px dashed var(--line)
}

.shell-intro h2 {
    margin: 0;
    font-size: 24px;
    font-weight: 800;
    letter-spacing: -0.01em
}

.shell-intro p {
    margin: 0;
    color: var(--muted);
    max-width: 760px;
    font-size: 14px
}

.shell-intro .meta-row {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 6px
}

.hub-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 24px 60px -28px rgba(15, 18, 28, 0.25);
    border-color: var(--ink)
}

.hub-card .pages a:hover {
    background: var(--ink);
    color: #fff;
    border-color: var(--ink)
}